![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/html/libs/absol-vchart/dist/ |
Upload File : |
/******/ (() => { // webpackBootstrap /******/ var __webpack_modules__ = ({ /***/ 6657: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ absol_acomp_AComp) }); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/MultiLanguageCSS.js var MultiLanguageCSS = __webpack_require__(1812); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DebugTask.js var _ = ACore/* default._ */.Z._; var $ = ACore/* default.$ */.Z.$; var originSetTimeout = setTimeout; var originClearTimeout = clearTimeout; var originSetInterval = setInterval; var originClearInterval = clearInterval; var pendingTimeout = 0; var pendingInterval = 0; var timeoutDict = {}; var intervalDict = {}; function DebugTask() { var res = _({ class: 'absol-debug-task', child: [ { child: [{ tag: 'span', class: 'absol-debug-task-name', child: { text: 'settimeout ' } }, { tag: 'span', class: ['absol-debug-task-value', 'settimeout'], child: { text: '0' } }] }, { child: [{ tag: 'span', class: 'absol-debug-task-name', child: { text: 'setintervel ' } }, { tag: 'span', class: ['absol-debug-task-value', 'setinterval'], child: { text: '0' } }, ] }, { child: [{ tag: 'span', class: 'absol-debug-task-name', child: { text: 'Work ' } }, { tag: 'span', class: ['absol-debug-task-value', 'work'], child: { text: '0%' } }, ] } ] }); res._timeout = 0; res._interval = 0; res._work = 0; res.$setTimeOutValue = $('.absol-debug-task-value.settimeout', res); res.$setIntervalValue = $('.absol-debug-task-value.setinterval', res); res.$setWorkValue = $('.absol-debug-task-value.work', res); return res; } DebugTask.property = {}; DebugTask.property.timeout = { set: function (value) { this._timeout = value; this.$setTimeOutValue.innerHTML = value + ''; }, get: function () { return this._timeout; } }; DebugTask.property.interval = { set: function (value) { this._interval = value; this.$setIntervalValue.innerHTML = value + ''; }, get: function () { return this._interval; } }; DebugTask.property.work = { set: function (value) { this._work = value; value = (value * 100).toFixed(1); this.$setWorkValue.innerHTML = value + '%'; }, get: function () { return this._work; } }; DebugTask.start = function () { if (DebugTask.started) return; if (!DebugTask.$view) { DebugTask.$view = _('debugtask'); } var times = []; originSetInterval(function(){ var now = performance.now(); while (times.length > 0 && times[0].end < now - 2000) { times.shift(); } if (times.length == 0) DebugTask.$view.work = 0; },3000); __webpack_require__.g.setTimeout = function () { var args = Array.prototype.map.call(arguments, function (x) { return x; }); var originCallback = arguments[0]; if (typeof originCallback == 'undefined') return; if (typeof originCallback == 'string') { originCallback = new Function(originCallback); } args[0] = function () { var ret; try { var now = performance.now(); while (times.length > 0 && times[0].end < now - 1000) { times.shift(); } ret = originCallback.apply(null, arguments); var now1 = performance.now(); var long = now1 - now; times.push({ long:long, start:now, end:now1 }); var sTime = 0; for (var i = 0; i< times.length; ++i ){ sTime+= times[i].long; } DebugTask.$view.work = sTime/(Math.max(now1 - times[0].start, 1000)); } catch (e) { console.error(e); } if (timeoutDict[timeoutId]) { pendingTimeout--; delete timeoutDict[timeoutId]; DebugTask.$view.timeout = pendingTimeout; } return ret; } var timeoutId = originSetTimeout.apply(__webpack_require__.g, args) pendingTimeout++; timeoutDict[timeoutId] = true; DebugTask.$view.timeout = pendingTimeout; return timeoutId; } __webpack_require__.g.clearTimeout = function (timeoutId) { if (timeoutDict[timeoutId]) { pendingTimeout--; delete timeoutDict[timeoutId]; DebugTask.$view.timeout = pendingTimeout; } return originClearTimeout.apply(__webpack_require__.g, arguments); }; __webpack_require__.g.setInterval = function () { var args = Array.prototype.map.call(arguments, function (x) { return x; }); var originCallback = arguments[0]; if (typeof originCallback == 'undefined') return; if (typeof originCallback == 'string') { originCallback = new Function(originCallback); } args[0] = function () { var ret; try { var now = performance.now(); while (times.length > 0 && times[0].end < now - 1000) { times.shift(); } ret = originCallback.apply(null, arguments); var now1 = performance.now(); var long = now1 - now; times.push({ long:long, start:now, end:now1 }); var sTime = 0; for (var i = 0; i< times.length; ++i ){ sTime+= times[i].long; } DebugTask.$view.work = sTime/(Math.max(now1 - times[0].start, 1000)); } catch (e) { console.error(e); } return ret; } var intervalId = originSetInterval.apply(__webpack_require__.g, args) pendingInterval++; intervalDict[intervalId] = true; DebugTask.$view.interval = pendingInterval; return intervalId; } __webpack_require__.g.clearInterval = function (intervalId) { var args = Array.prototype.map.call(arguments, function (x) { return x; }); if (intervalDict[intervalId]) { pendingInterval--; delete intervalDict[intervalId]; DebugTask.$view.interval = pendingInterval; } return originClearInterval.apply(__webpack_require__.g, args); }; Dom/* default.documentReady.then */.ZP.documentReady.then(function () { DebugTask.$view.addTo(document.body); }); }; ACore/* default.install */.Z.install('debugtask', DebugTask); /* harmony default export */ const js_DebugTask = (DebugTask); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/debugtask.css var debugtask = __webpack_require__(7388); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/common.css var common = __webpack_require__(8826); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Draggable.js var Draggable = __webpack_require__(5611); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiChars.js var EmojiChars = __webpack_require__(7712); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiAnims.js var EmojiAnims = __webpack_require__(4670); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/dom/install.js + 242 modules var install = __webpack_require__(6369); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tool/BlurTrigger.js var BlurTrigger = __webpack_require__(9346); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/AComp.js var AComp = { core: ACore/* default */.Z, $: ACore/* default.$ */.Z.$, _: ACore/* default._ */.Z._, creator: ACore/* default.creator */.Z.creator, buildDom: ACore/* default.buildDom */.Z.buildDom, runDebugTask: js_DebugTask.start.bind(js_DebugTask), Draggable: Draggable/* default */.Z, EmojiChars: EmojiChars/* default */.Z, EmojiAnims: EmojiAnims/* default */.Z, install: install/* default */.Z, BlurTrigger: BlurTrigger/* default */.Z }; window.runDebugTask = js_DebugTask.start.bind(js_DebugTask); /* harmony default export */ const absol_acomp_AComp = (AComp); /***/ }), /***/ 3855: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "_": () => (/* binding */ _), /* harmony export */ "$": () => (/* binding */ $), /* harmony export */ "$$": () => (/* binding */ $$), /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_default_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4630); /* harmony import */ var _css_default_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_default_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6628); var ACore = new absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .ZP({ creator: Object.assign({}, absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* ["default"].ShareInstance.creator */ .ZP.ShareInstance.creator) }); var _ = ACore._; var $ = ACore.$; var $$ = ACore.$$; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ACore); /***/ }), /***/ 9782: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6628); /* harmony import */ var _ContextMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7054); /* harmony import */ var absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(557); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(3349); /* harmony import */ var absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(9399); /*** * simple way, to replace old ContextCapture version ***/ function BContextCapture() { absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* ["default"].call */ .ZP.call(this); this.sync = Promise.resolve(); this.$root = null; this._pointerSession = 0; this.ev_contextMenu = this.ev_contextMenu.bind(this); } absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_4__/* ["default"].mixClass */ .ZP.mixClass(BContextCapture, absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .ZP); BContextCapture.prototype.attachTo = function (elt) { if (this.$root) this.$root.removeEventListener('contextmenu', this.ev_contextMenu, false); this.$root = elt; if (this.$root) this.$root.addEventListener('contextmenu', this.ev_contextMenu, false); } BContextCapture.prototype.auto = function () { absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].documentReady.then */ .ZP.documentReady.then(function () { this.attachTo(document.body); }.bind(this)); }; BContextCapture.prototype.showContextMenu = _ContextMenu__WEBPACK_IMPORTED_MODULE_1__/* ["default"].prototype.showContextMenu */ .Z.prototype.showContextMenu; BContextCapture.prototype._fireContextMenuEvent = _ContextMenu__WEBPACK_IMPORTED_MODULE_1__/* ["default"].prototype._fireContextMenuEvent */ .Z.prototype._fireContextMenuEvent; BContextCapture.prototype._checkNeedHandle = _ContextMenu__WEBPACK_IMPORTED_MODULE_1__/* ["default"].prototype._checkNeedHandle */ .Z.prototype._checkNeedHandle; /*** * * @param {PointerEvent} event */ BContextCapture.prototype.ev_contextMenu = function (event) { this._pointerSession++; this._posCurrent = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(event.clientX, event.clientY); this.$target = event.target; if (this._checkNeedHandle(event.target)) { if (this._fireContextMenuEvent()) { event.preventDefault(); } } }; var instance = new BContextCapture(); if ((!absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__/* ["default"].isMobile */ .Z.isMobile || !absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__/* ["default"].isSafari */ .Z.isSafari) && (absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__/* ["default"].os.type */ .Z.os.type !== 'ios')) { absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__/* ["default"].nativeContextMenuSupport */ .Z.nativeContextMenuSupport = true; _ContextMenu__WEBPACK_IMPORTED_MODULE_1__/* ["default"].auto */ .Z.auto = instance.auto.bind(instance);//override old version } else { absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_5__/* ["default"].nativeContextMenuSupport */ .Z.nativeContextMenuSupport = false; } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (instance); /***/ }), /***/ 7537: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_boardtable_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9936); /* harmony import */ var _css_boardtable_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_boardtable_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function Board() { } Board.tag = "board"; Board.render = function () { return _({ class: 'as-board', extendEvent: ['sizechange', 'changeposition'] }); }; Board.prototype.getParent = function () { var parent = this.parentElement; while (parent) { if (parent.classList.contains('ac-board-table')) return parent; parent = parent.parentElement; } return null; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Board); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Board); /***/ }), /***/ 7548: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports EFFECT_ZONE_CLASS_NAME, DRAG_ZONE_CLASS_NAME, FREE_ZONE_CLASS_NAME */ /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var _css_boardtable_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9936); /* harmony import */ var _css_boardtable_css__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_css_boardtable_css__WEBPACK_IMPORTED_MODULE_1__); /* harmony import */ var _Board__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7537); /* harmony import */ var absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(557); /* harmony import */ var absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1487); /* harmony import */ var absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(2759); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(863); /* harmony import */ var _Hanger__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(655); var _ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function BoardTable() { var events = { touchstart: this.eventHandler.mousedown, mousedown: this.eventHandler.mousedown }; _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.on2.call */ .Z.prototype.on2.call(this, events); this._childHolders = []; this._dragEventData = null; this._friends = []; this._longPressEventData = null; } BoardTable.tag = 'boardtable'; BoardTable.render = function () { return _({ class: 'as-board-table', extendEvent: ['sizechange', 'orderchange', 'itemleave', 'itementer', 'dragitemstart', 'dragitemend'] }); }; var EFFECT_ZONE_CLASS_NAME = 'as-board-table-effect-zone'; var DRAG_ZONE_CLASS_NAME = 'as-board-drag-zone'; var FREE_ZONE_CLASS_NAME = 'as-board-free-zone'; BoardTable.EFFECT_ZONE_CLASS_NAME = EFFECT_ZONE_CLASS_NAME; BoardTable.DRAG_ZONE_CLASS_NAME = DRAG_ZONE_CLASS_NAME; BoardTable.FREE_ZONE_CLASS_NAME = FREE_ZONE_CLASS_NAME; BoardTable.prototype.$preventContext = _({ tag: 'textarea', class: 'as-board-table-prevent-context', props: { readOnly: true } }); BoardTable.prototype.maxScrollSpeed = 300; BoardTable.prototype.findDomChildBefore = function (elt) { var nodes = this.childNodes; for (var i = 0; i < nodes.length; ++i) { if (nodes[i] == elt) return nodes[i - 1]; } return null; }; BoardTable.prototype.findDomChildAfter = function (elt) { var nodes = this.childNodes; for (var i = 0; i < nodes.length; ++i) { if (nodes[i] == elt) return nodes[i + 1]; } return null; }; BoardTable.prototype.addChild = function (elt) { if (elt.classList.contains('as-board')) { elt.selfRemove(); var atElt; if (this._childHolders.length > 0) { atElt = this.findDomChildAfter(this._childHolders[this._childHolders.length - 1].elt); if (atElt) { if (atElt != -1) this.insertBefore(elt, atElt); else throw new Error("Violation data!"); } else { this.appendChild(elt); } } else { this.appendChild(elt); } var holder = { elt: elt, }; // elt.on('sizechange', holder.onsizechange); this._childHolders.push(holder); } else { this.appendChild(elt); } return this; }; BoardTable.prototype.removeChild = function (elt) { var holderIndex = this.findChildHolderIndex(elt); if (holderIndex >= 0) { var holder = this._childHolders[holderIndex]; // holder.elt.off('sizechange', holder.onsizechange); this._childHolders.splice(holderIndex, 1); holder.elt.remove(); } else { this.super(elt); } }; BoardTable.prototype.findChildBefore = function (elt) { var holderIndex = this.findChildHolderIndex(elt); if (holderIndex < 0) return holderIndex; if (holderIndex < 1) return null; return this._childHolders[holderIndex - 1]; }; BoardTable.prototype.findChildAfter = function (elt) { var holderIndex = this.findChildHolderIndex(elt); if (holderIndex < 0) return holderIndex; if (holderIndex <= this._childHolders.length) return null; return this._childHolders[holderIndex + 1]; }; BoardTable.prototype.addChildBefore = function (elt, at) { elt.selfRemove(); var atIndex = this.findChildHolderIndex(at); if (elt.classList.contains('as-board')) { if (atIndex < 0) { if (this._childHolders.length > 0) { if (this.findDomChildAfter(this._childHolders[this._childHolders.length - 1].elt) == at) { atIndex = this._childHolders.length; } else { throw new Error("Invalid position, you must insert board next to other board!"); } } } this.insertBefore(elt, at); var holder = { elt: elt }; this._childHolders.splice(atIndex, 0, holder); } else { if (atIndex > 0) { throw new Error("Invalid position, you can not insert othert type between two board!"); } else { this.insertBefore(elt, at); } } return this; }; BoardTable.prototype.addChildAfter = function (elt, at) { //todo: testing elt.selfRemove(); var atIndex = this.findChildHolderIndex(at); var afterAt = this.findDomChildAfter(at); if (elt.classList.contains('as-board')) { if (atIndex < 0) { if (this._childHolders.length > 0) { if (this.findDomChildBefore(this._childHolders[0].elt) == at) { atIndex = -1; } else throw new Error("Invalid position, you must insert board next to other board!"); } } var holder = { elt: elt }; if (atIndex === -1) { this.insertBefore(elt, afterAt || this.firstChild); } else if (!afterAt) { this.appendChild(elt); } else { this.insertBefore(elt, afterAt); } this._childHolders.splice(atIndex + 1, 0, holder); } else { if (this._childHolders.length > 1 && atIndex >= 0 && atIndex + 1 < this._childHolders.length) { throw new Error("Invalid position, you can not insert othert type between two board!"); } else { if (!afterAt) { this.appendChild(elt); } else { this.insertBefore(elt, afterAt); } } } return this; }; BoardTable.prototype.clearChild = function () { this._childHolders = []; return absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__/* ["default"].prototype.clearChild.call */ .Z.prototype.clearChild.call(this); }; BoardTable.prototype.findChildHolder = function (elt) { return this._childHolders[this.findChildHolderIndex(elt)]; }; BoardTable.prototype.findChildHolderIndex = function (elt) { for (var i = 0; i < this._childHolders.length; ++i) { if (this._childHolders[i].elt == elt) return i; } return -1; }; BoardTable.prototype.getEffectZone = function () { var ez = this; while (ez) { if (ez.classList.contains(EFFECT_ZONE_CLASS_NAME)) { return ez; } ez = ez.parentElement; } return this; }; BoardTable.prototype._findDragZone = function (elt) { var res = null; while (elt != this && elt) { if (elt.classList.contains('as-board-table')) return null;//maybe in other if (!res && elt.classList.contains(DRAG_ZONE_CLASS_NAME)) { res = elt; } if (!res && elt.classList.contains(FREE_ZONE_CLASS_NAME)) return null;// do not drag elt = elt.parentElement; } return res; }; BoardTable.prototype._findBoard = function (elt) { while (elt != this && elt) { if (elt.classList.contains('as-board')) return elt; elt = elt.parentElement; } return null; }; BoardTable.prototype.getAllFriends = function () { var thisBT = this; var res = []; var friendQR; for (var i = 0; i < this._friends.length; ++i) { friendQR = this._friends[i]; if (friendQR != this && friendQR && friendQR.classList && friendQR.classList.contains('as-board-table')) { res.push(friendQR); } else if (typeof friendQR == 'string') {// query $(friendQR, false, function (elt) { if (thisBT != elt && elt.classList && elt.classList.contains('as-board-table')) { res.push(elt); } return false; }); } } return res; }; BoardTable.prototype._findHoverBoardIndex = function (clientX, clientY, excludes) { var cli = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(clientX, clientY); var bound; for (var i = 0; i < this._childHolders.length; ++i) { // holder = if (excludes && excludes.indexOf(this._childHolders[i].elt) >= 0) continue; bound = absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_5__/* ["default"].fromClientRect */ .Z.fromClientRect(this._childHolders[i].elt.getBoundingClientRect()); if (bound.containsPoint(cli)) return i; } return -1; }; /** * @type {BoardTable} */ BoardTable.eventHandler = {}; BoardTable.eventHandler.mousedown = function (event) { if (this._dragEventData) return; var mousePos; var pointerIdent = -1; var target; var isTouch = event.type === 'touchstart'; if (isTouch) { var touch = event.changedTouches[0]; target = touch.target; pointerIdent = touch.identifier; mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(touch.clientX, touch.clientY); } else { mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(event.clientX, event.clientY); target = event.target; } var dragzone = this._findDragZone(target); if (dragzone) { var boardElt = this._findBoard(dragzone); var holderIndex = this.findChildHolderIndex(boardElt); if (holderIndex < 0) return;// can not move var cBound = boardElt.getBoundingClientRect(); var mouseBoardOffset = mousePos.sub(new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(cBound.left, cBound.top)); this._dragEventData = { boardElt: boardElt, state: 'WAIT', mouseStartPos: mousePos, mousePos: mousePos, mouseBoardOffset: mouseBoardOffset, holderIndex: holderIndex, boardBound: cBound, isTouch: isTouch, pointerIdent: pointerIdent }; var cEvent = absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__/* ["default"].copyEvent */ .ZP.copyEvent(event); if (isTouch) { _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.on2.call */ .Z.prototype.on2.call(document.body, { touchend: this.eventHandler.touchFinishBeforeReadyDrag, touchcancel: this.eventHandler.touchFinishBeforeReadyDrag, touchmove: this.eventHandler.touchMoveBeforeReadyDrag }); this.$preventContext.off('contextmenu', this.eventHandler.contextMenu);//event maybe not remove because of double click this.$preventContext.on('contextmenu', this.eventHandler.contextMenu); var thisBT = this; this._dragEventData._longPressTimeout = setTimeout(function () { thisBT._longPressEventData = -1; thisBT.$preventContext.addStyle({ '--x': mousePos.x + 'px', '--y': mousePos.y + 'px' }).addTo(document.body); if (thisBT._dragEventData) thisBT.eventHandler.readyDrag(cEvent); }, 400); } else { this.eventHandler.readyDrag(event); } } }; BoardTable.eventHandler.touchFinishBeforeReadyDrag = function (event) { var thisBT = this; var dragEventData = this._dragEventData; if (!dragEventData) return; _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.off2.call */ .Z.prototype.off2.call(document.body, { touchend: this.eventHandler.touchFinishBeforeReadyDrag, touchcancel: this.eventHandler.touchFinishBeforeReadyDrag, touchmove: this.eventHandler.touchMoveBeforeReadyDrag }) if (this._dragEventData._longPressTimeout > 0) { clearTimeout(this._dragEventData._longPressTimeout); } if (dragEventData.state === 'WAIT') { this._dragEventData = null;// canceled } else { setTimeout(function () { thisBT.$preventContext.off('contextmenu', thisBT.eventHandler.contextMenu); thisBT.$preventContext.remove(); }, 60); } }; BoardTable.eventHandler.contextMenu = function (event) { event.preventDefault(); this.$preventContext.off('contextmenu', this.eventHandler.contextMenu); this.$preventContext.remove(); this.eventHandler.touchFinishBeforeReadyDrag(event); } BoardTable.eventHandler.touchMoveBeforeReadyDrag = function (event) { var dragEventData = this._dragEventData; var touch = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__/* .findChangedTouchByIdent */ .VY)(event, dragEventData.pointerIdent); if (!touch) return; var mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(touch.clientX, touch.clientY); if (dragEventData.state === 'WAIT') { var dv = mousePos.sub(dragEventData.mouseStartPos); if (dv.abs() > 8) { this.eventHandler.touchFinishBeforeReadyDrag(event); this._dragEventData = null;// cancel } } else { this.$preventContext.addStyle({ '--x': mousePos.x + 'px', '--y': mousePos.y + 'px' }); } }; BoardTable.eventHandler.readyDrag = function (event) { var dragEventData = this._dragEventData; dragEventData.state = "PRE_DRAG"; var bodyEvents = {}; if (dragEventData.isTouch) { bodyEvents.touchmove = this.eventHandler.mousemove; bodyEvents.touchcancel = this.eventHandler.mousefinish; bodyEvents.touchend = this.eventHandler.mousefinish; } else { bodyEvents.mousemove = this.eventHandler.mousemove; bodyEvents.mouseup = this.eventHandler.mousefinish; bodyEvents.mouseleave = this.eventHandler.mousefinish; } _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.on2.call */ .Z.prototype.on2.call(document.body, bodyEvents); if (dragEventData.isTouch) { this.eventHandler.mousemove(event); } }; BoardTable.eventHandler.mousemovePredrag = function (event) { var dragEventData = this._dragEventData; var mousePos = dragEventData.mousePos; var thisBT = this; event.preventDefault(); var cBound = dragEventData.boardElt.getBoundingClientRect(); if (mousePos.sub(dragEventData.mouseStartPos).abs() > 8 || dragEventData.isTouch) { dragEventData.placeHolderElt = $(dragEventData.boardElt.cloneNode(false)) .addClass('as-board-place-holder') .addStyle({ width: cBound.width + 'px', height: cBound.height + 'px' }); dragEventData.friendHolders = this.getAllFriends().concat([this]).map(function (elt) { //include itself var effectZone = elt.getEffectZone(); var res = { elt: elt, effectZone: effectZone } if (!dragEventData.isTouch) { var enterEvent = thisBT.eventHandler.enterFriendEffectZone.bind(thisBT, elt); _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.on2.call */ .Z.prototype.on2.call(effectZone, dragEventData.isTouch ? 'touchmove' : 'mouseenter', enterEvent); res.enterEvent = enterEvent; } else { // use move event to detect } return res; }); dragEventData.inEffectZoneOf = this dragEventData.cardStyle = { width: dragEventData.boardElt.style.width, height: dragEventData.boardElt.style.height }; dragEventData.boardElt.addStyle({ width: cBound.width + 'px', height: cBound.height + 'px' }); this.insertBefore(dragEventData.placeHolderElt, dragEventData.boardElt); dragEventData.state = "DRAG"; $(document.body).addClass('as-has-board-table-drag'); dragEventData.boardElt.addClass('as-board-moving'); dragEventData.boardAt = dragEventData.holderIndex; dragEventData.boardIn = thisBT; this.emit('dragitemstart', { type: 'dragitemstart', target: this, boardElt: this._dragEventData.boardElt }, this); } }; BoardTable.eventHandler.mousemoveDragInSelf = function (event) { var dragEventData = this._dragEventData; var mousePos = dragEventData.mousePos; if (this._childHolders.length < 2) { if (dragEventData.boardIn != this) { this.insertBefore(dragEventData.placeHolderElt, this._childHolders[0].elt); dragEventData.boardIn = this; dragEventData.boardAt = 0; } } else { // bản thân chỉ có 1, hoặc nhiều hơn var i = this._findHoverBoardIndex(mousePos.x, mousePos.y, [dragEventData.boardElt]); if (i >= 0) { if (dragEventData.boardIn != this) { dragEventData.boardIn = this; } var viewIndex; if ((i < dragEventData.holderIndex && i < dragEventData.boardAt) || (i > dragEventData.holderIndex && i > dragEventData.boardAt) || dragEventData.holderIndex == dragEventData.boardAt) { viewIndex = i; } else { if (dragEventData.holderIndex > dragEventData.boardAt) { viewIndex = i + 1; } else { viewIndex = i - 1; } } var fbound = this._childHolders[i].elt.getBoundingClientRect(); var displayStyple = this._childHolders[i].elt.getComputedStyleValue('display'); if (mousePos.x > fbound.left && mousePos.x < fbound.right && mousePos.y > fbound.top && mousePos.y < fbound.bottom) { if (displayStyple.startsWith('inline')) { if (dragEventData.boardBound.width < fbound.width) { if (dragEventData.boardAt > viewIndex && mousePos.x > fbound.left + dragEventData.boardBound.width) { viewIndex += 1; } else if (dragEventData.boardAt < viewIndex && mousePos.x < fbound.left + fbound.width - dragEventData.boardBound.width) { viewIndex -= 1; } } } else { if (dragEventData.boardBound.height < fbound.height) { if (dragEventData.boardAt > viewIndex && mousePos.y >= fbound.top + dragEventData.boardBound.height) { viewIndex += 1; } else if (dragEventData.boardAt < viewIndex && mousePos.y <= fbound.top + fbound.height - dragEventData.boardBound.height) { viewIndex -= 1; } } } viewIndex = Math.max(0, Math.min(this._childHolders.length, viewIndex)); if (viewIndex != dragEventData.boardAt) { dragEventData.boardAt = viewIndex; if (dragEventData.holderIndex >= viewIndex) { this.insertBefore(dragEventData.placeHolderElt, this._childHolders[viewIndex].elt); } else { var bf = absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__/* ["default"].prototype.findChildAfter.call */ .Z.prototype.findChildAfter.call(this, this._childHolders[viewIndex].elt); if (bf) this.insertBefore(dragEventData.placeHolderElt, bf); else { this.appendChild(dragEventData.placeHolderElt); } } } } } } }; BoardTable.eventHandler.mousemoveDragInOther = function (event) { var dragEventData = this._dragEventData; var mousePos = dragEventData.mousePos; var other = dragEventData.inEffectZoneOf; if (other._childHolders.length == 0) { if (dragEventData.boardIn != other) { dragEventData.boardIn = other; dragEventData.boardAt = 0; other.appendChild(dragEventData.placeHolderElt); } } else { var i = other._findHoverBoardIndex(mousePos.x, mousePos.y); if (i >= 0) { if (dragEventData.boardIn != other) { dragEventData.boardIn = other; } var displayStyple = other._childHolders[i].elt.getComputedStyleValue('display'); var di = 0; var bbound = other._childHolders[i].elt.getBoundingClientRect(); if (displayStyple.startsWith('inline')) { if (mousePos.x > bbound.left + bbound.width / 2) di++; } else { if (mousePos.y > bbound.top + bbound.height / 2) di++; } i += di; if (i < other._childHolders.length) { other.insertBefore(dragEventData.placeHolderElt, other._childHolders[i].elt); } else { var bf = other.findChildAfter(other._childHolders[other._childHolders.length - 1].elt); if (bf) { other.insertBefore(dragEventData.placeHolderElt, bf); } else { other.appendChild(dragEventData.placeHolderElt) } } dragEventData.boardAt = i; } } }; BoardTable.eventHandler.mousemoveDrag = function (event) { var dragEventData = this._dragEventData; if (dragEventData.inEffectZoneOf == this) { this.eventHandler.mousemoveDragInSelf(event); } else { this.eventHandler.mousemoveDragInOther(event); } }; BoardTable.eventHandler.boarDrag = function (event) { var dragEventData = this._dragEventData; var mousePos = dragEventData.mousePos; var boardPos = mousePos.sub(dragEventData.mouseBoardOffset); dragEventData.boardElt.addStyle({ left: boardPos.x + 'px', top: boardPos.y + 'px' }); }; BoardTable.eventHandler.dragOnEffectZone = function (event) { var dragEventData = this._dragEventData; var mousePos = dragEventData.mousePos; var friendHolders = dragEventData.friendHolders; var bound; for (var i = 0; i < friendHolders.length; ++i) { bound = absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_5__/* ["default"].fromClientRect */ .Z.fromClientRect(friendHolders[i].effectZone.getBoundingClientRect()); if (bound.containsPoint(mousePos)) { dragEventData.inEffectZoneOf = friendHolders[i].elt; break; } } }; BoardTable.eventHandler.mousemoveOverflow = function (event) { if (!this._dragEventData) return; var dragEventData = this._dragEventData; var scrollerX = this._dragEventData.boardIn; var overflowStyle; while (scrollerX) { overflowStyle = window.getComputedStyle(scrollerX)['overflow']; if ((overflowStyle === 'auto' || overflowStyle === 'auto hidden' || overflowStyle === 'scroll' || scrollerX.tagName === 'HTML') && (scrollerX.clientWidth < scrollerX.scrollWidth)) break; scrollerX = scrollerX.parentElement; } var scrollerY = this._dragEventData.boardIn; while (scrollerY) { overflowStyle = window.getComputedStyle(scrollerY)['overflow']; if ((overflowStyle === 'auto' || overflowStyle === 'hidden auto' || overflowStyle === 'scroll' || scrollerY.tagName === 'HTML') && (scrollerY.clientHeight < scrollerY.scrollHeight)) break; scrollerY = scrollerY.parentElement; } var outBound; var bBound; var screenSize = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_6__/* ["default"].getScreenSize */ .ZP.getScreenSize(); var vx = 0; var vy = 0; bBound = this._dragEventData.boardElt.getBoundingClientRect(); if (scrollerX) { if (dragEventData.$scrollerX !== scrollerX) { dragEventData.scrollerXValue = scrollerX.scrollLeft; dragEventData.$scrollerX = scrollerX; } outBound = scrollerX.getBoundingClientRect(); outBound = { left: Math.max(outBound.left, 0), top: Math.max(outBound.top, 0), bottom: Math.min(outBound.bottom, screenSize.height), right: Math.min(outBound.right, screenSize.width) } if (bBound.left < outBound.left) { vx = bBound.left - outBound.left; } else if (bBound.right > outBound.right) { vx = bBound.right - outBound.right; } } else { dragEventData.$scrollerX = null; } if (scrollerY) { if (dragEventData.$scrollerY !== scrollerY) { dragEventData.scrollerYValue = scrollerY.scrollTop; dragEventData.$scrollerY = scrollerY; } outBound = scrollerY.getBoundingClientRect(); outBound = { left: Math.max(outBound.left, 0), top: Math.max(outBound.top, 0), bottom: Math.min(outBound.bottom, screenSize.height), right: Math.min(outBound.right, screenSize.width) } if (bBound.top < outBound.top) { vy = bBound.top - outBound.top; } else if (bBound.bottom > outBound.bottom) { vy = bBound.bottom - outBound.bottom; } } else { dragEventData.$scrollerY = null; } vx = Math.max(-this.maxScrollSpeed, Math.min(this.maxScrollSpeed, vx * Math.sqrt(Math.abs(vx)))); vy = Math.max(-this.maxScrollSpeed, Math.min(this.maxScrollSpeed, vy * Math.sqrt(Math.abs(vy)))); if (vx !== 0 || vy !== 0) { var copyEvent = { type: event.type, preventDefault: function () {/* noop */ }, target: event.target }; if (event.type === 'touchmove') { copyEvent.changedTouches = Array.prototype.map.call(event.changedTouches, function (it) { return { identifier: it.identifier, clientX: it.clientX, clientY: it.clientY, target: it.target } }); copyEvent.touches = Array.prototype.map.call(event.touches, function (it) { return { identifier: it.identifier, clientX: it.clientX, clientY: it.clientY, target: it.target } }); } else { copyEvent.clientX = event.clientX; copyEvent.clientY = event.clientY } var thisBT = this; var now = new Date().getTime(); if (dragEventData.requestAnimationFrameId >= 0) { cancelAnimationFrame(dragEventData.requestAnimationFrameId); } dragEventData.requestAnimationFrameId = requestAnimationFrame(function () { dragEventData.requestAnimationFrameId = -1; var dt = (new Date().getTime() - now) / 1000; if (dragEventData.$scrollerY) { dragEventData.scrollerYValue += vy * dt; dragEventData.scrollerYValue = Math.max(0, Math.min(dragEventData.$scrollerY.scrollHeight - dragEventData.$scrollerY.clientHeight, dragEventData.scrollerYValue)) dragEventData.$scrollerY.scrollTop = dragEventData.scrollerYValue; } if (dragEventData.$scrollerX) { dragEventData.scrollerXValue += vx * dt; dragEventData.scrollerXValue = Math.max(0, Math.min(dragEventData.$scrollerX.scrollWidth - dragEventData.$scrollerX.clientWidth, dragEventData.scrollerXValue)) dragEventData.$scrollerX.scrollLeft = dragEventData.scrollerXValue; } if (thisBT._dragEventData && thisBT._dragEventData.state === "DRAG") { thisBT.eventHandler.mousemoveOverflow(copyEvent); } }); } }; BoardTable.eventHandler.mousemove = function (event) { var dragEventData = this._dragEventData; var isTouch = event.type === 'touchmove' || event.type === 'touchstart';// call from timeout if (dragEventData.isTouch !== isTouch) return; var mousePos; var pointerIdent; var touch = -2; if (isTouch) { touch = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__/* .findChangedTouchByIdent */ .VY)(event, dragEventData.pointerIdent); if (touch) { pointerIdent = touch.identifier; mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(touch.clientX, touch.clientY); } } else { pointerIdent = -1; mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(event.clientX, event.clientY); } if (dragEventData.pointerIdent !== pointerIdent) return; dragEventData.mousePos = mousePos; event.preventDefault(); if (dragEventData.isTouch && dragEventData.state === 'DRAG') { this.eventHandler.dragOnEffectZone(event);//because touch not have mouseenter event } if (dragEventData.state === 'PRE_DRAG') { this.eventHandler.mousemovePredrag(event); } if (dragEventData.state === 'DRAG') { this.eventHandler.mousemoveDrag(event); this.eventHandler.boarDrag(event); this.eventHandler.mousemoveOverflow(event); } }; BoardTable.eventHandler.mousefinish = function (event) { var dragEventData = this._dragEventData; var isTouch = event.type === 'touchend'; if (dragEventData.isTouch !== isTouch) return; var mousePos; var pointerIdent; var touch = -2; if (isTouch) { touch = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__/* .findChangedTouchByIdent */ .VY)(event, dragEventData.pointerIdent); if (touch) { pointerIdent = touch.identifier; mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(touch.clientX, touch.clientY); } } else { pointerIdent = -1; mousePos = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(event.clientX, event.clientY); } if (dragEventData.pointerIdent !== pointerIdent) return; dragEventData.mousePos = mousePos; var changed; if (dragEventData.state == 'DRAG') { setTimeout(function () { $(document.body).removeClass('as-has-board-table-drag'); }, 1) dragEventData.boardElt.removeClass('as-board-moving') .removeStyle('left') .removeStyle('top'); dragEventData.boardElt.addStyle(dragEventData.cardStyle); dragEventData.placeHolderElt.remove(); dragEventData.state = "FINISH"; if (!dragEventData.isTouch) dragEventData.friendHolders.forEach(function (holder) { _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.off2.call */ .Z.prototype.off2.call(holder.effectZone, 'mouseenter', holder.enterEvent); }); if (dragEventData.boardIn == this) { if (dragEventData.holderIndex != dragEventData.boardAt) { if (dragEventData.holderIndex > dragEventData.boardAt) { this.insertBefore(dragEventData.boardElt, this._childHolders[dragEventData.boardAt].elt); } else if (dragEventData.holderIndex < dragEventData.boardAt) { var bf = absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__/* ["default"].prototype.findChildAfter.call */ .Z.prototype.findChildAfter.call(this, this._childHolders[dragEventData.boardAt].elt); if (bf) this.insertBefore(dragEventData.boardElt, bf); else { this.appendChild(dragEventData.boardElt); } } var holder = this._childHolders.splice(dragEventData.holderIndex, 1)[0]; this._childHolders.splice(dragEventData.boardAt, 0, holder); changed = 'orderchange'; this.emit('orderchange', { type: 'orderchange', boardElt: holder.elt, action: 'move', from: dragEventData.holderIndex, to: dragEventData.boardAt, target: this, }, this); } } else { var holder = this._childHolders.splice(dragEventData.holderIndex, 1)[0]; holder.elt.remove(); ///remove all event var other = dragEventData.boardIn; changed = 'itemleave'; this.emit('itemleave', { type: 'itemleave', item: holder.elt, from: { index: dragEventData.holderIndex, table: this }, to: { index: dragEventData.boardAt, table: other }, target: this }, this); if (other._childHolders.length == 0) { other.appendChild(holder.elt); other._childHolders.push(holder); } else { if (dragEventData.boardAt < other._childHolders.length) { other.insertBefore(holder.elt, other._childHolders[dragEventData.boardAt].elt); other._childHolders.splice(dragEventData.boardAt, 0, holder); } else { var bf = other.findDomChildAfter(other._childHolders.elt); if (bf) { other.insertBefore(holder.elt, bf); } else { other.appendChild(holder.elt); } other._childHolders.push(holder); } } other.emit('itementer', { type: 'itementer', item: holder.elt, target: other, from: { index: dragEventData.holderIndex, table: this }, to: { index: dragEventData.boardAt, table: other } }, other); } this.emit('dragitemend', { type: 'dragitemend', target: this, changed: changed, boardElt: this._dragEventData.boardElt }, this); } var bodyEvents = {}; if (dragEventData.isTouch) { bodyEvents.touchmove = this.eventHandler.mousemove; bodyEvents.touchcancel = this.eventHandler.mousefinish; bodyEvents.touchend = this.eventHandler.mousefinish; } else { bodyEvents.mousemove = this.eventHandler.mousemove; bodyEvents.mouseup = this.eventHandler.mousefinish; bodyEvents.mouseleave = this.eventHandler.mousefinish; } _Hanger__WEBPACK_IMPORTED_MODULE_8__/* ["default"].prototype.off2.call */ .Z.prototype.off2.call(document.body, bodyEvents); this._dragEventData = null; }; BoardTable.eventHandler.enterFriendEffectZone = function (friendElt, event) { this._dragEventData.inEffectZoneOf = friendElt; }; BoardTable.prototype.getAllBoards = function () { return this._childHolders.map(function (holder) { return holder.elt; }); }; BoardTable.property = {}; BoardTable.property.friends = { set: function (value) { value = value || []; if (!(value instanceof Array)) value = [value]; this._friends = value; }, get: function () { return this._friends; } }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(BoardTable); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (BoardTable); /***/ }), /***/ 1728: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_checkboxinput_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3144); /* harmony import */ var _css_checkboxinput_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_checkboxinput_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var tickIcon = _(['<svg class="as-checkbox-input-check-icon" width="18px" height="18px" version="1.1" viewBox="0 0 18 18" xmlns="http://www.w3.org/2000/svg" >', ' <g transform="translate(0 -279)">', ' <path class="bound" d="m3 279.69h12c1.3434 0.0111 2.3298 1.5259 2.3131 2.4775v11.836c0.05005 0.89373-1.1834 2.2964-2.3131 2.3131h-12c-0.82692 0.0166-2.3131-1.1834-2.3131-2.3131v-12.237c0.0022374-1.171 0.3775-2.0759 2.3131-2.0759z" style="stroke-linejoin:round; stroke-width: 1"/>', ' <path class="tick" d="m3.1656 288.66c-0.10159 0.0612-0.11743 0.12506-0.12993 0.18899l3.7473 4.3467c0.066638 0.0459 0.11813 0.0263 0.16832 1e-3 0 0 1.7699-4.2166 4.7251-7.4568 1.4783-1.6208 3.2406-3.3659 3.2406-3.3659 0.0054-0.14125-0.10946-0.15807-0.1754-0.22551 0 0-2.5832 1.6364-4.7524 3.8336-1.8697 1.8939-3.6666 4.4016-3.6666 4.4016z"/>', ' <path class="minus" d="m4 287 h10 v2 h-10z"/>', ' </g>', '</svg>' ].join('') ); /*** * @extends AElement * @constructor */ function CheckboxInput() { this.$input = $('input', this) .on('change', this.notifyChange.bind(this)); this.checked = false; this.disabled = false; this.readOnly = false; this.on('click', this.eventHandler.click); this.onchange = null; } CheckboxInput.tag = "CheckboxInput".toLowerCase(); CheckboxInput.render = function (data) { return _({ tag: 'label', extendEvent: 'change', class: 'as-checkbox-input', child: [ { elt: data && data.$input, tag: 'input', class: 'as-checkbox-input-value', attr: { type: 'checkbox' } }, tickIcon.cloneNode(true) ] } ) }; /*** * as normal, change event will be fired when checkbox change by system */ CheckboxInput.prototype.notifyChange = function () { var event = { checked: this.checked }; this.emit('change', event, this); }; CheckboxInput.prototype._updateCheckedClass = function () { if (this.checked) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } }; CheckboxInput.property = {}; CheckboxInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } this.$input.disabled = !!value; }, get: function () { return this.$input.disabled; } }; CheckboxInput.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } } /*** * * @type {CheckboxInput} */ CheckboxInput.property.checked = { set: function (value) { this.$input.checked = !!value; this._updateCheckedClass(); }, get: function () { return this.$input.checked; } }; /*** * * @type {CheckboxInput} */ CheckboxInput.property.minus = { set: function (value) { if (value) { this.addClass('as-has-minus'); } else { this.removeClass('as-has-minus'); } }, get: function () { return this.hasClass('as-has-minus'); } }; CheckboxInput.attribute = { checked: { set: function (value) { if (value === 'false' || value === null) { this.checked = false; } else { this.checked = true; } }, get: function () { return this.checked ? 'true' : 'false' }, remove: function () { this.checked = false; } }, disabled: { set: function (value) { if (value === 'false' || value === null) { this.disabled = false; } else { this.disabled = true; } }, get: function () { return this.disabled ? 'true' : 'false' }, remove: function () { this.disabled = false; } } }; /*** * * @type {CheckboxInput} */ CheckboxInput.eventHandler = {}; CheckboxInput.eventHandler.click = function (event) { if (this.readOnly) { event.preventDefault(); } this._updateCheckedClass(); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(CheckboxInput); CheckboxInput.autoReplace = function () { var placeHolders = Array.prototype.slice.call(document.getElementsByTagName(this.tag)); var ph; var attOfPH; var attrs; var style; var classList; var attNode; var attrName, attrValue; var props; for (var i = 0; i < placeHolders.length; ++i) { ph = placeHolders[i]; attOfPH = ph.attributes; classList = []; style = {}; attrs = {}; props = {}; for (var j = 0; j < attOfPH.length; ++j) { attNode = attOfPH[j]; attrName = attNode.nodeName; attrValue = attNode.nodeValue; if (attrName == 'style') { attrValue.trim().split(';').reduce(function (style, prop) { var p = prop.split(':'); if (p.length == 2) { style[p[0].trim()] = p[1].trim(); } return style; }, style); } else if (attrName == 'class') { classList = attrValue.trim().split(/\s+/); } else if (attrName == 'onchange') { props.onchange = new Function('event', 'sender', attrValue); } else { attrs[attrName] = attrValue; } } var newElt = _({ tag: this.tag, attr: attrs, class: classList, style: style, props: props }); $(ph).selfReplace(newElt); } }; CheckboxInput.initAfterLoad = function () { absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].documentReady.then */ .ZP.documentReady.then(function () { CheckboxInput.autoReplace(); }) }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (CheckboxInput); /***/ }), /***/ 4654: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_checkboxbutton_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2435); /* harmony import */ var _css_checkboxbutton_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_checkboxbutton_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _CheckBoxInput__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1728); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install('checkboxbutton', _CheckBoxInput__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_CheckBoxInput__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z); /***/ }), /***/ 4845: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_chromecalendar_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9708); /* harmony import */ var _css_chromecalendar_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_chromecalendar_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7807); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(863); /* harmony import */ var _Scroller__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(9246); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(3349); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_DelaySignal__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(8098); /* harmony import */ var _Follower__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7094); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var calendarLangMap = { 'en': { monthNames: [ 'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December' ], shortMonthNames: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'], dayOfWeekNames: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'], shortDayOfWeekNames: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'], quarterNames: ['Q1', 'Q2', 'Q3', 'Q4'] }, 'vi': { monthNames: [ 'Tháng 1', 'Tháng 2', 'Tháng 3', 'Tháng 4', 'Tháng 5', 'Tháng 6', 'Tháng 7', 'Tháng 8', 'Tháng 9', 'Tháng 10', 'Tháng 11', 'Tháng 12' ], shortMonthNames: ['Thg 1', 'Thg 2', 'Thg 3', 'Thg 4', 'Thg 5', 'Thg 6', 'Thg 7', 'Thg 8', 'Thg 9', 'Thg 10', 'Thg 11', 'Thg 12'], dayOfWeekNames: ['Chủ Nhật', 'Thứ Hai', 'Thứ Ba', 'Thứ Tư', 'Thứ Năm', 'Thứ Sáu', 'Thứ Bảy'], shortDayOfWeekNames: ['CN', 'T2', 'T3', 'T4', 'T5', 'T6', 'T7'], quarterNames: ['Q1', 'Q2', 'Q3', 'Q4'] } }; var getCalendarSupportedLanguage = () => { var res = null; if (window['LanguageModule']) res = window['LanguageModule'].defaultcode; if (!res) res = navigator.language || navigator.userLanguage; res = res || 'en'; res = res.toLowerCase(); if (res === 'vn') res = 'vi'; if (!calendarLangMap[res]) res = 'en'; return res; } /** * get multi language text * @param {string} key * @returns {*} */ var getCMLText = key => { return calendarLangMap[getCalendarSupportedLanguage()][key]; }; var EV_CONTENT_CHANGE = 'ev_content_change'; /** * @extends AElement * @constructor */ function ChromeCalendar() { var thisCal = this; this.dayInWeekTexts = getCMLText('shortDayOfWeekNames'); this._startDayOfWeek = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.getDefaultFirstDayOfWeek)(); this._level = "day"; this.$years = $('.absol-chrome-calendar-years', this); this.$title = $('.absol-chrome-calendar-title', this) this.$titleTime = $('.title-time', this.$title); this.$instance = $('.absol-chrome-calendar-instance', this); this.$era = $('.absol-chrome-calendar-era', this) this.$month = $('.absol-chrome-calendar-month', this); this.$dayOfWeek = $('.absol-chrome-calendar-dayofweek', this); this._min = new Date(1890, 0, 1); this._max = new Date(2090, 0, 1); this._selectedDates = [absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay(new Date())]; this._viewDate = new Date(); this.$prevBtn = $('.absol-chrome-calendar-header-buttons > button.prev-btn', this) this.$todayBtn = $('.absol-chrome-calendar-header-buttons > button.today-btn', this) this.$nextBtn = $('.absol-chrome-calendar-header-buttons > button.next-btn', this) /*** * * @type {VScroller} */ this.$yearScroller = $('vscroller.absol-chrome-calendar-years', this); this.$yearItems = []; $('.absol-chrome-calendar-year', this.$yearScroller, function (e) { thisCal.$yearItems.push(e); }); this.$attachHook = _('attachhook').addTo(this); this.domSignal = new absol_src_HTML5_DelaySignal__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z() .on(EV_CONTENT_CHANGE, () => { switch (this.level) { case 'day': case 'week': this.startViewer('month'); this.viewer.updateContent(); break; case 'month': case 'quarter': this.startViewer('year'); this.viewer.updateContent(); break; case 'year': this.startViewer('era'); break; default: break; } this.viewer.updateContent(); this.headerCtrl.updateTitle(); this.headerCtrl.updateButtons(); }) this.sync = new Promise(function (rs) { thisCal.$attachHook.on('attached', rs); }); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* ["default"].drillProperty */ .ZP.drillProperty(this, this, 'minLimitDate', 'min'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* ["default"].drillProperty */ .ZP.drillProperty(this, this, 'minDateLimit', 'min'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* ["default"].drillProperty */ .ZP.drillProperty(this, this, 'maxLimitDate', 'max'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* ["default"].drillProperty */ .ZP.drillProperty(this, this, 'maxDateLimit', 'max'); this.headerCtrl = new CCHeaderController(this); this.viewers = { month: new CCMonthViewer(this), year: new CCYearViewer(this), era: new CCEraViewer(this) }; /** * * @type {CCViewerAbstract} */ this.viewer = this.viewers['month']; this.viewer.start(); /** * @type {number} * @name startDayOfWeek * @memberOf ChromeCalendar# */ /** * @type {Date[]} * @name selectedDates * @memberOf ChromeCalendar# */ /** * @type {'day'|'week'|'month'|'quarter'|'year'} * @name level * @memberOf ChromeCalendar# */ /** * @type {Date} * @name viewDate * @memberOf ChromeCalendar# */ } ChromeCalendar.tag = 'ChromeCalendar'.toLowerCase(); ChromeCalendar.render = function () { return _({ class: ['absol-chrome-calendar'], attr: { 'data-level': 'day', tabindex: '1' }, extendEvent: 'pick', child: [ { class: 'absol-chrome-calendar-header', child: [ { class: 'absol-chrome-calendar-title', child: [ { tag: 'span', class: 'title-time', child: { text: 'Septemper, 2019' } }, ] }, { class: 'absol-chrome-calendar-header-buttons', child: [ { tag: 'button', class: 'prev-btn', child: 'span.mdi.mdi-menu-left', attr: { title: 'Previous Month' } }, { tag: 'button', class: 'today-btn', child: 'span.mdi.mdi-circle-medium', attr: { title: 'Today' } }, { tag: 'button', class: 'next-btn', child: 'span.mdi.mdi-menu-right', attr: { title: 'Next Month' } } ] } ] }, { class: 'absol-chrome-calendar-instance', child: [ { class: 'absol-chrome-calendar-dayofweek', child: getCMLText('shortDayOfWeekNames').map(function (text) { return { child: { text: text } } }) }, { class: 'absol-chrome-calendar-month', }, { tag: 'vscroller', class: 'absol-chrome-calendar-years', }, { class: "absol-chrome-calendar-era" } ] } ] }); }; /** * @param {Date} date * @returns {Boolean} */ ChromeCalendar.prototype.isSelectedDate = function (date) { for (var i = 0; i < this._selectedDates.length; ++i) { if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(date, this._selectedDates[i]) === 0) return true; } return false; }; ChromeCalendar.prototype.isSelectedWeek = function (date) { return this._selectedDates.some(it => { if (date.getFullYear() !== it.getFullYear()) return false; var weekIdx = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.weekIndexOf)(date, false, this.startDayOfWeek); var itWeekIdx = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.weekIndexOf)(it, false, this.startDayOfWeek); return weekIdx === itWeekIdx; }); }; /** * @param {Date} date * @returns {Boolean} */ ChromeCalendar.prototype.isSelectedMonth = function (date) { for (var i = 0; i < this._selectedDates.length; ++i) { if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareMonth)(date, this._selectedDates[i]) === 0) return true; } return false; }; /** * @param {Date} date * @returns {Boolean} */ ChromeCalendar.prototype.isSelectedQuarter = function (date) { for (var i = 0; i < this._selectedDates.length; ++i) { if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareMonth)((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfQuarter)(date), (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfQuarter)(this._selectedDates[i])) === 0) return true; } return false; }; /** * @param {Date} date * @returns {Boolean} */ ChromeCalendar.prototype.isSelectedYear = function (date) { for (var i = 0; i < this._selectedDates.length; ++i) { if (date.getFullYear() === this._selectedDates[i].getFullYear()) return true; } return false; }; ChromeCalendar.prototype.dayCmpLimit = function (date) { if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(date, this._min) < 0) return -1; if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(date, this._max) > 0) return 1; return 0; }; ChromeCalendar.prototype.monthCmpLimit = function (date) { var startOfMonth = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth)(date); var endOfMonth = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextMonth)(date); var minMil = Math.max(startOfMonth.getTime(), this._min.getTime()); var maxMil = Math.min(endOfMonth.getTime(), (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(this._max).getTime()); if (minMil < maxMil) return 0; return this.dayCmpLimit(date); }; ChromeCalendar.prototype.yearCmpLimit = function (date) { var startOfYear = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfYear)(date); var endOfYear = new Date(date.getFullYear() + 1, 0, 1); var minMil = Math.max(startOfYear.getTime(), this._min.getTime()); var maxMil = Math.min(endOfYear.getTime(), (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(this._max).getTime()); if (minMil < maxMil) return 0; return this.dayCmpLimit(date); }; ChromeCalendar.prototype.quarterCmpLimit = function (date) { var startOfQuarter = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfQuarter)(date); var endOfQuarter = new Date(date.getFullYear(), date.getMonth() + 3, 1); var minMil = Math.max(startOfQuarter.getTime(), this._min.getTime()); var maxMil = Math.min(endOfQuarter.getTime(), (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(this._max).getTime()); if (minMil < maxMil) return 0; return this.dayCmpLimit(date); } /** * * @param {"month"|"year"|"era"} key */ ChromeCalendar.prototype.startViewer = function (key) { if (!this.viewers[key]) return; if (this.viewers[key] === this.viewer) { this.viewer.start(); this.headerCtrl.updateTitle(); } else { this.viewer.stop(); this.viewer = this.viewers[key]; this.viewer.start(); this.headerCtrl.updateTitle(); } }; ChromeCalendar.property = {}; ChromeCalendar.property.selectedDates = { set: function (value) { value = value || []; if (!(value instanceof Array)) value = [value]; value = value.map(d => (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.implicitDate)(d)).filter(d => !!d); this._selectedDates = value; this._viewDate = this._selectedDates[0] || new Date(); this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { var level = this._level; var res = this._selectedDates.map(d => { var res = d; switch (level) { case 'day': res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(d); break; case 'week': res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfWeek)(d, this.startDayOfWeek); if (res.getFullYear() < d.getFullYear()) res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfYear)(d); break; case 'month': res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth)(d); break; case 'quarter': res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfQuarter)(d); break; case 'year': res = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfYear)(d); break; } return res; }); res = res.reduce((ac, d) => { var key = (0,_utils__WEBPACK_IMPORTED_MODULE_6__.keyStringOf)(d); if (ac.has[key]) return ac; ac.has[key] = d; ac.arr.push(d); return ac; }, { has: {}, arr: [] }).arr; res.sort((a, b) => { return a.getTime() - b.getTime(); }); return res; } }; ChromeCalendar.property.min = { set: function (value) { if (!value) value = new Date(1890, 0, 1); if (typeof value == 'number') value = new Date(value); value = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(value); value = new Date(Math.max(new Date(1890, 0, 1).getTime(), value.getTime())); this._min = value; this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { return this._min; } }; //include maxLimitDate ChromeCalendar.property.max = { set: function (value) { if (!value) value = new Date(2090, 0, 1); if (typeof value == 'number') value = new Date(value); if (value.getTime() > (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(value).getTime()) value = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(value)); value = new Date(Math.min(new Date(2090, 0, 1).getTime(), value.getTime())); this._max = value; this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { return this._max; } }; ChromeCalendar.property.multiSelect = { set: function (value) { value = false; // throw new Error('Not support yet!') var lastValue = this.multiSelect; value = !!value; if (lastValue !== value) { if (value) { this.addClass('as-multi-select') } else { this.removeClass('as-multi-select'); } } this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { return this.hasClass('as-multi-select'); } }; ChromeCalendar.property.level = { set: function (value) { value = (value || '') + ''; value = value.toLowerCase(); if (['day', 'week', 'quarter', 'month', 'year'].indexOf(value) < 0) value = 'day'; if (this._level === value) return; this.attr('data-level', value); this._level = value; this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { return this._level; } }; ChromeCalendar.prototype.dayInWeekTexts = ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa']; ChromeCalendar.property.startDayOfWeek = { set: function (value) { value = Math.max(0, Math.min(Math.floor(value || 0), 6)); if (this._startDayOfWeek !== value) { this._startDayOfWeek = value; Array.prototype.forEach.call(this.$dayOfWeek.childNodes, function (e, i) { e.firstChild.data = this.dayInWeekTexts[(i + value) % 7]; }.bind(this)); } this.viewers.month.updateContent(); }, get: function () { return this._startDayOfWeek; } }; ChromeCalendar.property.viewDate = { set: function (date) { this._viewDate = date; this.domSignal.emit(EV_CONTENT_CHANGE); }, get: function () { return this._viewDate; } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ChromeCalendar); /** * * @param {ChromeCalendar} elt * @constructor */ function CCViewerAbstract(elt) { this.elt = elt; this.$instance = elt.$instance; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } } CCViewerAbstract.prototype.getTitle = function () { return ''; }; CCViewerAbstract.prototype.updateContent = function () { }; CCViewerAbstract.prototype.prev = function () { }; CCViewerAbstract.prototype.next = function () { }; CCViewerAbstract.prototype.canPrev = function () { }; CCViewerAbstract.prototype.canNext = function () { }; CCViewerAbstract.prototype.viewToday = function () { }; CCViewerAbstract.prototype.canViewToday = function () { }; CCViewerAbstract.prototype.start = function () { }; CCViewerAbstract.prototype.stop = function () { }; CCViewerAbstract.prototype.onSelectedDatesChange = function () { }; /** * @extends CCViewerAbstract * @param elt * @constructor */ function CCMonthViewer(elt) { CCViewerAbstract.call(this, elt); this.$month = elt.$month; this.$dayOfWeek = elt.$dayOfWeek; this.$instance = elt.$instance; this.$month.on('click', this.ev_click) .on('mouseenter', this.ev_mouseEnter); // this.startingDate = null; this.animationSync = Promise.resolve(); this.isListening = false; this.$hoverRow = null; } (0,absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* .mixClass */ .Jx)(CCMonthViewer, CCViewerAbstract); CCMonthViewer.prototype.updateContent = function () { var viewDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth)(this.elt._viewDate); var viewMonth = viewDate.getMonth(); var viewYear = viewDate.getFullYear(); var bg = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth)(viewDate); var startDayOfWeek = this.elt.startDayOfWeek; bg = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfWeek)(bg, false, startDayOfWeek); var weekIdx; var shortDayOfWeekNames = getCMLText('shortDayOfWeekNames'); Array.prototype.forEach.call(this.$dayOfWeek.childNodes, (elt, i) => { elt.firstChild.data = shortDayOfWeekNames[(i + startDayOfWeek) % 7]; }); var now = new Date(); var rowElt, cellElt; while (this.$month.childNodes.length < 6) { rowElt = _({ class: 'absol-chrome-calendar-week-in-month', child: Array(7).fill('div') }); this.$month.addChild(rowElt); } var i, j; var isSelectedRow; for (i = 0; i < 6; ++i) { rowElt = this.$month.childNodes[i]; isSelectedRow = false; weekIdx = bg.getFullYear() < viewDate.getFullYear() ? 0 : (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.weekIndexOf)(bg, false, startDayOfWeek); rowElt.attr('data-week-idx-text', (0,_utils__WEBPACK_IMPORTED_MODULE_6__.zeroPadding)(weekIdx + 1, 2) + ''); // if (this.elt.isSel) for (j = 0; j < rowElt.childNodes.length; ++j) { cellElt = rowElt.childNodes[j]; cellElt.attr('data-date', bg.getDate()); cellElt.attr('data-time', bg.getTime()); if (bg.getFullYear() !== viewYear) { cellElt.addClass('as-not-in-year'); } else { cellElt.removeClass('as-not-in-year'); } if (bg.getMonth() === viewMonth) { cellElt.removeClass('absol-chrome-calendar-not-in-month'); } else { cellElt.addClass('absol-chrome-calendar-not-in-month'); } if (this.elt.level === 'day' && this.elt.isSelectedDate(bg)) { cellElt.addClass('absol-chrome-calendar-selected'); } else if (this.elt.level === 'week' && this.elt.isSelectedWeek(bg)) { cellElt.addClass('absol-chrome-calendar-selected'); if (!isSelectedRow && bg.getFullYear() === this.elt._viewDate.getFullYear()) { isSelectedRow = true; } } else { cellElt.removeClass('absol-chrome-calendar-selected'); } if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(bg, now) === 0) { cellElt.addClass('absol-chrome-calendar-today'); } else { cellElt.removeClass('absol-chrome-calendar-today'); } if (this.elt.dayCmpLimit(bg) === 0) { cellElt.removeClass('as-disabled'); } else { cellElt.addClass('as-disabled'); } bg = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(bg); } if (isSelectedRow) { rowElt.addClass('as-selected'); } else { rowElt.removeClass('as-selected'); } } }; CCMonthViewer.prototype.animation = function (delta) { var oldViewDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth)(this.elt._viewDate); var newViewDate = delta < 0 ? (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.prevMonth)(oldViewDate) : (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextMonth)(oldViewDate); var startDayOfWeek = this.elt.startDayOfWeek; var oldBg = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfWeek)(oldViewDate, false, startDayOfWeek); var newBg = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfWeek)(newViewDate, false, startDayOfWeek); var curDate; var additionalRow = Math.round((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(oldBg, newBg) / 7); if (delta > 0) { additionalRow = -additionalRow; } var now = new Date(); var aniMonth = _({ class: ['absol-chrome-calendar-month', 'as-animation'] }); if (delta < 0) { aniMonth.addStyle('top', -1.2 * (additionalRow - 1) + 'em'); } else { aniMonth.addStyle('top', '1.2em'); } var updateCellClassByViewDate = (viewDate) => { curDate = delta < 0 ? newBg : oldBg; var isSelectedRow; for (i = 0; i < aniMonth.childNodes.length; ++i) { rowElt = aniMonth.childNodes[i]; isSelectedRow = false; for (j = 0; j < rowElt.childNodes.length; ++j) { cellElt = rowElt.childNodes[j]; if (curDate.getMonth() !== viewDate.getMonth()) { cellElt.addClass('absol-chrome-calendar-not-in-month'); } else { cellElt.removeClass('absol-chrome-calendar-not-in-month'); } if (!isSelectedRow && this.elt.level === 'week' && curDate.getFullYear() === viewDate.getFullYear() && this.elt.isSelectedWeek(curDate)) { isSelectedRow = true; } curDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(curDate); } if (isSelectedRow) { rowElt.addClass('as-selected'); } else { rowElt.removeClass('as-selected'); } } } var rowElt, cellElt; var i, j; curDate = delta < 0 ? newBg : oldBg; var weekIdx; for (i = 0; i < 6 + additionalRow; ++i) { rowElt = _({ class: 'absol-chrome-calendar-week-in-month', child: Array(7).fill('div') }); aniMonth.addChild(rowElt); for (j = 0; j < rowElt.childNodes.length; ++j) { cellElt = rowElt.childNodes[j]; weekIdx = curDate.getFullYear() < newViewDate.getFullYear() ? 0 : (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.weekIndexOf)(curDate, false, startDayOfWeek); rowElt.attr('data-week-idx-text', (0,_utils__WEBPACK_IMPORTED_MODULE_6__.zeroPadding)(weekIdx + 1, 2) + ''); cellElt.attr('data-date', curDate.getDate()); cellElt.attr('data-time', curDate.getTime()); if ((0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(curDate, now) === 0) { cellElt.addClass('absol-chrome-calendar-today'); } if (this.elt.level === 'day' && this.elt.isSelectedDate(curDate)) { cellElt.addClass('absol-chrome-calendar-selected'); } else if (this.elt.level === 'week' && this.elt.isSelectedWeek(curDate)) { cellElt.addClass('absol-chrome-calendar-selected'); } if (this.elt.dayCmpLimit(curDate) === 0) { cellElt.removeClass('as-disabled'); } else { cellElt.addClass('as-disabled'); } curDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextDate)(curDate); } } updateCellClassByViewDate(oldViewDate); this.$instance.addChild(aniMonth); requestAnimationFrame(() => { if (delta < 0) { aniMonth.addStyle('top', '1.2em'); } else { aniMonth.addStyle('top', -1.2 * (additionalRow - 1) + 'em'); } updateCellClassByViewDate(newViewDate); setTimeout(() => { aniMonth.remove(); }, 200) }); }; CCMonthViewer.prototype.canPrev = function () { return (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareMonth)(this.elt._viewDate, this.elt._min) > 0; }; CCMonthViewer.prototype.canNext = function () { return (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareMonth)(this.elt._viewDate, this.elt._max) < 0; }; CCMonthViewer.prototype.canViewToday = function () { var now = new Date(); return (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(now, this.elt._min) >= 0 && (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate)(now, this.elt._max) <= 0; }; CCMonthViewer.prototype.prev = function () { this.animation(-1); this.elt._viewDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.prevMonth)(this.elt._viewDate); this.updateContent(); this.elt.headerCtrl.updateTitle(); this.elt.headerCtrl.updateButtons(); }; CCMonthViewer.prototype.next = function () { this.animation(1); this.elt._viewDate = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextMonth)(this.elt._viewDate); this.updateContent(); this.elt.headerCtrl.updateTitle(); this.elt.headerCtrl.updateButtons(); }; CCMonthViewer.prototype.viewToday = function () { this.elt._viewDate = new Date(); this.updateContent(); this.elt.headerCtrl.updateTitle(); this.elt.headerCtrl.updateButtons(); }; CCMonthViewer.prototype.start = function () { this.elt.attr('data-view', 'month'); this.updateContent(); }; CCMonthViewer.prototype.stop = function () { }; CCMonthViewer.prototype.getTitle = function () { var viewDate = this.elt._viewDate; var res = '' + getCMLText('monthNames')[viewDate.getMonth()]; res += ', ' + viewDate.getFullYear(); return res; }; CCMonthViewer.prototype.ev_click = function (event) { var dateBtn = event.target; var date; while (dateBtn && dateBtn !== this.$month) { if (dateBtn.attr && dateBtn.attr('data-time')) { date = new Date(parseInt(dateBtn.attr('data-time'))); date = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(date); this.elt._selectedDates = [date]; this.onSelectedDatesChange(); this.elt.emit('pick', { type: 'pick', value: date, isTrusted: event && event.isTrusted, originEvent: event, selectedDates: this.elt.selectedDates }, this.elt); if (dateBtn.hasClass('absol-chrome-calendar-not-in-month')) { if (parseInt(dateBtn.attr('data-date')) < 15) { this.next(); } else { this.prev(); } } break; } dateBtn = dateBtn.parentElement; } }; CCMonthViewer.prototype.ev_mouseEnter = function (event) { if (this.isListening) return; if (this.elt.level !== 'week') return; this.isListening = true; if (this.$hoverRow) { this.$hoverRow.removeClass('as-hover-in-year') .removeClass('as-hover-not-in-year'); this.$hoverRow = null; } document.addEventListener('mousemove', this.ev_mouseMove); }; CCMonthViewer.prototype.ev_mouseMove = function (event) { if (!(0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* .hitElement */ .EY)(this.$month, event)) { this.isListening = false; document.removeEventListener('mousemove', this.ev_mouseMove); } var viewDate = this.elt._viewDate; var target = event.target; var date = null; var rowElt; if (target.attr) { if (target.attr('data-time')) { date = new Date(parseInt(target.attr('data-time'))); date = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfDay)(date); rowElt = target.parentElement; } else if (target.attr('data-week-idx-text')) { rowElt = target; date = new Date(parseInt(rowElt.childNodes[0].attr('data-time'))); if (date.getFullYear() !== viewDate.getFullYear()) { date = new Date(viewDate.getFullYear(), 0, 1, 0, 0, 0); } } } if (this.$hoverRow && this.$hoverRow !== rowElt) { this.$hoverRow.removeClass('as-hover-in-year') .removeClass('as-hover-not-in-year'); this.$hoverRow = null; } if (!date) return; this.$hoverRow = rowElt; if (viewDate.getFullYear() !== date.getFullYear()) { rowElt.removeClass('as-hover-in-year') .addClass('as-hover-not-in-year'); } else { rowElt.removeClass('as-hover-not-in-year') .addClass('as-hover-in-year'); } }; CCMonthViewer.prototype.onSelectedDatesChange = function () { var rowElt, cellElt; var i, j; var bg; var isSelectedRow; for (i = 0; i < this.$month.childNodes.length; ++i) { rowElt = this.$month.childNodes[i]; isSelectedRow = false; for (j = 0; j < rowElt.childNodes.length; ++j) { cellElt = rowElt.childNodes[j]; bg = new Date(parseInt(cellElt.attr('data-time'))); if (this.elt.level === 'day' && this.elt.isSelectedDate(bg)) { cellElt.addClass('absol-chrome-calendar-selected'); } else if (this.elt.level === 'week' && this.elt.isSelectedWeek(bg)) { cellElt.addClass('absol-chrome-calendar-selected'); if (!isSelectedRow && bg.getFullYear() === this.elt._viewDate.getFullYear()) { isSelectedRow = true; } } else { cellElt.removeClass('absol-chrome-calendar-selected'); } } if (isSelectedRow) { rowElt.addClass('as-selected'); } else { rowElt.removeClass('as-selected'); } } }; /** * @extends CCViewerAbstract * @param {ChromeCalendar}elt * @constructor */ function CCYearViewer(elt) { CCViewerAbstract.call(this, elt); this.$years = elt.$years; this.$yearScroller = elt.$yearScroller; this.$lastOpenYearItem = null; this.mouseListening = false; } (0,absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* .mixClass */ .Jx)(CCYearViewer, CCViewerAbstract); CCYearViewer.prototype.start = function () { this.elt.attr('data-view', 'year'); this.updateContent(); }; CCYearViewer.prototype.updateOpenYear = function () { if (this.$lastOpenYearItem) { this.$lastOpenYearItem.$months.updateActiveMonth(); } }; CCYearViewer.prototype.updateContent = function () { if (!this.$yearsContent) { this.$yearsContent = _({ class: 'absol-chrome-calendar-years-content', child: Array(200).fill(0).map((u, i) => { return { class: 'absol-chrome-calendar-year', attr: { 'data-year': i + 1890 }, child: [ { class: 'absol-chrome-calendar-year-head', child: { text: i + 1890 + '' }, } ], props: { __year__: i + 1890 }, on: { click: () => { this.viewYear(i + 1890); // thisCal.expandYear(this.__year__); }, mouseenter: this.ev_mouseEnter } }; }) }); this.$years.addChild(this.$yearsContent); this.$yearItems = Array.prototype.slice.call(this.$yearsContent.childNodes); } this.viewYear(this.elt._viewDate.getFullYear()); }; CCYearViewer.prototype.createMonths = function (year) { var now = new Date(); var shortMonthNames = getCMLText('shortMonthNames'); var res = _({ class: 'absol-chrome-calendar-year-months', child: Array(3).fill('').map((u, i) => { return { class: 'absol-chrome-calendar-year-row-months', child: Array(4).fill(0).map((v, j) => { var date = new Date(year, i * 4 + j, 1, 0, 0, 0, 0); var quarter = Math.floor((i * 4 + j) / 3); return { class: ['absol-chrome-calendar-year-month'] .concat((year === now.getFullYear() && now.getMonth() === i * 4 + j) ? ['absol-chrome-calendar-today'] : []) .concat(this.elt.isSelectedMonth(date) ? ['absol-chrome-calendar-selected'] : []) , attr: { 'data-quarter': quarter + '', 'data-date': date.getTime() + '', 'data-month': i * 4 + j + '' }, child: { text: shortMonthNames[i * 4 + j] }, on: { click: function () { } }, props: { __date__: date, __quarter__: quarter } } }) } }), on: { click: this.ev_clickMonth } }); res.$monthList = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$$)('.absol-chrome-calendar-year-month', res) res.updateActiveMonth = () => { res.$monthList.forEach((e) => { now = new Date(); if (absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareMonth(e.__date__, now) === 0) { e.addClass('absol-chrome-calendar-today'); } else { e.removeClass('absol-chrome-calendar-today'); } if (this.elt.isSelectedMonth(e.__date__)) { e.addClass('absol-chrome-calendar-selected'); } else { e.removeClass('absol-chrome-calendar-selected'); } if (this.elt.isSelectedQuarter(e.__date__)) { e.addClass('as-quarter-selected'); } else { e.removeClass('as-quarter-selected'); } var beginOfMonth = absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.beginOfMonth(e.__date__); var endOfMonth = absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.prevDate(absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.nextMonth(e.__date__)); if (absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate(this.elt._min, endOfMonth) > 0 || absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_2__.compareDate(beginOfMonth, this.elt._max) > 0) { e.addClass('absol-chrome-calendar-date-disabled'); } else { e.removeClass('absol-chrome-calendar-date-disabled'); } }); } return res; }; CCYearViewer.prototype.viewYear = function (year) { var viewDate = this.elt._viewDate; if (viewDate.getFullYear() !== year) { viewDate = new Date(year, 0, 1, 0, 0, 0, 0); this.elt._viewDate = viewDate; } //todo: update button, title var fontSize = this.elt.getFontSize() || 14; var lastItemElt = this.$lastOpenYearItem; var itemElt = this.$yearItems[year - 1890]; var lastYear = 100000000; if (lastItemElt && lastItemElt.__year__ !== year) { lastYear = lastItemElt.__year__; lastItemElt.addClass('start-closing'); setTimeout(function () { lastItemElt.removeClass('start-closing').addClass('closing'); }, 0); setTimeout(function () { lastItemElt.removeClass('closing'); lastItemElt.$months.remove(); lastItemElt.$months = undefined; }, 100); } if (lastItemElt !== itemElt) { if (!itemElt.$months) { itemElt.$months = this.createMonths(year).addTo(itemElt); itemElt.addClass('start-opening'); setTimeout(function () { itemElt.removeClass('start-opening').addClass('opening'); }, 1); setTimeout(function () { itemElt.removeClass('opening'); }, 100); } } var dy = itemElt.getBoundingClientRect().top - this.$yearScroller.getBoundingClientRect().top - fontSize * 0.45; if (itemElt.__year__ > lastYear) { dy -= 6 * fontSize + 1; } this.$yearScroller.scrollBy(dy, 100); this.$lastOpenYearItem = itemElt; itemElt.$months.updateActiveMonth(); this.elt.headerCtrl.updateTitle(); this.elt.headerCtrl.updateButtons(); }; CCYearViewer.prototype.stop = function () { }; CCYearViewer.prototype.canNext = function () { return this.elt._viewDate.getFullYear() < this.elt._max.getFullYear(); }; CCYearViewer.prototype.canPrev = function () { return this.elt._viewDate.getFullYear() > this.elt._min.getFullYear(); }; CCYearViewer.prototype.canViewToday = function () { var viewDate = new Date(); var year = viewDate.getFullYear(); return year >= this.elt._min.getFullYear() && year <= this.elt._max.getFullYear(); } CCYearViewer.prototype.prev = function () { this.elt._viewDate = new Date(this.elt._viewDate.getFullYear() - 1, 0, 1); this.viewYear(this.elt._viewDate.getFullYear()); }; CCYearViewer.prototype.next = function () { this.elt._viewDate = new Date(this.elt._viewDate.getFullYear() + 1, 0, 1); this.viewYear(this.elt._viewDate.getFullYear()); }; CCYearViewer.prototype.viewToday = function () { this.elt._viewDate = new Date(); this.viewYear(new Date().getFullYear()); }; CCYearViewer.prototype.getTitle = function () { var viewDate = this.elt._viewDate; return '' + viewDate.getFullYear(); }; CCYearViewer.prototype.onSelectedDatesChange = function () { console.log(this.elt.selectedDates); }; CCYearViewer.prototype.ev_clickMonth = function (event) { var monthElt = event.target; var date; if (monthElt && monthElt.attr) date = monthElt.attr('data-date'); if (!date) return; date = new Date(parseInt(date)); var level = this.elt.level; switch (level) { case 'month': case 'quarter': this.elt._selectedDates = [date]; this.updateOpenYear(); this.elt.emit('pick', { type: 'pick', value: date, isTrusted: event && event.isTrusted, originEvent: event }, this.elt); break; case 'year': break; case 'day': case 'week': this.elt._viewDate = date; this.elt.startViewer('month'); break; } }; CCYearViewer.prototype.ev_mouseEnter = function (event) { if (this.mouseListening) return; this.mouseListening = true; document.addEventListener('mousemove', this.ev_mouseMove); }; CCYearViewer.prototype.ev_mouseMove = function (event) { if (!(0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* .hitElement */ .EY)(this.$yearsContent, event)) { this.mouseListening = false; document.removeEventListener('mousemove', this.ev_mouseMove); this.$yearsContent.attr('data-hover-quarter', undefined); return; } if (typeof event.target.__quarter__ === "number") { if (this.$yearsContent.attr('data-hover-quarter') !== event.target.__quarter__ + '') this.$yearsContent.attr('data-hover-quarter', event.target.__quarter__ + ''); } else { this.$yearsContent.attr('data-hover-quarter', undefined); } }; function CCEraViewer(elt) { CCViewerAbstract.call(this, elt); this.$era = elt.$era; this.$yearScroller = elt.$yearScroller; this.$instance = elt.$instance; this._lastStartDecade = -1; this._decadeScrollTimeout = -1; this.scrollIntoDecadeResolve = null; this.title = '1980-2089'; this.$era.on('scroll', this.ev_scroll) .on('click', this.ev_click); } (0,absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_5__/* .mixClass */ .Jx)(CCEraViewer, CCViewerAbstract); CCEraViewer.prototype.start = function () { this.elt.attr('data-view', 'era'); this.updateContent(); this.viewEra(false); this.updatePickedYear(); }; CCEraViewer.prototype.canNext = function () { var viewDate = this.elt._viewDate; var year = viewDate.getFullYear(); var eraIdx = Math.floor(year / 10); var maxEraIdx = Math.floor(this.elt._max.getFullYear() / 10); return (eraIdx < maxEraIdx); }; CCEraViewer.prototype.canPrev = function () { var viewDate = this.elt._viewDate; var year = viewDate.getFullYear(); var eraIdx = Math.floor(year / 10); var minEraIdx = Math.floor(this.elt._min.getFullYear() / 10); return eraIdx > minEraIdx; }; CCEraViewer.prototype.canViewToday = function () { var viewDate = this.elt._viewDate; var year = viewDate.getFullYear(); var eraIdx = Math.floor(year / 10); var minEraIdx = Math.floor(this.elt._min.getFullYear() / 10); var maxEraIdx = Math.floor(this.elt._max.getFullYear() / 10); return eraIdx >= minEraIdx && eraIdx <= maxEraIdx; }; CCEraViewer.prototype.prev = function () { this.elt._viewDate = new Date(this.elt._viewDate.getFullYear() - 10, 0, 1); this.scrollIntoDecade(Math.floor(this.elt._viewDate.getFullYear() / 10) * 10, true) }; CCEraViewer.prototype.next = function () { this.elt._viewDate = new Date(this.elt._viewDate.getFullYear() + 10, 0, 1); this.scrollIntoDecade(Math.floor(this.elt._viewDate.getFullYear() / 10) * 10, true); }; CCEraViewer.prototype.viewToday = function () { this.elt._viewDate = new Date(); this.scrollIntoDecade(Math.floor(this.elt._viewDate.getFullYear() / 10) * 10, true); }; CCEraViewer.prototype.updateContent = function () { if (this.$era.childNodes.length === 0) { var now = new Date(); var cYear = now.getFullYear(); var rows = Array(50).fill(0).map(function (u, i) { return _({ class: 'absol-chrome-calendar-era-row', child: Array(4).fill(0).map(function (u1, j) { var classList = ['absol-chrome-calendar-era-year']; var year = 1890 + i * 4 + j; if (cYear === year) { classList.push('absol-chrome-calendar-today'); } return { class: classList, child: { text: year + '' }, props: { __year__: year } }; }) }); }); this.$era.addChild(rows); } this.updateDisabledYearInEra(); }; CCEraViewer.prototype.viewEra = function (animation) { this.elt.removeClass('view-month') .removeClass('view-year') .addClass('view-era'); this.scrollIntoDecade(Math.floor(this.elt._viewDate.getFullYear() / 10) * 10, animation) }; CCEraViewer.prototype.getTitle = function () { return this.title; }; CCEraViewer.prototype.updatePickedYear = function () { var yearElt; while (this.$lastPickYears && this.$lastPickYears.length > 0) { yearElt = this.$lastPickYears.pop(); yearElt.removeClass('absol-chrome-calendar-selected'); } this.$lastPickYears = this.elt._selectedDates.map((date) => { var yearElt = this.yearInEra(date.getFullYear()); yearElt.addClass('absol-chrome-calendar-selected'); return yearElt; }); }; CCEraViewer.prototype.updateDisabledYearInEra = function () { var i, j; var rowElt, cellElt, date; for (i = 0; i < this.$era.childNodes.length; ++i) { rowElt = this.$era.childNodes[i]; for (j = 0; j < rowElt.childNodes.length; ++j) { cellElt = rowElt.childNodes[j]; date = new Date(cellElt.__year__, 0, 1); if (this.elt.yearCmpLimit(date) === 0) { cellElt.removeClass('absol-chrome-calendar-date-disabled'); } else { cellElt.addClass('absol-chrome-calendar-date-disabled'); } } } }; CCEraViewer.prototype.scrollIntoDecade = function (startYear, animation) { if (!this.elt.isDescendantOf(document.body)) { return this; } return new Promise((resolve) => { var eraBound = this.$era.getBoundingClientRect(); var rowIdx = Math.floor((startYear - 1890) / 4); if (this._decadeScrollTimeout > 0) { clearTimeout(this._decadeScrollTimeout); this._decadeScrollTimeout = -1; } if (this.scrollIntoDecadeResolve) { this.scrollIntoDecadeResolve(); this.scrollIntoDecadeResolve = null; } this.scrollIntoDecadeResolve = resolve; var t0 = new Date().getTime(); var t1 = t0 + 250; var y0 = this.$era.scrollTop; var y1 = rowIdx * eraBound.height / 4; var tick; if (animation) { tick = () => { var tc = new Date().getTime(); var yc = Math.min(1, Math.pow((tc - t0) / (t1 - t0), 2)) * (y1 - y0) + y0; this.$era.scrollTop = yc; if (tc < t1) { this._decadeScrollTimeout = setTimeout(tick, 1000 / 30); } else { this._decadeScrollTimeout = -1; this.scrollIntoDecadeResolve = null; resolve(); } }; this._decadeScrollTimeout = setTimeout(tick, 100); } else { this.$era.scrollTop = y1; } }); }; CCEraViewer.prototype.updateYearInEra = function () { var eraBound = this.$era.getBoundingClientRect(); var startYear = 1890 + 4 * Math.ceil((this.$era.scrollTop - eraBound.height / 16) * 4 / eraBound.height); var startDecade = Math.floor(startYear / 10) * 10; if ((startDecade + 10 - startYear) < 8) startDecade += 10; if (this._lastStartDecade !== startDecade) { if (this._lastStartDecade > 0) { this.clearYearInEra(this._lastStartDecade); } this._lastStartDecade = startDecade; this.activeYearInEra(startDecade); this.title = startDecade + '-' + (startDecade + 10); if (this.elt._level === 'year') { //todo if (!this._decadeScrollTimeout || this._decadeScrollTimeout < 0) { if (this.elt.yearCmpLimit(new Date(startDecade, 0, 1)) === 0) this.elt._viewDate = new Date(startDecade, 0, 1); } } this.elt.headerCtrl.updateTitle(); this.elt.headerCtrl.updateButtons(); } }; CCEraViewer.prototype.clearYearInEra = function (startYear) { var cellElt; for (var i = 0; i < 10; ++i) { cellElt = this.yearInEra(startYear + i); if (cellElt) cellElt.removeClass('absol-chrome-calendar-in-decade'); } }; CCEraViewer.prototype.yearInEra = function (year) { var d = year - 1890; var rowIdx = Math.floor(d / 4); var colIdx = d % 4; return this.$era.childNodes[rowIdx] && this.$era.childNodes[rowIdx].childNodes[colIdx]; }; CCEraViewer.prototype.activeYearInEra = function (startYear) { var cellElt; for (var i = 0; i < 10; ++i) { cellElt = this.yearInEra(startYear + i); if (cellElt) cellElt.addClass('absol-chrome-calendar-in-decade'); } } CCEraViewer.prototype.ev_scroll = function (event) { this.updateYearInEra(); }; CCEraViewer.prototype.ev_click = function (event) { var yearElt = event.target; var year = yearElt.__year__; if (typeof year !== "number") return; var date = new Date(year, 0, 1, 0, 0, 0, 0); if (this.elt.level === 'year') { this.elt._selectedDates = [date]; this.updatePickedYear(); this.scrollIntoDecade(Math.floor(year / 10) * 10, true); this.elt.emit('pick', { type: 'pick', value: date, isTrusted: event && event.isTrusted, originEvent: event, }); } else { this.elt._viewDate = date; this.elt.startViewer('year'); } }; /** * * @param {ChromeCalendar} elt * @constructor */ function CCHeaderController(elt) { this.elt = elt; this.$prevBtn = elt.$prevBtn; this.$nextBtn = elt.$nextBtn; this.$todayBtn = elt.$todayBtn; this.$titleTime = elt.$titleTime; this.$title = elt.$title; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.$prevBtn.on('click', this.ev_clickPrev); this.$nextBtn.on('click', this.ev_clickNext); this.$todayBtn.on('click', this.ev_clickToday); this.$title.on('click', this.ev_clickTitle); } CCHeaderController.prototype.updateTitle = function () { this.$titleTime.innerHTML = this.elt.viewer.getTitle(); }; CCHeaderController.prototype.updateButtons = function () { this.$prevBtn.disabled = !this.elt.viewer.canPrev(); this.$nextBtn.disabled = !this.elt.viewer.canNext(); this.$todayBtn.disabled = !this.elt.viewer.canViewToday(); } CCHeaderController.prototype.ev_clickPrev = function () { this.elt.viewer.prev(); }; CCHeaderController.prototype.ev_clickNext = function () { this.elt.viewer.next(); }; CCHeaderController.prototype.ev_clickToday = function () { this.elt.viewer.viewToday(); }; CCHeaderController.prototype.ev_clickTitle = function () { var curViewer = this.elt.viewer; curViewer.stop(); if (curViewer === this.elt.viewers.month) { this.elt.startViewer('year'); } else if (curViewer === this.elt.viewers.year) { this.elt.startViewer('era'); } }; /** * * @param {AElement|HTMLElement} element * @param calendarProps * @param anchor * @param {function} calendarPickListener * @param {boolean=} darkTheme * @returns {CCShareDropDownInstance} */ ChromeCalendar.showWhenClick = function (element, calendarProps, anchor, calendarPickListener, darkTheme) { var opt = { props: calendarProps, anchor: anchor, onPick: calendarPickListener, darkTheme: darkTheme, triggerElt: element }; return new CCShareDropDownInstance(element, opt); }; ChromeCalendar.show = function (element, calendarProps, anchor, calendarPickListener, darkTheme) { var opt = { props: calendarProps, anchor: anchor, onPick: calendarPickListener, darkTheme: darkTheme, }; var instance = new CCShareDropDownInstance(element, opt); return instance.id; }; ChromeCalendar.close = function (session) { var share = CCShareDropDownInstance.prototype.share; var instance = share.instances[session]; if (instance) { instance.close(); if (!instance.opt.triggerElt) instance.remove(); } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ChromeCalendar); /** * * @param {AElement} elt * @param {{props?:object, anchor?: number[], onPick?: function, darkTheme?: boolean, triggerElt?:AElement }} opt * @constructor */ function CCShareDropDownInstance(elt, opt) { this.id = Math.random() * 10000000000 >> 0; this.elt = elt; this.opt = Object.assign({}, opt); this.ev_clickOut = this.ev_clickOut.bind(this); this.ev_click = this.ev_click.bind(this); if (this.opt.triggerElt) { this.opt.triggerElt.on('click', this.ev_click); } this.share.instances[this.id] = this; } CCShareDropDownInstance.prototype.share = { $follower: null, $picker: null, session: null, onPick: null, holder: null, instances: {} }; CCShareDropDownInstance.prototype.prepare = function () { var share = this.share; if (share.$follower) return; /** * * @type {Follower|AElement} */ share.$follower = _({ tag: _Follower__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z }); share.$follower.cancelWaiting(); share.$picker = _({ tag: ChromeCalendar, on: { pick: (event) => { if (typeof share.onPick === "function") share.onPick(event.value, event, this); } } }).addTo(share.$follower); share.session = Math.random() * 10000000000 >> 0; share.onPick = null; } /** * */ CCShareDropDownInstance.prototype.show = function () { this.prepare(); var share = this.share; if (share.holder) share.holder.close(); share.holder = this; var props = this.opt.props; if (props instanceof Date) props = { selectedDates: [props] }; if (props instanceof Array) props = { selectedDates: props }; props.maxDateLimit = props.maxDateLimit || null; props.minDateLimit = props.minDateLimit || null; share.$follower.addTo(document.body); Object.assign(share.$picker, props); share.$follower.addStyle('visibility', 'hidden'); if (this.opt.darkTheme) { share.$picker.addClass('dark'); } else { share.$picker.removeClass('dark'); } if (this.opt.triggerElt) { setTimeout(() => { document.addEventListener('click', this.ev_clickOut, false); }, 30); } share.$follower.sponsorElement = this.opt.triggerElt || this.elt; share.$follower.anchor = this.opt.anchor; share.$follower.followTarget = this.elt; share.$follower.updatePosition(); share.onPick = ()=>{ var value = share.$picker.selectedDates[0]; if (value && this.opt.onPick) { this.opt.onPick(value); if (this.opt.triggerElt) { this.close(); } } } setTimeout(() => { if (share.holder === this) { share.$follower.removeStyle('visibility', 'hidden'); } }, 10); }; CCShareDropDownInstance.prototype.close = function () { var share = this.share; if (!share.$follower) return; if (share.holder !== this) return; share.holder = null; if (this.opt.triggerElt) { document.removeEventListener('click', this.ev_clickOut, false); } share.onPick = null; share.$follower.selfRemove(); }; /** * * @param {Date} value */ CCShareDropDownInstance.prototype.setDateValue = function (value) { var share = this.share; if (share.holder === this) { share.$picker.selectedDates = [value]; } }; CCShareDropDownInstance.prototype.cancel = function () { this.close(); }; CCShareDropDownInstance.prototype.remove = function () { this.close(); if (this.opt.triggerElt) { this.opt.triggerElt.removeEventListener('click', this.ev_click); } delete this.share.instances[this.id]; }; CCShareDropDownInstance.prototype.ev_clickOut = function (event) { if (!(0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* .hitElement */ .EY)(this.elt, event)) this.close(); }; CCShareDropDownInstance.prototype.ev_click = function (event) { this.show(); }; /***/ }), /***/ 7054: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony export ContextCaptor */ /* harmony import */ var _css_contextmenu_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7994); /* harmony import */ var _css_contextmenu_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_contextmenu_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6628); /* harmony import */ var absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(557); /* harmony import */ var _Menu__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(407); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7951); /* harmony import */ var _BoardTable__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7548); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(1477); /* harmony import */ var absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(9399); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var supportContextEvent = false; var isMobile = absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_9__/* ["default"].isMobile */ .Z.isMobile; /** * @extends AElement * @constructor */ function ContextCaptor() { this.attachedElt = null; this.$textarea = $('textarea', this) .attr('readonly', 'true') .on('contextmenu', this.eventHandler.contextmenu, true); this._ss = 0; this._isTouch = false; /** this._target = null; * @type {Vec2} */ this._posStart = null; /** * @type {Vec2} */ this._posCurrent = null; this._touchId = -100; this._longPressTimeout = -1; this._removeTimeout = -1; this._fireContextMenuTimeout = -1; this.$target = null; this._pointerSession = 0; this._lastContextSession = 0; this.mousedownEvent = null; this.sync = Promise.resolve(); }; ContextCaptor.prototype.attachTo = function (elt) { if (this.attachedElt) { this.attachedElt.removeEventListener('mousedown', this.eventHandler.mousedown); this.attachedElt.removeEventListener('touchstart', this.eventHandler.mousedown); this.attachedElt = null; } this.attachedElt = elt; if (this.attachedElt) { this.attachedElt.addEventListener('mousedown', this.eventHandler.mousedown); this.attachedElt.addEventListener('touchstart', this.eventHandler.mousedown); } return this; }; ContextCaptor.tag = 'ContextCaptor'.toLowerCase(); ContextCaptor.render = function () { return _({ class: ['absol-context-menu-anchor'], extendEvent: 'requestcontextmenu', child: [ 'textarea' ] }); }; ContextCaptor.prototype.showContextMenu = function (x, y, props, onSelectItem) { var self = this; var anchor = _('.as-context-menu-ctn.absol-context-menu-anchor' + (isMobile ? '.as-anchor-modal' : '')).addTo(document.body); var finish = function (event) { document.removeEventListener('click', finish); document.removeEventListener('touchcancel', finish); document.removeEventListener('touchend', finish); document.removeEventListener('contextmenu', finish); anchor.off('click', touchModal); self.off('requestcontextmenu', finish); setTimeout(function () { anchor.selfRemove();// }, 10); }; function touchModal(event) { if (event.target.classList && event.target.classList.contains('as-anchor-modal')) { finish(event); } } var vmenu = _({ tag: 'vmenu', props: props, on: { press: onSelectItem || function () { } } }).addTo(anchor); setTimeout(function () { if (!isMobile) { var screenSize = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].getScreenSize */ .ZP.getScreenSize(); var menuBound = vmenu.getBoundingClientRect(); if (x + menuBound.width > screenSize.width - 17) { x -= menuBound.width; } if (y + menuBound.height > screenSize.height - 17) { y -= menuBound.height; } anchor.addStyle({ left: x + 'px', top: y + 'px' }); } anchor.addClass('absol-active'); (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$$)('VMenuItem'.toLowerCase(), vmenu).forEach(e => { if (e.autoFixParentSize) e.autoFixParentSize(); }); }, 30); setTimeout(function () { document.addEventListener('click', finish) document.addEventListener('contextmenu', finish); self.on('requestcontextmenu', finish); anchor.on('click', touchModal); }, 10) }; ContextCaptor.prototype._checkNeedHandle = function (target) { var current = target; var needHandle = false; while (current && !needHandle && !current.classList.contains('as-system-context-menu')) { if (current.isSupportedEvent && current.isSupportedEvent('contextmenu')) needHandle = true; current = current.parentElement; } return needHandle; }; ContextCaptor.prototype._fireContextMenuEvent = function () { if (this._lastContextSession >= this._pointerSession) return false;// prevent fire multi-times in a pointer session var showed = false; this._lastContextSession = this._pointerSession; var baseEventData = { clientX: this._posCurrent.x, clientY: this._posCurrent.y, target: this.$target }; this.emit('requestcontextmenu', baseEventData, this); var self = this; var propagation = true; var localEvent = Object.assign({ clientX: this._posCurrent.x, clientY: this._posCurrent.y, target: this.$target, showContextMenu: function (props, onSelectItem) { showed = true; self.sync = self.sync.then(function () { return new Promise(function (rs) { setTimeout(function () { self.showContextMenu(self._posCurrent.x, self._posCurrent.y, props, onSelectItem); rs(); }, 30) }); }) }, stopPropagation: function () { propagation = false; } }, baseEventData); Object.defineProperty(localEvent, 'selectedText', { get: function () { return (0,_utils__WEBPACK_IMPORTED_MODULE_8__.getSelectionText)(); } }); var current = this.$target; while (current && propagation) { if (current.isSupportedEvent && current.isSupportedEvent('contextmenu')) { current.emit('contextmenu', localEvent, current, this); } current = current.parentElement; } return showed; }; /** * @type {ContextCaptor} */ ContextCaptor.eventHandler = {}; ContextCaptor.eventHandler.mousedown = function (event) { if (this._touchId != -100) return; this._pointerSession++; var target; var isTouch; var touchId; var posCurrent; var pointer; if (event.type == 'touchstart') { isTouch = true; pointer = event.changedTouches[0]; touchId = pointer.identifier; } else { isTouch = false; touchId = -1; pointer = event; } target = pointer.target; posCurrent = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z(pointer.clientX, pointer.clientY); if (isTouch) { var dragzone = _BoardTable__WEBPACK_IMPORTED_MODULE_7__/* ["default"].prototype._findDragZone */ .ZP.prototype._findDragZone(target); if (dragzone) return; var thisCT = this; this._longPressTimeout = setTimeout(function () { if (!thisCT._checkNeedHandle(target)) return; if (thisCT._removeTimeout > 0) { clearTimeout(thisCT._removeTimeout); thisCT._removeTimeout = -1; } thisCT._ss++; thisCT.moveTo(thisCT._posCurrent); thisCT.active(true); thisCT._longPressTimeout = -1; if (thisCT._fireContextMenuTimeout >= 0) { clearTimeout(thisCT._fireContextMenuTimeout); } // show if device not support contextmenu event (after 700ms) thisCT._fireContextMenuTimeout = setTimeout(function () { if (!supportContextEvent) { thisCT._fireContextMenuEvent(); } }, 300); }, 400); this.$target = target; this._isTouch = isTouch; this._touchId = touchId; this._posCurrent = posCurrent; this._posStart = posCurrent; document.addEventListener('touchmove', thisCT.eventHandler.mousemove); document.addEventListener('touchend', thisCT.eventHandler.mousefinish); document.addEventListener('touchcancel', thisCT.eventHandler.mousefinish); } else { if (absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__/* ["default"].isMouseRight */ .ZP.isMouseRight(event) && this._checkNeedHandle(target)) { if (this._removeTimeout > 0) { clearTimeout(this._removeTimeout); this._removeTimeout = -1; } this.$target = target; this._isTouch = isTouch; this._posCurrent = posCurrent; this._posStart = posCurrent; this._touchId = touchId; this._ss++; this.moveTo(this._posCurrent); this.active(true); document.addEventListener('mousemove', this.eventHandler.mousemove); document.addEventListener('mouseup', this.eventHandler.mousefinish); document.addEventListener('mouseleave', this.eventHandler.mousefinish); } } }; /** * @param {Vec2} pos */ ContextCaptor.prototype.moveTo = function (pos) { this.addStyle({ left: pos.x - 80 + 'px', top: pos.y - 80 + 'px' }); }; ContextCaptor.prototype.active = function (flag) { if (flag) this.addClass('absol-active'); else this.removeClass('absol-active'); }; ContextCaptor.eventHandler.mousemove = function (event) { var isTouch = this._isTouch; var touchId; var pointer; var posCurrent; if (isTouch) { pointer = event.changedTouches[0]; touchId = pointer.identifier; } else { isTouch = false; touchId = -1; pointer = event; } if (touchId != this._touchId) return; posCurrent = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z(pointer.clientX, pointer.clientY); this._posCurrent = posCurrent; if (isTouch) { if (this._posStart.sub(posCurrent).abs() > 10) this.eventHandler.mousefinish(event); } this.moveTo(posCurrent); }; ContextCaptor.eventHandler.mousefinish = function (event) { var isTouch = this._isTouch; var touchId; var pointer; if (isTouch) { pointer = event.changedTouches[0]; touchId = pointer.identifier; } else { isTouch = false; touchId = -1; pointer = event; } if (touchId != this._touchId) return; if (isTouch) { document.removeEventListener('touchmove', this.eventHandler.mousemove); document.removeEventListener('touchend', this.eventHandler.mousefinish); document.removeEventListener('touchcancel', this.eventHandler.mousefinish); if (this._longPressTimeout > 0) { clearTimeout(this._longPressTimeout); this._longPressTimeout = -1; } } else { document.removeEventListener('mousemove', this.eventHandler.mousemove); document.removeEventListener('mouseup', this.eventHandler.mousefinish); document.removeEventListener('mouseleave', this.eventHandler.mousefinish); } this._touchId = -100; if (this._fireContextMenuTimeout >= 0) { clearTimeout(this._fireContextMenuTimeout); } var thisCT = this; this._removeTimeout = setTimeout(function () { thisCT.active(false); thisCT._removeTimeout = -1; }, 1); }; ContextCaptor.eventHandler.contextmenu = function (event) { supportContextEvent = true; event.preventDefault(); this._fireContextMenuEvent(); }; ContextCaptor.auto = function () { if (ContextCaptor.$elt) return; ContextCaptor.$elt = _('contextcaptor'); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].documentReady.then */ .ZP.documentReady.then(function () { ContextCaptor.$elt.addTo(document.body); ContextCaptor.$elt.attachTo(document.body); }); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ContextCaptor); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ContextCaptor); /***/ }), /***/ 5611: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); function Draggable(element) { if (!element) element = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"]._ */ .Z._('div'); else _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$ */ .Z.$(element); element.defineEvent(['predrag', 'drag', 'begindrag', 'enddrag']); var body = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$ */ .Z.$('body'); var isMoving = false; var firstMove = false; var offsetX; var offsetY; var fontSize; var left0em, top0em, left0, top0; var finishMoving = function (event) { if (isMoving) { isMoving = false; body.off('mousemove', mouseMoveEventHandler); event.moveDX = event.clientX - offsetX; event.moveDY = event.clientY - offsetY; event.moveDXem = event.moveDX / fontSize; event.moveDYem = event.moveDY / fontSize; event.moveToX = left0 + event.moveDX; event.moveToY = top0 + event.moveDY; element.emit('enddrag', event); } }; var mouseUpEventHandler = function (event) { finishMoving(event); }; var mouseMoveEventHandler = function (event) { event.preventDefault(); event.moveDX = event.clientX - offsetX; event.moveDY = event.clientY - offsetY; event.moveDXem = event.moveDX / fontSize; event.moveDYem = event.moveDY / fontSize; event.moveToX = left0 + event.moveDX; event.moveToY = top0 + event.moveDY; event.moveToXem = left0em + event.moveDXem; event.moveToYem = top0em + event.moveDYem; if (firstMove) { firstMove = false; element.emit('begindrag', event); } element.emit('drag', event); }; var mouseOutEventHandler = function (event) { finishMoving(event); }; var mouseDownEventHandler = function (event) { isMoving = true; firstMove = true; body.on('mousemove', mouseMoveEventHandler); body.once('mouseleave', mouseOutEventHandler); body.once('mouseup', mouseUpEventHandler); fontSize = this.getFontSize(); offsetX = event.clientX; offsetY = event.clientY; left0 = parseFloat(element.getComputedStyleValue('left').replace('px', '')); top0 = parseFloat(element.getComputedStyleValue('top').replace('px', '')); left0em = left0 / fontSize; top0em = top0 / fontSize; event.x0 = left0; event.y0 = top0; event.y0em = left0em; event.y0em = top0em; element.emit('predrag', event); }; element.on('mousedown', mouseDownEventHandler); return element; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Draggable); /***/ }), /***/ 1577: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_dropzone_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6950); /* harmony import */ var _css_dropzone_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_dropzone_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(863); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function DropZone() { this.defineEvent(['fileenter', 'fileleave', 'filedrop']); this.addClass('as-drop-zone'); this.on('dragover', this.eventHandler.dragZoneFileOver) .on('drop', this.eventHandler.dropZoneFileDrop); this._fileOverTimeout = -1; } DropZone.tag = 'dropzone'; DropZone.render = function () { return _('div'); }; DropZone.eventHandler = {}; DropZone.eventHandler.dragZoneFileOver = function (event) { event.preventDefault(); if (this._fileOverTimeout > 0) { clearTimeout(this._fileOverTimeout); } else { this.addClass('as-drag-over'); this.emit('fileenter', event, this); } this._fileOverTimeout = setTimeout(this.eventHandler.dragZoneFileOverEnd, 200); }; /*** * * @param {DragEvent} event */ DropZone.eventHandler.dropZoneFileDrop = function (event) { if (this._fileOverTimeout > 0) { clearTimeout(this._fileOverTimeout); this._fileOverTimeout = -1; } event.preventDefault(); this.removeClass('as-drag-over'); event._files = null; if (!event.hasOwnProperty('files')) Object.defineProperty(event, 'files', { get: function () { if (this._files) return this._files; var files = []; var file; if (event.dataTransfer.items) { for (var i = 0; i < event.dataTransfer.items.length; i++) { if (event.dataTransfer.items[i].kind === 'file') { file = event.dataTransfer.items[i].getAsFile(); files.push(file); } } } else { // Use DataTransfer interface to access the file(s) for (var i = 0; i < event.dataTransfer.files.length; i++) { files.push(event.dataTransfer.files[i]); } } this._files = files; return this._files; } }); this.emit('filedrop', event, this); }; DropZone.eventHandler.dragZoneFileOverEnd = function () { this._fileOverTimeout = -1; this.removeClass('as-drag-over'); this.emit('fileleave', {type: 'fileleave'}, this); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(DropZone); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DropZone); /***/ }), /***/ 4670: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__), /* harmony export */ "M": () => (/* binding */ EmojiAnimByIdent) /* harmony export */ }); var EmojiAnims = [ [ "(heart)", "heart.png", "Heart" ], [ "(cool)", "cool.png", "Cool" ], [ "(hearteyes)", "hearteyes.png", "Heart eyes" ], [ "(stareyes)", "stareyes.png", "Star eyes" ], [ "(like)", "like.png", "Like" ], [ "(unamused)", "unamused.png", "Unamused" ], [ "(cwl)", "cwl.png", "Crying with laughter" ], [ "(xd)", "xd.png", "XD smiley" ], [ ":)", "smile.png", "Smile" ], [ ":(", "sad.png", "Sad" ], [ ":D", "laugh.png", "Laugh" ], [ ":O", "surprised.png", "Surprised" ], [ ";)", "wink.png", "Wink" ], [ ";(", "cry.png", "Crying" ], [ "(shivering)", "shivering.png", "Cold shivering" ], [ "(:|", "sweat.png", "Sweating" ], [ ":|", "speechless.png", "Speechless" ], [ ":P", "tongueout.png", "Cheeky" ], [ ":$", "blush.png", "Blushing" ], [ "(inlove)", "inlove.png", "In love" ], [ "(kiss)", "kiss.png", "Kiss" ], [ ":^)", "wonder.png", "Wondering" ], [ "|-)", "sleepy.png", "Sleepy" ], [ "|-(", "dull.png", "Dull" ], [ "(yawn)", "yawn.png", "Yawn" ], [ "(puke)", "puke.png", "Vomiting" ], [ "(doh)", "doh.png", "Doh!" ], [ "(angry)", "angry.png", "Angry" ], [ "(wasntme)", "wasntme.png", "It wasn't me!" ], [ "(worry)", "worry.png", "Worried" ], [ "(mm)", "mmm.png", "Mmmmm…" ], [ "(nerd)", "nerdy.png", "Nerdy" ], [ "(rainbowsmile)", "rainbowsmile.png", "Rainbow smile" ], [ ":x", "lipssealed.png", "My lips are sealed" ], [ "(devil)", "devil.png", "Devil" ], [ "(angel)", "angel.png", "Angel" ], [ "(envy)", "envy.png", "Envy" ], [ "(makeup)", "makeup.png", "Make-up" ], [ "(think)", "think.png", "Thinking" ], [ "(rofl)", "rofl.png", "Rolling on the floor laughing" ], [ "(happy)", "happy.png", "Happy" ], [ "(smirk)", "smirk.png", "Smirking" ], [ "(nod)", "nod.png", "Nodding" ], [ "(shake)", "shake.png", "Shake" ], [ "(waiting)", "waiting.png", "Waiting" ], [ "(emo)", "emo.png", "Emo" ], [ "(donttalk)", "donttalktome.png", "Don't talk to me" ], [ "(idea)", "idea.png", "Idea" ], [ "(talk)", "talk.png", "Talking" ], [ "(swear)", "swear.png", "Swearing" ], [ "]:)", "evilgrin.png", "Evil grin" ], [ "(headbang)", "headbang.png", "Banging head on wall" ], [ "(learn)", "learn.png", "Global Learning" ], [ "(headphones)", "headphones.png", "Listening to headphones" ], [ "(morningafter)", "hungover.png", "Morning after party" ], [ "(selfie)", "selfie.png", "Selfie" ], [ "(shock)", "shock.png", "Spoiler alert" ], [ "(llsshock)", "llsshock.png", "Spoiler alert" ], [ "(ttm)", "ttm.png", "Talking too much" ], [ "(dream)", "dream.png", "Dreaming" ], [ "(ill)", "ill.png", "Ill" ], [ "(tired)", "tired.png", "Tired" ], [ "(party)", "party.png", "Party" ], [ "(bandit)", "bandit.png", "Bandit" ], [ "(tauri)", "tauri.png", "Bald man with glasses" ], [ "(nazar)", "nazar.png", "Blessing" ], [ "(movember)", "movember.png", "Movember" ], [ "(mysteryskype)", "mysteryskype.png", "Mystery Skype" ], [ "(dotdfemale)", "dotdfemale.png", "Day of the dead" ], [ "(dotdmale)", "dotdmale.png", "Day of the dead" ], [ "(selfiediwali)", "selfiediwali.png", "Selfie Diwali" ], [ "(diwaliselfie)", "diwaliselfie.png", "Diwali selfie" ], [ "(steveaoki)", "steveaoki.png", "Steve Aoki" ], [ "(aokijump)", "aokijump.png", "Aoki jump" ], [ "(cakethrow)", "cakethrow.png", "Cake throw" ], [ "(kolony)", "kolony.png", "Kolony" ], [ "(joy)", "joy.png", "Joy" ], [ "(anger)", "anger.png", "Anger" ], [ "(sadness)", "sadness.png", "Sadness" ], [ "(disgust)", "disgust.png", "Disgust" ], [ "(fear)", "fear.png", "Fear" ], [ "(hestonfacepalm)", "hestonfacepalm.png", "Heston facepalm" ], [ "(heston)", "heston.png", "Heston Blumenthal" ], [ "(stormtrooper)", "stormtrooper.png", "Storm trooper" ], [ "(kyloren)", "kyloren.png", "Kylo Ren" ], [ "(captainphasma)", "captainphasma.png", "Captain Phasma" ], [ "(malthe)", "malthe.png", "Smiling man with glasses" ], [ "(ladyvamp)", "ladyvampire.png", "Lady vampire" ], [ "(vampire)", "vampire.png", "Vampire" ], [ "(ghost)", "ghost.png", "Ghost" ], [ "(skull)", "skull.png", "Skull" ], [ "(pumpkin)", "pumpkin.png", "Pumpkin" ], [ "(santa)", "santa.png", "Santa" ], [ "(xmascwl)", "xmascwl.png", "Xmas crying with laughter" ], [ "(festiveparty)", "festiveparty.png", "Festive party" ], [ "(holidayspirit)", "holidayspirit.png", "Holiday spirit" ], [ "(rudolfsurprise)", "rudolfsurprise.png", "Surprised Rudolf" ], [ "(rudolfidea)", "rudolfidea.png", "Rudolf idea" ], [ "(wtf)", "wtf.png", "WTF…" ], [ "(smoking)", "smoke.png", "Smoking" ], [ "(drunk)", "drunk.png", "Drunk" ], [ "(finger)", "finger.png", "Finger" ], [ "(oliver)", "oliver.png", "Man saying come on" ], [ "(xmassarcastic)", "xmassarcastic.png", "Xmas sarcastic" ], [ "(xmascry)", "xmascry.png", "Xmas cry" ], [ "(wave)", "hi.png", "Hi" ], [ "(highfive)", "highfive.png", "High five" ], [ "(clap)", "clap.png", "Clapping" ], [ "(sarcastic)", "sarcastic.png", "Sarcastic" ], [ "(chuckle)", "giggle.png", "Giggle" ], [ "(facepalm)", "facepalm.png", "Facepalm" ], [ "(rock)", "rock.png", "Rock" ], [ "(yn)", "fingerscrossed.png", "Fingers crossed" ], [ "(listening)", "listening.png", "Listening" ], [ "(wait)", "wait.png", "Wait" ], [ "(whew)", "whew.png", "Relieved" ], [ "(tmi)", "tmi.png", "Too much information" ], [ "(call)", "call.png", "Call" ], [ "(punch)", "punch.png", "Punch" ], [ "(talktothehand)", "talktothehand.png", "Talk to the hand" ], [ "(whistle)", "whistle.png", "Whistle" ], [ "(slap)", "slap.png", "Slap" ], [ "(lalala)", "lalala.png", "Lalala" ], [ "(y)", "yes.png", "Yes" ], [ "(n)", "no.png", "No" ], [ "(handshake)", "handshake.png", "Handshake" ], [ "(fistbump)", "fistbump.png", "Fist bump" ], [ "(poke)", "poke.png", "Poke" ], [ "(celebrate)", "handsinair.png", "Hands celebrating" ], [ "(hearthands)", "hearthands.png", "Heart hands" ], [ "(victory)", "victory.png", "Victory sign" ], [ "(noworries)", "noworries.png", "No worries" ], [ "(ok)", "ok.png", "OK" ], [ "(pray)", "praying.png", "Praying" ], [ "(flex)", "muscle.png", "Muscle" ], [ "(ek)", "naturescall.png", "Nature's call" ], [ "(woty)", "woty.png", "Woman of the year" ], [ "(glassceiling)", "glassceiling.png", "Glass ceiling" ], [ "(deadyes)", "deadyes.png", "Dead yes" ], [ "(xmasyes)", "xmasyes.png", "Xmas yes" ], [ "(dropthemic)", "dropthemic.png", "Drop the mic" ] ]; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EmojiAnims); var EmojiAnimByIdent = EmojiAnims.reduce((ac, cr) => { ac[cr[0]] = cr; return ac; }, {}); /***/ }), /***/ 7712: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); var EmojiChars = [["Smileys & Emotion", [["face-smiling", [[["U+1F600"], "😀", "grinning face"], [["U+1F603"], "😃", "grinning face with big eyes"], [["U+1F604"], "😄", "grinning face with smiling eyes"], [["U+1F601"], "😁", "beaming face with smiling eyes"], [["U+1F606"], "😆", "grinning squinting face"], [["U+1F605"], "😅", "grinning face with sweat"], [["U+1F923"], "🤣", "rolling on the floor laughing"], [["U+1F602"], "😂", "face with tears of joy"], [["U+1F642"], "🙂", "slightly smiling face"], [["U+1F643"], "🙃", "upside-down face"], [["U+1F609"], "😉", "winking face"], [["U+1F60A"], "😊", "smiling face with smiling eyes"], [["U+1F607"], "😇", "smiling face with halo"]]], ["face-affection", [[["U+1F970"], "🥰", "smiling face with hearts"], [["U+1F60D"], "😍", "smiling face with heart-eyes"], [["U+1F929"], "🤩", "star-struck"], [["U+1F618"], "😘", "face blowing a kiss"], [["U+1F617"], "😗", "kissing face"], [["U+263A"], "☺", "smiling face"], [["U+1F61A"], "😚", "kissing face with closed eyes"], [["U+1F619"], "😙", "kissing face with smiling eyes"], [["U+1F972"], "🥲", "⊛ smiling face with tear"]]], ["face-tongue", [[["U+1F60B"], "😋", "face savoring food"], [["U+1F61B"], "😛", "face with tongue"], [["U+1F61C"], "😜", "winking face with tongue"], [["U+1F92A"], "🤪", "zany face"], [["U+1F61D"], "😝", "squinting face with tongue"], [["U+1F911"], "🤑", "money-mouth face"]]], ["face-hand", [[["U+1F917"], "🤗", "hugging face"], [["U+1F92D"], "🤭", "face with hand over mouth"], [["U+1F92B"], "🤫", "shushing face"], [["U+1F914"], "🤔", "thinking face"]]], ["face-neutral-skeptical", [[["U+1F910"], "🤐", "zipper-mouth face"], [["U+1F928"], "🤨", "face with raised eyebrow"], [["U+1F610"], "😐", "neutral face"], [["U+1F611"], "😑", "expressionless face"], [["U+1F636"], "😶", "face without mouth"], [["U+1F60F"], "😏", "smirking face"], [["U+1F612"], "😒", "unamused face"], [["U+1F644"], "🙄", "face with rolling eyes"], [["U+1F62C"], "😬", "grimacing face"], [["U+1F925"], "🤥", "lying face"]]], ["face-sleepy", [[["U+1F60C"], "😌", "relieved face"], [["U+1F614"], "😔", "pensive face"], [["U+1F62A"], "😪", "sleepy face"], [["U+1F924"], "🤤", "drooling face"], [["U+1F634"], "😴", "sleeping face"]]], ["face-unwell", [[["U+1F637"], "😷", "face with medical mask"], [["U+1F912"], "🤒", "face with thermometer"], [["U+1F915"], "🤕", "face with head-bandage"], [["U+1F922"], "🤢", "nauseated face"], [["U+1F92E"], "🤮", "face vomiting"], [["U+1F927"], "🤧", "sneezing face"], [["U+1F975"], "🥵", "hot face"], [["U+1F976"], "🥶", "cold face"], [["U+1F974"], "🥴", "woozy face"], [["U+1F635"], "😵", "dizzy face"], [["U+1F92F"], "🤯", "exploding head"]]], ["face-hat", [[["U+1F920"], "🤠", "cowboy hat face"], [["U+1F973"], "🥳", "partying face"], [["U+1F978"], "🥸", "⊛ disguised face"]]], ["face-glasses", [[["U+1F60E"], "😎", "smiling face with sunglasses"], [["U+1F913"], "🤓", "nerd face"], [["U+1F9D0"], "🧐", "face with monocle"]]], ["face-concerned", [[["U+1F615"], "😕", "confused face"], [["U+1F61F"], "😟", "worried face"], [["U+1F641"], "🙁", "slightly frowning face"], [["U+2639"], "☹", "frowning face"], [["U+1F62E"], "😮", "face with open mouth"], [["U+1F62F"], "😯", "hushed face"], [["U+1F632"], "😲", "astonished face"], [["U+1F633"], "😳", "flushed face"], [["U+1F97A"], "🥺", "pleading face"], [["U+1F626"], "😦", "frowning face with open mouth"], [["U+1F627"], "😧", "anguished face"], [["U+1F628"], "😨", "fearful face"], [["U+1F630"], "😰", "anxious face with sweat"], [["U+1F625"], "😥", "sad but relieved face"], [["U+1F622"], "😢", "crying face"], [["U+1F62D"], "😭", "loudly crying face"], [["U+1F631"], "😱", "face screaming in fear"], [["U+1F616"], "😖", "confounded face"], [["U+1F623"], "😣", "persevering face"], [["U+1F61E"], "😞", "disappointed face"], [["U+1F613"], "😓", "downcast face with sweat"], [["U+1F629"], "😩", "weary face"], [["U+1F62B"], "😫", "tired face"], [["U+1F971"], "🥱", "yawning face"]]], ["face-negative", [[["U+1F624"], "😤", "face with steam from nose"], [["U+1F621"], "😡", "pouting face"], [["U+1F620"], "😠", "angry face"], [["U+1F92C"], "🤬", "face with symbols on mouth"], [["U+1F608"], "😈", "smiling face with horns"], [["U+1F47F"], "👿", "angry face with horns"], [["U+1F480"], "💀", "skull"], [["U+2620"], "☠", "skull and crossbones"]]], ["face-costume", [[["U+1F4A9"], "💩", "pile of poo"], [["U+1F921"], "🤡", "clown face"], [["U+1F479"], "👹", "ogre"], [["U+1F47A"], "👺", "goblin"], [["U+1F47B"], "👻", "ghost"], [["U+1F47D"], "👽", "alien"], [["U+1F47E"], "👾", "alien monster"], [["U+1F916"], "🤖", "robot"]]], ["cat-face", [[["U+1F63A"], "😺", "grinning cat"], [["U+1F638"], "😸", "grinning cat with smiling eyes"], [["U+1F639"], "😹", "cat with tears of joy"], [["U+1F63B"], "😻", "smiling cat with heart-eyes"], [["U+1F63C"], "😼", "cat with wry smile"], [["U+1F63D"], "😽", "kissing cat"], [["U+1F640"], "🙀", "weary cat"], [["U+1F63F"], "😿", "crying cat"], [["U+1F63E"], "😾", "pouting cat"]]], ["monkey-face", [[["U+1F648"], "🙈", "see-no-evil monkey"], [["U+1F649"], "🙉", "hear-no-evil monkey"], [["U+1F64A"], "🙊", "speak-no-evil monkey"]]], ["emotion", [[["U+1F48B"], "💋", "kiss mark"], [["U+1F48C"], "💌", "love letter"], [["U+1F498"], "💘", "heart with arrow"], [["U+1F49D"], "💝", "heart with ribbon"], [["U+1F496"], "💖", "sparkling heart"], [["U+1F497"], "💗", "growing heart"], [["U+1F493"], "💓", "beating heart"], [["U+1F49E"], "💞", "revolving hearts"], [["U+1F495"], "💕", "two hearts"], [["U+1F49F"], "💟", "heart decoration"], [["U+2763"], "❣", "heart exclamation"], [["U+1F494"], "💔", "broken heart"], [["U+2764"], "❤", "red heart"], [["U+1F9E1"], "🧡", "orange heart"], [["U+1F49B"], "💛", "yellow heart"], [["U+1F49A"], "💚", "green heart"], [["U+1F499"], "💙", "blue heart"], [["U+1F49C"], "💜", "purple heart"], [["U+1F90E"], "🤎", "brown heart"], [["U+1F5A4"], "🖤", "black heart"], [["U+1F90D"], "🤍", "white heart"], [["U+1F4AF"], "💯", "hundred points"], [["U+1F4A2"], "💢", "anger symbol"], [["U+1F4A5"], "💥", "collision"], [["U+1F4AB"], "💫", "dizzy"], [["U+1F4A6"], "💦", "sweat droplets"], [["U+1F4A8"], "💨", "dashing away"], [["U+1F573"], "🕳", "hole"], [["U+1F4A3"], "💣", "bomb"], [["U+1F4AC"], "💬", "speech balloon"], [["U+1F441", "U+FE0F", "U+200D", "U+1F5E8", "U+FE0F"], "👁️🗨️", "eye in speech bubble"], [["U+1F5E8"], "🗨", "left speech bubble"], [["U+1F5EF"], "🗯", "right anger bubble"], [["U+1F4AD"], "💭", "thought balloon"], [["U+1F4A4"], "💤", "zzz"]]]]], ["People & Body", [["hand-fingers-open", [[["U+1F44B"], "👋", "waving hand"], [["U+1F91A"], "🤚", "raised back of hand"], [["U+1F590"], "🖐", "hand with fingers splayed"], [["U+270B"], "✋", "raised hand"], [["U+1F596"], "🖖", "vulcan salute"]]], ["hand-fingers-partial", [[["U+1F44C"], "👌", "OK hand"], [["U+1F90C"], "🤌", "⊛ pinched fingers"], [["U+1F90F"], "🤏", "pinching hand"], [["U+270C"], "✌", "victory hand"], [["U+1F91E"], "🤞", "crossed fingers"], [["U+1F91F"], "🤟", "love-you gesture"], [["U+1F918"], "🤘", "sign of the horns"], [["U+1F919"], "🤙", "call me hand"]]], ["hand-single-finger", [[["U+1F448"], "👈", "backhand index pointing left"], [["U+1F449"], "👉", "backhand index pointing right"], [["U+1F446"], "👆", "backhand index pointing up"], [["U+1F595"], "🖕", "middle finger"], [["U+1F447"], "👇", "backhand index pointing down"], [["U+261D"], "☝", "index pointing up"]]], ["hand-fingers-closed", [[["U+1F44D"], "👍", "thumbs up"], [["U+1F44E"], "👎", "thumbs down"], [["U+270A"], "✊", "raised fist"], [["U+1F44A"], "👊", "oncoming fist"], [["U+1F91B"], "🤛", "left-facing fist"], [["U+1F91C"], "🤜", "right-facing fist"]]], ["hands", [[["U+1F44F"], "👏", "clapping hands"], [["U+1F64C"], "🙌", "raising hands"], [["U+1F450"], "👐", "open hands"], [["U+1F932"], "🤲", "palms up together"], [["U+1F91D"], "🤝", "handshake"], [["U+1F64F"], "🙏", "folded hands"]]], ["hand-prop", [[["U+270D"], "✍", "writing hand"], [["U+1F485"], "💅", "nail polish"], [["U+1F933"], "🤳", "selfie"]]], ["body-parts", [[["U+1F4AA"], "💪", "flexed biceps"], [["U+1F9BE"], "🦾", "mechanical arm"], [["U+1F9BF"], "🦿", "mechanical leg"], [["U+1F9B5"], "🦵", "leg"], [["U+1F9B6"], "🦶", "foot"], [["U+1F442"], "👂", "ear"], [["U+1F9BB"], "🦻", "ear with hearing aid"], [["U+1F443"], "👃", "nose"], [["U+1F9E0"], "🧠", "brain"], [["U+1F9B7"], "🦷", "tooth"], [["U+1F9B4"], "🦴", "bone"], [["U+1F440"], "👀", "eyes"], [["U+1F441"], "👁", "eye"], [["U+1F445"], "👅", "tongue"], [["U+1F444"], "👄", "mouth"]]], ["person", [[["U+1F476"], "👶", "baby"], [["U+1F9D2"], "🧒", "child"], [["U+1F466"], "👦", "boy"], [["U+1F467"], "👧", "girl"], [["U+1F9D1"], "🧑", "person"], [["U+1F471"], "👱", "person: blond hair"], [["U+1F468"], "👨", "man"], [["U+1F9D4"], "🧔", "man: beard"], [["U+1F468", "U+200D", "U+1F9B0"], "👨🦰", "man: red hair"], [["U+1F468", "U+200D", "U+1F9B1"], "👨🦱", "man: curly hair"], [["U+1F468", "U+200D", "U+1F9B3"], "👨🦳", "man: white hair"], [["U+1F468", "U+200D", "U+1F9B2"], "👨🦲", "man: bald"], [["U+1F469"], "👩", "woman"], [["U+1F469", "U+200D", "U+1F9B0"], "👩🦰", "woman: red hair"], [["U+1F9D1", "U+200D", "U+1F9B0"], "🧑🦰", "person: red hair"], [["U+1F469", "U+200D", "U+1F9B1"], "👩🦱", "woman: curly hair"], [["U+1F9D1", "U+200D", "U+1F9B1"], "🧑🦱", "person: curly hair"], [["U+1F469", "U+200D", "U+1F9B3"], "👩🦳", "woman: white hair"], [["U+1F9D1", "U+200D", "U+1F9B3"], "🧑🦳", "person: white hair"], [["U+1F469", "U+200D", "U+1F9B2"], "👩🦲", "woman: bald"], [["U+1F9D1", "U+200D", "U+1F9B2"], "🧑🦲", "person: bald"], [["U+1F471", "U+200D", "U+2640", "U+FE0F"], "👱♀️", "woman: blond hair"], [["U+1F471", "U+200D", "U+2642", "U+FE0F"], "👱♂️", "man: blond hair"], [["U+1F9D3"], "🧓", "older person"], [["U+1F474"], "👴", "old man"], [["U+1F475"], "👵", "old woman"]]], ["person-gesture", [[["U+1F64D"], "🙍", "person frowning"], [["U+1F64D", "U+200D", "U+2642", "U+FE0F"], "🙍♂️", "man frowning"], [["U+1F64D", "U+200D", "U+2640", "U+FE0F"], "🙍♀️", "woman frowning"], [["U+1F64E"], "🙎", "person pouting"], [["U+1F64E", "U+200D", "U+2642", "U+FE0F"], "🙎♂️", "man pouting"], [["U+1F64E", "U+200D", "U+2640", "U+FE0F"], "🙎♀️", "woman pouting"], [["U+1F645"], "🙅", "person gesturing NO"], [["U+1F645", "U+200D", "U+2642", "U+FE0F"], "🙅♂️", "man gesturing NO"], [["U+1F645", "U+200D", "U+2640", "U+FE0F"], "🙅♀️", "woman gesturing NO"], [["U+1F646"], "🙆", "person gesturing OK"], [["U+1F646", "U+200D", "U+2642", "U+FE0F"], "🙆♂️", "man gesturing OK"], [["U+1F646", "U+200D", "U+2640", "U+FE0F"], "🙆♀️", "woman gesturing OK"], [["U+1F481"], "💁", "person tipping hand"], [["U+1F481", "U+200D", "U+2642", "U+FE0F"], "💁♂️", "man tipping hand"], [["U+1F481", "U+200D", "U+2640", "U+FE0F"], "💁♀️", "woman tipping hand"], [["U+1F64B"], "🙋", "person raising hand"], [["U+1F64B", "U+200D", "U+2642", "U+FE0F"], "🙋♂️", "man raising hand"], [["U+1F64B", "U+200D", "U+2640", "U+FE0F"], "🙋♀️", "woman raising hand"], [["U+1F9CF"], "🧏", "deaf person"], [["U+1F9CF", "U+200D", "U+2642", "U+FE0F"], "🧏♂️", "deaf man"], [["U+1F9CF", "U+200D", "U+2640", "U+FE0F"], "🧏♀️", "deaf woman"], [["U+1F647"], "🙇", "person bowing"], [["U+1F647", "U+200D", "U+2642", "U+FE0F"], "🙇♂️", "man bowing"], [["U+1F647", "U+200D", "U+2640", "U+FE0F"], "🙇♀️", "woman bowing"], [["U+1F926"], "🤦", "person facepalming"], [["U+1F926", "U+200D", "U+2642", "U+FE0F"], "🤦♂️", "man facepalming"], [["U+1F926", "U+200D", "U+2640", "U+FE0F"], "🤦♀️", "woman facepalming"], [["U+1F937"], "🤷", "person shrugging"], [["U+1F937", "U+200D", "U+2642", "U+FE0F"], "🤷♂️", "man shrugging"], [["U+1F937", "U+200D", "U+2640", "U+FE0F"], "🤷♀️", "woman shrugging"]]], ["person-role", [[["U+1F9D1", "U+200D", "U+2695", "U+FE0F"], "🧑⚕️", "health worker"], [["U+1F468", "U+200D", "U+2695", "U+FE0F"], "👨⚕️", "man health worker"], [["U+1F469", "U+200D", "U+2695", "U+FE0F"], "👩⚕️", "woman health worker"], [["U+1F9D1", "U+200D", "U+1F393"], "🧑🎓", "student"], [["U+1F468", "U+200D", "U+1F393"], "👨🎓", "man student"], [["U+1F469", "U+200D", "U+1F393"], "👩🎓", "woman student"], [["U+1F9D1", "U+200D", "U+1F3EB"], "🧑🏫", "teacher"], [["U+1F468", "U+200D", "U+1F3EB"], "👨🏫", "man teacher"], [["U+1F469", "U+200D", "U+1F3EB"], "👩🏫", "woman teacher"], [["U+1F9D1", "U+200D", "U+2696", "U+FE0F"], "🧑⚖️", "judge"], [["U+1F468", "U+200D", "U+2696", "U+FE0F"], "👨⚖️", "man judge"], [["U+1F469", "U+200D", "U+2696", "U+FE0F"], "👩⚖️", "woman judge"], [["U+1F9D1", "U+200D", "U+1F33E"], "🧑🌾", "farmer"], [["U+1F468", "U+200D", "U+1F33E"], "👨🌾", "man farmer"], [["U+1F469", "U+200D", "U+1F33E"], "👩🌾", "woman farmer"], [["U+1F9D1", "U+200D", "U+1F373"], "🧑🍳", "cook"], [["U+1F468", "U+200D", "U+1F373"], "👨🍳", "man cook"], [["U+1F469", "U+200D", "U+1F373"], "👩🍳", "woman cook"], [["U+1F9D1", "U+200D", "U+1F527"], "🧑🔧", "mechanic"], [["U+1F468", "U+200D", "U+1F527"], "👨🔧", "man mechanic"], [["U+1F469", "U+200D", "U+1F527"], "👩🔧", "woman mechanic"], [["U+1F9D1", "U+200D", "U+1F3ED"], "🧑🏭", "factory worker"], [["U+1F468", "U+200D", "U+1F3ED"], "👨🏭", "man factory worker"], [["U+1F469", "U+200D", "U+1F3ED"], "👩🏭", "woman factory worker"], [["U+1F9D1", "U+200D", "U+1F4BC"], "🧑💼", "office worker"], [["U+1F468", "U+200D", "U+1F4BC"], "👨💼", "man office worker"], [["U+1F469", "U+200D", "U+1F4BC"], "👩💼", "woman office worker"], [["U+1F9D1", "U+200D", "U+1F52C"], "🧑🔬", "scientist"], [["U+1F468", "U+200D", "U+1F52C"], "👨🔬", "man scientist"], [["U+1F469", "U+200D", "U+1F52C"], "👩🔬", "woman scientist"], [["U+1F9D1", "U+200D", "U+1F4BB"], "🧑💻", "technologist"], [["U+1F468", "U+200D", "U+1F4BB"], "👨💻", "man technologist"], [["U+1F469", "U+200D", "U+1F4BB"], "👩💻", "woman technologist"], [["U+1F9D1", "U+200D", "U+1F3A4"], "🧑🎤", "singer"], [["U+1F468", "U+200D", "U+1F3A4"], "👨🎤", "man singer"], [["U+1F469", "U+200D", "U+1F3A4"], "👩🎤", "woman singer"], [["U+1F9D1", "U+200D", "U+1F3A8"], "🧑🎨", "artist"], [["U+1F468", "U+200D", "U+1F3A8"], "👨🎨", "man artist"], [["U+1F469", "U+200D", "U+1F3A8"], "👩🎨", "woman artist"], [["U+1F9D1", "U+200D", "U+2708", "U+FE0F"], "🧑✈️", "pilot"], [["U+1F468", "U+200D", "U+2708", "U+FE0F"], "👨✈️", "man pilot"], [["U+1F469", "U+200D", "U+2708", "U+FE0F"], "👩✈️", "woman pilot"], [["U+1F9D1", "U+200D", "U+1F680"], "🧑🚀", "astronaut"], [["U+1F468", "U+200D", "U+1F680"], "👨🚀", "man astronaut"], [["U+1F469", "U+200D", "U+1F680"], "👩🚀", "woman astronaut"], [["U+1F9D1", "U+200D", "U+1F692"], "🧑🚒", "firefighter"], [["U+1F468", "U+200D", "U+1F692"], "👨🚒", "man firefighter"], [["U+1F469", "U+200D", "U+1F692"], "👩🚒", "woman firefighter"], [["U+1F46E"], "👮", "police officer"], [["U+1F46E", "U+200D", "U+2642", "U+FE0F"], "👮♂️", "man police officer"], [["U+1F46E", "U+200D", "U+2640", "U+FE0F"], "👮♀️", "woman police officer"], [["U+1F575"], "🕵", "detective"], [["U+1F575", "U+FE0F", "U+200D", "U+2642", "U+FE0F"], "🕵️♂️", "man detective"], [["U+1F575", "U+FE0F", "U+200D", "U+2640", "U+FE0F"], "🕵️♀️", "woman detective"], [["U+1F482"], "💂", "guard"], [["U+1F482", "U+200D", "U+2642", "U+FE0F"], "💂♂️", "man guard"], [["U+1F482", "U+200D", "U+2640", "U+FE0F"], "💂♀️", "woman guard"], [["U+1F977"], "🥷", "⊛ ninja"], [["U+1F477"], "👷", "construction worker"], [["U+1F477", "U+200D", "U+2642", "U+FE0F"], "👷♂️", "man construction worker"], [["U+1F477", "U+200D", "U+2640", "U+FE0F"], "👷♀️", "woman construction worker"], [["U+1F934"], "🤴", "prince"], [["U+1F478"], "👸", "princess"], [["U+1F473"], "👳", "person wearing turban"], [["U+1F473", "U+200D", "U+2642", "U+FE0F"], "👳♂️", "man wearing turban"], [["U+1F473", "U+200D", "U+2640", "U+FE0F"], "👳♀️", "woman wearing turban"], [["U+1F472"], "👲", "person with skullcap"], [["U+1F9D5"], "🧕", "woman with headscarf"], [["U+1F935"], "🤵", "person in tuxedo"], [["U+1F935", "U+200D", "U+2642", "U+FE0F"], "🤵♂️", "⊛ man in tuxedo"], [["U+1F935", "U+200D", "U+2640", "U+FE0F"], "🤵♀️", "⊛ woman in tuxedo"], [["U+1F470"], "👰", "person with veil"], [["U+1F930"], "🤰", "pregnant woman"], [["U+1F931"], "🤱", "breast-feeding"]]], ["person-fantasy", [[["U+1F47C"], "👼", "baby angel"], [["U+1F385"], "🎅", "Santa Claus"], [["U+1F936"], "🤶", "Mrs. Claus"], [["U+1F9B8"], "🦸", "superhero"], [["U+1F9B8", "U+200D", "U+2642", "U+FE0F"], "🦸♂️", "man superhero"], [["U+1F9B8", "U+200D", "U+2640", "U+FE0F"], "🦸♀️", "woman superhero"], [["U+1F9B9"], "🦹", "supervillain"], [["U+1F9B9", "U+200D", "U+2642", "U+FE0F"], "🦹♂️", "man supervillain"], [["U+1F9B9", "U+200D", "U+2640", "U+FE0F"], "🦹♀️", "woman supervillain"], [["U+1F9D9"], "🧙", "mage"], [["U+1F9D9", "U+200D", "U+2642", "U+FE0F"], "🧙♂️", "man mage"], [["U+1F9D9", "U+200D", "U+2640", "U+FE0F"], "🧙♀️", "woman mage"], [["U+1F9DA"], "🧚", "fairy"], [["U+1F9DA", "U+200D", "U+2642", "U+FE0F"], "🧚♂️", "man fairy"], [["U+1F9DA", "U+200D", "U+2640", "U+FE0F"], "🧚♀️", "woman fairy"], [["U+1F9DB"], "🧛", "vampire"], [["U+1F9DB", "U+200D", "U+2642", "U+FE0F"], "🧛♂️", "man vampire"], [["U+1F9DB", "U+200D", "U+2640", "U+FE0F"], "🧛♀️", "woman vampire"], [["U+1F9DC"], "🧜", "merperson"], [["U+1F9DC", "U+200D", "U+2642", "U+FE0F"], "🧜♂️", "merman"], [["U+1F9DC", "U+200D", "U+2640", "U+FE0F"], "🧜♀️", "mermaid"], [["U+1F9DD"], "🧝", "elf"], [["U+1F9DD", "U+200D", "U+2642", "U+FE0F"], "🧝♂️", "man elf"], [["U+1F9DD", "U+200D", "U+2640", "U+FE0F"], "🧝♀️", "woman elf"], [["U+1F9DE"], "🧞", "genie"], [["U+1F9DE", "U+200D", "U+2642", "U+FE0F"], "🧞♂️", "man genie"], [["U+1F9DE", "U+200D", "U+2640", "U+FE0F"], "🧞♀️", "woman genie"], [["U+1F9DF"], "🧟", "zombie"], [["U+1F9DF", "U+200D", "U+2642", "U+FE0F"], "🧟♂️", "man zombie"], [["U+1F9DF", "U+200D", "U+2640", "U+FE0F"], "🧟♀️", "woman zombie"]]], ["person-activity", [[["U+1F486"], "💆", "person getting massage"], [["U+1F486", "U+200D", "U+2642", "U+FE0F"], "💆♂️", "man getting massage"], [["U+1F486", "U+200D", "U+2640", "U+FE0F"], "💆♀️", "woman getting massage"], [["U+1F487"], "💇", "person getting haircut"], [["U+1F487", "U+200D", "U+2642", "U+FE0F"], "💇♂️", "man getting haircut"], [["U+1F487", "U+200D", "U+2640", "U+FE0F"], "💇♀️", "woman getting haircut"], [["U+1F6B6"], "🚶", "person walking"], [["U+1F6B6", "U+200D", "U+2642", "U+FE0F"], "🚶♂️", "man walking"], [["U+1F6B6", "U+200D", "U+2640", "U+FE0F"], "🚶♀️", "woman walking"], [["U+1F9CD"], "🧍", "person standing"], [["U+1F9CD", "U+200D", "U+2642", "U+FE0F"], "🧍♂️", "man standing"], [["U+1F9CD", "U+200D", "U+2640", "U+FE0F"], "🧍♀️", "woman standing"], [["U+1F9CE"], "🧎", "person kneeling"], [["U+1F9CE", "U+200D", "U+2642", "U+FE0F"], "🧎♂️", "man kneeling"], [["U+1F9CE", "U+200D", "U+2640", "U+FE0F"], "🧎♀️", "woman kneeling"], [["U+1F9D1", "U+200D", "U+1F9AF"], "🧑🦯", "person with white cane"], [["U+1F468", "U+200D", "U+1F9AF"], "👨🦯", "man with white cane"], [["U+1F469", "U+200D", "U+1F9AF"], "👩🦯", "woman with white cane"], [["U+1F9D1", "U+200D", "U+1F9BC"], "🧑🦼", "person in motorized wheelchair"], [["U+1F468", "U+200D", "U+1F9BC"], "👨🦼", "man in motorized wheelchair"], [["U+1F469", "U+200D", "U+1F9BC"], "👩🦼", "woman in motorized wheelchair"], [["U+1F9D1", "U+200D", "U+1F9BD"], "🧑🦽", "person in manual wheelchair"], [["U+1F468", "U+200D", "U+1F9BD"], "👨🦽", "man in manual wheelchair"], [["U+1F469", "U+200D", "U+1F9BD"], "👩🦽", "woman in manual wheelchair"], [["U+1F3C3"], "🏃", "person running"], [["U+1F3C3", "U+200D", "U+2642", "U+FE0F"], "🏃♂️", "man running"], [["U+1F3C3", "U+200D", "U+2640", "U+FE0F"], "🏃♀️", "woman running"], [["U+1F483"], "💃", "woman dancing"], [["U+1F57A"], "🕺", "man dancing"], [["U+1F574"], "🕴", "person in suit levitating"], [["U+1F46F"], "👯", "people with bunny ears"], [["U+1F46F", "U+200D", "U+2642", "U+FE0F"], "👯♂️", "men with bunny ears"], [["U+1F46F", "U+200D", "U+2640", "U+FE0F"], "👯♀️", "women with bunny ears"], [["U+1F9D6"], "🧖", "person in steamy room"], [["U+1F9D6", "U+200D", "U+2642", "U+FE0F"], "🧖♂️", "man in steamy room"], [["U+1F9D6", "U+200D", "U+2640", "U+FE0F"], "🧖♀️", "woman in steamy room"], [["U+1F9D7"], "🧗", "person climbing"], [["U+1F9D7", "U+200D", "U+2642", "U+FE0F"], "🧗♂️", "man climbing"], [["U+1F9D7", "U+200D", "U+2640", "U+FE0F"], "🧗♀️", "woman climbing"]]], ["person-sport", [[["U+1F93A"], "🤺", "person fencing"], [["U+1F3C7"], "🏇", "horse racing"], [["U+26F7"], "⛷", "skier"], [["U+1F3C2"], "🏂", "snowboarder"], [["U+1F3CC"], "🏌", "person golfing"], [["U+1F3CC", "U+FE0F", "U+200D", "U+2642", "U+FE0F"], "🏌️♂️", "man golfing"], [["U+1F3CC", "U+FE0F", "U+200D", "U+2640", "U+FE0F"], "🏌️♀️", "woman golfing"], [["U+1F3C4"], "🏄", "person surfing"], [["U+1F3C4", "U+200D", "U+2642", "U+FE0F"], "🏄♂️", "man surfing"], [["U+1F3C4", "U+200D", "U+2640", "U+FE0F"], "🏄♀️", "woman surfing"], [["U+1F6A3"], "🚣", "person rowing boat"], [["U+1F6A3", "U+200D", "U+2642", "U+FE0F"], "🚣♂️", "man rowing boat"], [["U+1F6A3", "U+200D", "U+2640", "U+FE0F"], "🚣♀️", "woman rowing boat"], [["U+1F3CA"], "🏊", "person swimming"], [["U+1F3CA", "U+200D", "U+2642", "U+FE0F"], "🏊♂️", "man swimming"], [["U+1F3CA", "U+200D", "U+2640", "U+FE0F"], "🏊♀️", "woman swimming"], [["U+26F9"], "⛹", "person bouncing ball"], [["U+26F9", "U+FE0F", "U+200D", "U+2642", "U+FE0F"], "⛹️♂️", "man bouncing ball"], [["U+26F9", "U+FE0F", "U+200D", "U+2640", "U+FE0F"], "⛹️♀️", "woman bouncing ball"], [["U+1F3CB"], "🏋", "person lifting weights"], [["U+1F3CB", "U+FE0F", "U+200D", "U+2642", "U+FE0F"], "🏋️♂️", "man lifting weights"], [["U+1F3CB", "U+FE0F", "U+200D", "U+2640", "U+FE0F"], "🏋️♀️", "woman lifting weights"], [["U+1F6B4"], "🚴", "person biking"], [["U+1F6B4", "U+200D", "U+2642", "U+FE0F"], "🚴♂️", "man biking"], [["U+1F6B4", "U+200D", "U+2640", "U+FE0F"], "🚴♀️", "woman biking"], [["U+1F6B5"], "🚵", "person mountain biking"], [["U+1F6B5", "U+200D", "U+2642", "U+FE0F"], "🚵♂️", "man mountain biking"], [["U+1F6B5", "U+200D", "U+2640", "U+FE0F"], "🚵♀️", "woman mountain biking"], [["U+1F938"], "🤸", "person cartwheeling"], [["U+1F938", "U+200D", "U+2642", "U+FE0F"], "🤸♂️", "man cartwheeling"], [["U+1F938", "U+200D", "U+2640", "U+FE0F"], "🤸♀️", "woman cartwheeling"], [["U+1F93C"], "🤼", "people wrestling"], [["U+1F93C", "U+200D", "U+2642", "U+FE0F"], "🤼♂️", "men wrestling"], [["U+1F93C", "U+200D", "U+2640", "U+FE0F"], "🤼♀️", "women wrestling"], [["U+1F93D"], "🤽", "person playing water polo"], [["U+1F93D", "U+200D", "U+2642", "U+FE0F"], "🤽♂️", "man playing water polo"], [["U+1F93D", "U+200D", "U+2640", "U+FE0F"], "🤽♀️", "woman playing water polo"], [["U+1F93E"], "🤾", "person playing handball"], [["U+1F93E", "U+200D", "U+2642", "U+FE0F"], "🤾♂️", "man playing handball"], [["U+1F93E", "U+200D", "U+2640", "U+FE0F"], "🤾♀️", "woman playing handball"], [["U+1F939"], "🤹", "person juggling"], [["U+1F939", "U+200D", "U+2642", "U+FE0F"], "🤹♂️", "man juggling"], [["U+1F939", "U+200D", "U+2640", "U+FE0F"], "🤹♀️", "woman juggling"]]], ["person-resting", [[["U+1F9D8"], "🧘", "person in lotus position"], [["U+1F9D8", "U+200D", "U+2642", "U+FE0F"], "🧘♂️", "man in lotus position"], [["U+1F9D8", "U+200D", "U+2640", "U+FE0F"], "🧘♀️", "woman in lotus position"], [["U+1F6C0"], "🛀", "person taking bath"], [["U+1F6CC"], "🛌", "person in bed"]]], ["family", [[["U+1F9D1", "U+200D", "U+1F91D", "U+200D", "U+1F9D1"], "🧑🤝🧑", "people holding hands"], [["U+1F46D"], "👭", "women holding hands"], [["U+1F46B"], "👫", "woman and man holding hands"], [["U+1F46C"], "👬", "men holding hands"], [["U+1F48F"], "💏", "kiss"], [["U+1F469", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F48B", "U+200D", "U+1F468"], "👩❤️💋👨", "kiss: woman, man"], [["U+1F468", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F48B", "U+200D", "U+1F468"], "👨❤️💋👨", "kiss: man, man"], [["U+1F469", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F48B", "U+200D", "U+1F469"], "👩❤️💋👩", "kiss: woman, woman"], [["U+1F491"], "💑", "couple with heart"], [["U+1F469", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F468"], "👩❤️👨", "couple with heart: woman, man"], [["U+1F468", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F468"], "👨❤️👨", "couple with heart: man, man"], [["U+1F469", "U+200D", "U+2764", "U+FE0F", "U+200D", "U+1F469"], "👩❤️👩", "couple with heart: woman, woman"], [["U+1F46A"], "👪", "family"], [["U+1F468", "U+200D", "U+1F469", "U+200D", "U+1F466"], "👨👩👦", "family: man, woman, boy"], [["U+1F468", "U+200D", "U+1F469", "U+200D", "U+1F467"], "👨👩👧", "family: man, woman, girl"], [["U+1F468", "U+200D", "U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F466"], "👨👩👧👦", "family: man, woman, girl, boy"], [["U+1F468", "U+200D", "U+1F469", "U+200D", "U+1F466", "U+200D", "U+1F466"], "👨👩👦👦", "family: man, woman, boy, boy"], [["U+1F468", "U+200D", "U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F467"], "👨👩👧👧", "family: man, woman, girl, girl"], [["U+1F468", "U+200D", "U+1F468", "U+200D", "U+1F466"], "👨👨👦", "family: man, man, boy"], [["U+1F468", "U+200D", "U+1F468", "U+200D", "U+1F467"], "👨👨👧", "family: man, man, girl"], [["U+1F468", "U+200D", "U+1F468", "U+200D", "U+1F467", "U+200D", "U+1F466"], "👨👨👧👦", "family: man, man, girl, boy"], [["U+1F468", "U+200D", "U+1F468", "U+200D", "U+1F466", "U+200D", "U+1F466"], "👨👨👦👦", "family: man, man, boy, boy"], [["U+1F468", "U+200D", "U+1F468", "U+200D", "U+1F467", "U+200D", "U+1F467"], "👨👨👧👧", "family: man, man, girl, girl"], [["U+1F469", "U+200D", "U+1F469", "U+200D", "U+1F466"], "👩👩👦", "family: woman, woman, boy"], [["U+1F469", "U+200D", "U+1F469", "U+200D", "U+1F467"], "👩👩👧", "family: woman, woman, girl"], [["U+1F469", "U+200D", "U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F466"], "👩👩👧👦", "family: woman, woman, girl, boy"], [["U+1F469", "U+200D", "U+1F469", "U+200D", "U+1F466", "U+200D", "U+1F466"], "👩👩👦👦", "family: woman, woman, boy, boy"], [["U+1F469", "U+200D", "U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F467"], "👩👩👧👧", "family: woman, woman, girl, girl"], [["U+1F468", "U+200D", "U+1F466"], "👨👦", "family: man, boy"], [["U+1F468", "U+200D", "U+1F466", "U+200D", "U+1F466"], "👨👦👦", "family: man, boy, boy"], [["U+1F468", "U+200D", "U+1F467"], "👨👧", "family: man, girl"], [["U+1F468", "U+200D", "U+1F467", "U+200D", "U+1F466"], "👨👧👦", "family: man, girl, boy"], [["U+1F468", "U+200D", "U+1F467", "U+200D", "U+1F467"], "👨👧👧", "family: man, girl, girl"], [["U+1F469", "U+200D", "U+1F466"], "👩👦", "family: woman, boy"], [["U+1F469", "U+200D", "U+1F466", "U+200D", "U+1F466"], "👩👦👦", "family: woman, boy, boy"], [["U+1F469", "U+200D", "U+1F467"], "👩👧", "family: woman, girl"], [["U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F466"], "👩👧👦", "family: woman, girl, boy"], [["U+1F469", "U+200D", "U+1F467", "U+200D", "U+1F467"], "👩👧👧", "family: woman, girl, girl"]]], ["person-symbol", [[["U+1F5E3"], "🗣", "speaking head"], [["U+1F464"], "👤", "bust in silhouette"], [["U+1F465"], "👥", "busts in silhouette"], [["U+1FAC2"], "🫂", "⊛ people hugging"], [["U+1F463"], "👣", "footprints"]]]]], ["Component", [["hair-style", [[["U+1F9B0"], "🦰", "red hair"], [["U+1F9B1"], "🦱", "curly hair"], [["U+1F9B3"], "🦳", "white hair"], [["U+1F9B2"], "🦲", "bald"]]]]], ["Animals & Nature", [["animal-mammal", [[["U+1F435"], "🐵", "monkey face"], [["U+1F412"], "🐒", "monkey"], [["U+1F98D"], "🦍", "gorilla"], [["U+1F9A7"], "🦧", "orangutan"], [["U+1F436"], "🐶", "dog face"], [["U+1F415"], "🐕", "dog"], [["U+1F9AE"], "🦮", "guide dog"], [["U+1F415", "U+200D", "U+1F9BA"], "🐕🦺", "service dog"], [["U+1F429"], "🐩", "poodle"], [["U+1F43A"], "🐺", "wolf"], [["U+1F98A"], "🦊", "fox"], [["U+1F99D"], "🦝", "raccoon"], [["U+1F431"], "🐱", "cat face"], [["U+1F408"], "🐈", "cat"], [["U+1F981"], "🦁", "lion"], [["U+1F42F"], "🐯", "tiger face"], [["U+1F405"], "🐅", "tiger"], [["U+1F406"], "🐆", "leopard"], [["U+1F434"], "🐴", "horse face"], [["U+1F40E"], "🐎", "horse"], [["U+1F984"], "🦄", "unicorn"], [["U+1F993"], "🦓", "zebra"], [["U+1F98C"], "🦌", "deer"], [["U+1F42E"], "🐮", "cow face"], [["U+1F402"], "🐂", "ox"], [["U+1F403"], "🐃", "water buffalo"], [["U+1F404"], "🐄", "cow"], [["U+1F437"], "🐷", "pig face"], [["U+1F416"], "🐖", "pig"], [["U+1F417"], "🐗", "boar"], [["U+1F43D"], "🐽", "pig nose"], [["U+1F40F"], "🐏", "ram"], [["U+1F411"], "🐑", "ewe"], [["U+1F410"], "🐐", "goat"], [["U+1F42A"], "🐪", "camel"], [["U+1F42B"], "🐫", "two-hump camel"], [["U+1F999"], "🦙", "llama"], [["U+1F992"], "🦒", "giraffe"], [["U+1F418"], "🐘", "elephant"], [["U+1F98F"], "🦏", "rhinoceros"], [["U+1F99B"], "🦛", "hippopotamus"], [["U+1F42D"], "🐭", "mouse face"], [["U+1F401"], "🐁", "mouse"], [["U+1F400"], "🐀", "rat"], [["U+1F439"], "🐹", "hamster"], [["U+1F430"], "🐰", "rabbit face"], [["U+1F407"], "🐇", "rabbit"], [["U+1F43F"], "🐿", "chipmunk"], [["U+1F994"], "🦔", "hedgehog"], [["U+1F987"], "🦇", "bat"], [["U+1F43B"], "🐻", "bear"], [["U+1F43B", "U+200D", "U+2744", "U+FE0F"], "🐻❄️", "⊛ polar bear"], [["U+1F428"], "🐨", "koala"], [["U+1F43C"], "🐼", "panda"], [["U+1F9A5"], "🦥", "sloth"], [["U+1F9A6"], "🦦", "otter"], [["U+1F9A8"], "🦨", "skunk"], [["U+1F998"], "🦘", "kangaroo"], [["U+1F9A1"], "🦡", "badger"], [["U+1F43E"], "🐾", "paw prints"]]], ["animal-bird", [[["U+1F983"], "🦃", "turkey"], [["U+1F414"], "🐔", "chicken"], [["U+1F413"], "🐓", "rooster"], [["U+1F423"], "🐣", "hatching chick"], [["U+1F424"], "🐤", "baby chick"], [["U+1F425"], "🐥", "front-facing baby chick"], [["U+1F426"], "🐦", "bird"], [["U+1F427"], "🐧", "penguin"], [["U+1F54A"], "🕊", "dove"], [["U+1F985"], "🦅", "eagle"], [["U+1F986"], "🦆", "duck"], [["U+1F9A2"], "🦢", "swan"], [["U+1F989"], "🦉", "owl"], [["U+1FAB6"], "🪶", "⊛ feather"], [["U+1F9A9"], "🦩", "flamingo"], [["U+1F99A"], "🦚", "peacock"], [["U+1F99C"], "🦜", "parrot"]]], ["animal-amphibian", [[["U+1F438"], "🐸", "frog"]]], ["animal-reptile", [[["U+1F40A"], "🐊", "crocodile"], [["U+1F422"], "🐢", "turtle"], [["U+1F98E"], "🦎", "lizard"], [["U+1F40D"], "🐍", "snake"], [["U+1F432"], "🐲", "dragon face"], [["U+1F409"], "🐉", "dragon"], [["U+1F995"], "🦕", "sauropod"], [["U+1F996"], "🦖", "T-Rex"]]], ["animal-marine", [[["U+1F433"], "🐳", "spouting whale"], [["U+1F40B"], "🐋", "whale"], [["U+1F42C"], "🐬", "dolphin"], [["U+1F41F"], "🐟", "fish"], [["U+1F420"], "🐠", "tropical fish"], [["U+1F421"], "🐡", "blowfish"], [["U+1F988"], "🦈", "shark"], [["U+1F419"], "🐙", "octopus"], [["U+1F41A"], "🐚", "spiral shell"]]], ["animal-bug", [[["U+1F40C"], "🐌", "snail"], [["U+1F98B"], "🦋", "butterfly"], [["U+1F41B"], "🐛", "bug"], [["U+1F41C"], "🐜", "ant"], [["U+1F41D"], "🐝", "honeybee"], [["U+1F41E"], "🐞", "lady beetle"], [["U+1F997"], "🦗", "cricket"], [["U+1F577"], "🕷", "spider"], [["U+1F578"], "🕸", "spider web"], [["U+1F982"], "🦂", "scorpion"], [["U+1F99F"], "🦟", "mosquito"], [["U+1F9A0"], "🦠", "microbe"]]], ["plant-flower", [[["U+1F490"], "💐", "bouquet"], [["U+1F338"], "🌸", "cherry blossom"], [["U+1F4AE"], "💮", "white flower"], [["U+1F3F5"], "🏵", "rosette"], [["U+1F339"], "🌹", "rose"], [["U+1F940"], "🥀", "wilted flower"], [["U+1F33A"], "🌺", "hibiscus"], [["U+1F33B"], "🌻", "sunflower"], [["U+1F33C"], "🌼", "blossom"], [["U+1F337"], "🌷", "tulip"]]], ["plant-other", [[["U+1F331"], "🌱", "seedling"], [["U+1FAB4"], "🪴", "⊛ potted plant"], [["U+1F332"], "🌲", "evergreen tree"], [["U+1F333"], "🌳", "deciduous tree"], [["U+1F334"], "🌴", "palm tree"], [["U+1F335"], "🌵", "cactus"], [["U+1F33E"], "🌾", "sheaf of rice"], [["U+1F33F"], "🌿", "herb"], [["U+2618"], "☘", "shamrock"], [["U+1F340"], "🍀", "four leaf clover"], [["U+1F341"], "🍁", "maple leaf"], [["U+1F342"], "🍂", "fallen leaf"], [["U+1F343"], "🍃", "leaf fluttering in wind"]]]]], ["Food & Drink", [["food-fruit", [[["U+1F347"], "🍇", "grapes"], [["U+1F348"], "🍈", "melon"], [["U+1F349"], "🍉", "watermelon"], [["U+1F34A"], "🍊", "tangerine"], [["U+1F34B"], "🍋", "lemon"], [["U+1F34C"], "🍌", "banana"], [["U+1F34D"], "🍍", "pineapple"], [["U+1F96D"], "🥭", "mango"], [["U+1F34E"], "🍎", "red apple"], [["U+1F34F"], "🍏", "green apple"], [["U+1F350"], "🍐", "pear"], [["U+1F351"], "🍑", "peach"], [["U+1F352"], "🍒", "cherries"], [["U+1F353"], "🍓", "strawberry"], [["U+1FAD0"], "🫐", "⊛ blueberries"], [["U+1F95D"], "🥝", "kiwi fruit"], [["U+1F345"], "🍅", "tomato"], [["U+1FAD2"], "🫒", "⊛ olive"], [["U+1F965"], "🥥", "coconut"]]], ["food-vegetable", [[["U+1F951"], "🥑", "avocado"], [["U+1F346"], "🍆", "eggplant"], [["U+1F954"], "🥔", "potato"], [["U+1F955"], "🥕", "carrot"], [["U+1F33D"], "🌽", "ear of corn"], [["U+1F336"], "🌶", "hot pepper"], [["U+1F952"], "🥒", "cucumber"], [["U+1F96C"], "🥬", "leafy green"], [["U+1F966"], "🥦", "broccoli"], [["U+1F9C4"], "🧄", "garlic"], [["U+1F9C5"], "🧅", "onion"], [["U+1F344"], "🍄", "mushroom"], [["U+1F95C"], "🥜", "peanuts"], [["U+1F330"], "🌰", "chestnut"]]], ["food-prepared", [[["U+1F35E"], "🍞", "bread"], [["U+1F950"], "🥐", "croissant"], [["U+1F956"], "🥖", "baguette bread"], [["U+1FAD3"], "🫓", "⊛ flatbread"], [["U+1F968"], "🥨", "pretzel"], [["U+1F96F"], "🥯", "bagel"], [["U+1F95E"], "🥞", "pancakes"], [["U+1F9C7"], "🧇", "waffle"], [["U+1F9C0"], "🧀", "cheese wedge"], [["U+1F356"], "🍖", "meat on bone"], [["U+1F357"], "🍗", "poultry leg"], [["U+1F969"], "🥩", "cut of meat"], [["U+1F953"], "🥓", "bacon"], [["U+1F354"], "🍔", "hamburger"], [["U+1F35F"], "🍟", "french fries"], [["U+1F355"], "🍕", "pizza"], [["U+1F32D"], "🌭", "hot dog"], [["U+1F96A"], "🥪", "sandwich"], [["U+1F32E"], "🌮", "taco"], [["U+1F32F"], "🌯", "burrito"], [["U+1FAD4"], "🫔", "⊛ tamale"], [["U+1F959"], "🥙", "stuffed flatbread"], [["U+1F9C6"], "🧆", "falafel"], [["U+1F95A"], "🥚", "egg"], [["U+1F373"], "🍳", "cooking"], [["U+1F958"], "🥘", "shallow pan of food"], [["U+1F372"], "🍲", "pot of food"], [["U+1FAD5"], "🫕", "⊛ fondue"], [["U+1F963"], "🥣", "bowl with spoon"], [["U+1F957"], "🥗", "green salad"], [["U+1F37F"], "🍿", "popcorn"], [["U+1F9C8"], "🧈", "butter"], [["U+1F9C2"], "🧂", "salt"], [["U+1F96B"], "🥫", "canned food"]]], ["food-asian", [[["U+1F371"], "🍱", "bento box"], [["U+1F358"], "🍘", "rice cracker"], [["U+1F359"], "🍙", "rice ball"], [["U+1F35A"], "🍚", "cooked rice"], [["U+1F35B"], "🍛", "curry rice"], [["U+1F35C"], "🍜", "steaming bowl"], [["U+1F35D"], "🍝", "spaghetti"], [["U+1F360"], "🍠", "roasted sweet potato"], [["U+1F362"], "🍢", "oden"], [["U+1F363"], "🍣", "sushi"], [["U+1F364"], "🍤", "fried shrimp"], [["U+1F365"], "🍥", "fish cake with swirl"], [["U+1F96E"], "🥮", "moon cake"], [["U+1F361"], "🍡", "dango"], [["U+1F95F"], "🥟", "dumpling"], [["U+1F960"], "🥠", "fortune cookie"], [["U+1F961"], "🥡", "takeout box"]]], ["food-marine", [[["U+1F980"], "🦀", "crab"], [["U+1F99E"], "🦞", "lobster"], [["U+1F990"], "🦐", "shrimp"], [["U+1F991"], "🦑", "squid"], [["U+1F9AA"], "🦪", "oyster"]]], ["food-sweet", [[["U+1F366"], "🍦", "soft ice cream"], [["U+1F367"], "🍧", "shaved ice"], [["U+1F368"], "🍨", "ice cream"], [["U+1F369"], "🍩", "doughnut"], [["U+1F36A"], "🍪", "cookie"], [["U+1F382"], "🎂", "birthday cake"], [["U+1F370"], "🍰", "shortcake"], [["U+1F9C1"], "🧁", "cupcake"], [["U+1F967"], "🥧", "pie"], [["U+1F36B"], "🍫", "chocolate bar"], [["U+1F36C"], "🍬", "candy"], [["U+1F36D"], "🍭", "lollipop"], [["U+1F36E"], "🍮", "custard"], [["U+1F36F"], "🍯", "honey pot"]]], ["drink", [[["U+1F37C"], "🍼", "baby bottle"], [["U+1F95B"], "🥛", "glass of milk"], [["U+2615"], "☕", "hot beverage"], [["U+1F375"], "🍵", "teacup without handle"], [["U+1F376"], "🍶", "sake"], [["U+1F37E"], "🍾", "bottle with popping cork"], [["U+1F377"], "🍷", "wine glass"], [["U+1F378"], "🍸", "cocktail glass"], [["U+1F379"], "🍹", "tropical drink"], [["U+1F37A"], "🍺", "beer mug"], [["U+1F37B"], "🍻", "clinking beer mugs"], [["U+1F942"], "🥂", "clinking glasses"], [["U+1F943"], "🥃", "tumbler glass"], [["U+1F964"], "🥤", "cup with straw"], [["U+1F9CB"], "🧋", "⊛ bubble tea"], [["U+1F9C3"], "🧃", "beverage box"], [["U+1F9C9"], "🧉", "mate"], [["U+1F9CA"], "🧊", "ice"]]], ["dishware", [[["U+1F962"], "🥢", "chopsticks"], [["U+1F37D"], "🍽", "fork and knife with plate"], [["U+1F374"], "🍴", "fork and knife"], [["U+1F944"], "🥄", "spoon"], [["U+1F52A"], "🔪", "kitchen knife"], [["U+1F3FA"], "🏺", "amphora"]]]]], ["Travel & Places", [["place-map", [[["U+1F30D"], "🌍", "globe showing Europe-Africa"], [["U+1F30E"], "🌎", "globe showing Americas"], [["U+1F30F"], "🌏", "globe showing Asia-Australia"], [["U+1F310"], "🌐", "globe with meridians"], [["U+1F5FA"], "🗺", "world map"], [["U+1F5FE"], "🗾", "map of Japan"], [["U+1F9ED"], "🧭", "compass"]]], ["place-geographic", [[["U+1F3D4"], "🏔", "snow-capped mountain"], [["U+26F0"], "⛰", "mountain"], [["U+1F30B"], "🌋", "volcano"], [["U+1F5FB"], "🗻", "mount fuji"], [["U+1F3D5"], "🏕", "camping"], [["U+1F3D6"], "🏖", "beach with umbrella"], [["U+1F3DC"], "🏜", "desert"], [["U+1F3DD"], "🏝", "desert island"], [["U+1F3DE"], "🏞", "national park"]]], ["place-building", [[["U+1F3DF"], "🏟", "stadium"], [["U+1F3DB"], "🏛", "classical building"], [["U+1F3D7"], "🏗", "building construction"], [["U+1F9F1"], "🧱", "brick"], [["U+1FAA8"], "🪨", "⊛ rock"], [["U+1FAB5"], "🪵", "⊛ wood"], [["U+1F3D8"], "🏘", "houses"], [["U+1F3DA"], "🏚", "derelict house"], [["U+1F3E0"], "🏠", "house"], [["U+1F3E1"], "🏡", "house with garden"], [["U+1F3E2"], "🏢", "office building"], [["U+1F3E3"], "🏣", "Japanese post office"], [["U+1F3E4"], "🏤", "post office"], [["U+1F3E5"], "🏥", "hospital"], [["U+1F3E6"], "🏦", "bank"], [["U+1F3E8"], "🏨", "hotel"], [["U+1F3E9"], "🏩", "love hotel"], [["U+1F3EA"], "🏪", "convenience store"], [["U+1F3EB"], "🏫", "school"], [["U+1F3EC"], "🏬", "department store"], [["U+1F3ED"], "🏭", "factory"], [["U+1F3EF"], "🏯", "Japanese castle"], [["U+1F3F0"], "🏰", "castle"], [["U+1F492"], "💒", "wedding"], [["U+1F5FC"], "🗼", "Tokyo tower"], [["U+1F5FD"], "🗽", "Statue of Liberty"]]], ["place-religious", [[["U+26EA"], "⛪", "church"], [["U+1F54C"], "🕌", "mosque"], [["U+1F6D5"], "🛕", "hindu temple"], [["U+1F54D"], "🕍", "synagogue"], [["U+26E9"], "⛩", "shinto shrine"], [["U+1F54B"], "🕋", "kaaba"]]], ["place-other", [[["U+26F2"], "⛲", "fountain"], [["U+26FA"], "⛺", "tent"], [["U+1F301"], "🌁", "foggy"], [["U+1F303"], "🌃", "night with stars"], [["U+1F3D9"], "🏙", "cityscape"], [["U+1F304"], "🌄", "sunrise over mountains"], [["U+1F305"], "🌅", "sunrise"], [["U+1F306"], "🌆", "cityscape at dusk"], [["U+1F307"], "🌇", "sunset"], [["U+1F309"], "🌉", "bridge at night"], [["U+2668"], "♨", "hot springs"], [["U+1F3A0"], "🎠", "carousel horse"], [["U+1F3A1"], "🎡", "ferris wheel"], [["U+1F3A2"], "🎢", "roller coaster"], [["U+1F488"], "💈", "barber pole"], [["U+1F3AA"], "🎪", "circus tent"]]], ["transport-ground", [[["U+1F682"], "🚂", "locomotive"], [["U+1F683"], "🚃", "railway car"], [["U+1F684"], "🚄", "high-speed train"], [["U+1F685"], "🚅", "bullet train"], [["U+1F686"], "🚆", "train"], [["U+1F687"], "🚇", "metro"], [["U+1F688"], "🚈", "light rail"], [["U+1F689"], "🚉", "station"], [["U+1F68A"], "🚊", "tram"], [["U+1F69D"], "🚝", "monorail"], [["U+1F69E"], "🚞", "mountain railway"], [["U+1F68B"], "🚋", "tram car"], [["U+1F68C"], "🚌", "bus"], [["U+1F68D"], "🚍", "oncoming bus"], [["U+1F68E"], "🚎", "trolleybus"], [["U+1F690"], "🚐", "minibus"], [["U+1F691"], "🚑", "ambulance"], [["U+1F692"], "🚒", "fire engine"], [["U+1F693"], "🚓", "police car"], [["U+1F694"], "🚔", "oncoming police car"], [["U+1F695"], "🚕", "taxi"], [["U+1F696"], "🚖", "oncoming taxi"], [["U+1F697"], "🚗", "automobile"], [["U+1F698"], "🚘", "oncoming automobile"], [["U+1F699"], "🚙", "sport utility vehicle"], [["U+1F69A"], "🚚", "delivery truck"], [["U+1F69B"], "🚛", "articulated lorry"], [["U+1F69C"], "🚜", "tractor"], [["U+1F3CE"], "🏎", "racing car"], [["U+1F3CD"], "🏍", "motorcycle"], [["U+1F6F5"], "🛵", "motor scooter"], [["U+1F9BD"], "🦽", "manual wheelchair"], [["U+1F9BC"], "🦼", "motorized wheelchair"], [["U+1F6FA"], "🛺", "auto rickshaw"], [["U+1F6B2"], "🚲", "bicycle"], [["U+1F6F4"], "🛴", "kick scooter"], [["U+1F6F9"], "🛹", "skateboard"], [["U+1F6FC"], "🛼", "⊛ roller skate"], [["U+1F68F"], "🚏", "bus stop"], [["U+1F6E3"], "🛣", "motorway"], [["U+1F6E4"], "🛤", "railway track"], [["U+1F6E2"], "🛢", "oil drum"], [["U+26FD"], "⛽", "fuel pump"], [["U+1F6A8"], "🚨", "police car light"], [["U+1F6A5"], "🚥", "horizontal traffic light"], [["U+1F6A6"], "🚦", "vertical traffic light"], [["U+1F6D1"], "🛑", "stop sign"], [["U+1F6A7"], "🚧", "construction"]]], ["transport-water", [[["U+2693"], "⚓", "anchor"], [["U+26F5"], "⛵", "sailboat"], [["U+1F6F6"], "🛶", "canoe"], [["U+1F6A4"], "🚤", "speedboat"], [["U+1F6F3"], "🛳", "passenger ship"], [["U+26F4"], "⛴", "ferry"], [["U+1F6E5"], "🛥", "motor boat"], [["U+1F6A2"], "🚢", "ship"]]], ["transport-air", [[["U+2708"], "✈", "airplane"], [["U+1F6E9"], "🛩", "small airplane"], [["U+1F6EB"], "🛫", "airplane departure"], [["U+1F6EC"], "🛬", "airplane arrival"], [["U+1FA82"], "🪂", "parachute"], [["U+1F4BA"], "💺", "seat"], [["U+1F681"], "🚁", "helicopter"], [["U+1F69F"], "🚟", "suspension railway"], [["U+1F6A0"], "🚠", "mountain cableway"], [["U+1F6A1"], "🚡", "aerial tramway"], [["U+1F6F0"], "🛰", "satellite"], [["U+1F680"], "🚀", "rocket"], [["U+1F6F8"], "🛸", "flying saucer"]]], ["hotel", [[["U+1F6CE"], "🛎", "bellhop bell"], [["U+1F9F3"], "🧳", "luggage"]]], ["time", [[["U+231B"], "⌛", "hourglass done"], [["U+23F3"], "⏳", "hourglass not done"], [["U+231A"], "⌚", "watch"], [["U+23F0"], "⏰", "alarm clock"], [["U+23F1"], "⏱", "stopwatch"], [["U+23F2"], "⏲", "timer clock"], [["U+1F570"], "🕰", "mantelpiece clock"], [["U+1F55B"], "🕛", "twelve o’clock"], [["U+1F567"], "🕧", "twelve-thirty"], [["U+1F550"], "🕐", "one o’clock"], [["U+1F55C"], "🕜", "one-thirty"], [["U+1F551"], "🕑", "two o’clock"], [["U+1F55D"], "🕝", "two-thirty"], [["U+1F552"], "🕒", "three o’clock"], [["U+1F55E"], "🕞", "three-thirty"], [["U+1F553"], "🕓", "four o’clock"], [["U+1F55F"], "🕟", "four-thirty"], [["U+1F554"], "🕔", "five o’clock"], [["U+1F560"], "🕠", "five-thirty"], [["U+1F555"], "🕕", "six o’clock"], [["U+1F561"], "🕡", "six-thirty"], [["U+1F556"], "🕖", "seven o’clock"], [["U+1F562"], "🕢", "seven-thirty"], [["U+1F557"], "🕗", "eight o’clock"], [["U+1F563"], "🕣", "eight-thirty"], [["U+1F558"], "🕘", "nine o’clock"], [["U+1F564"], "🕤", "nine-thirty"], [["U+1F559"], "🕙", "ten o’clock"], [["U+1F565"], "🕥", "ten-thirty"], [["U+1F55A"], "🕚", "eleven o’clock"], [["U+1F566"], "🕦", "eleven-thirty"]]], ["sky & weather", [[["U+1F311"], "🌑", "new moon"], [["U+1F312"], "🌒", "waxing crescent moon"], [["U+1F313"], "🌓", "first quarter moon"], [["U+1F314"], "🌔", "waxing gibbous moon"], [["U+1F315"], "🌕", "full moon"], [["U+1F316"], "🌖", "waning gibbous moon"], [["U+1F317"], "🌗", "last quarter moon"], [["U+1F318"], "🌘", "waning crescent moon"], [["U+1F319"], "🌙", "crescent moon"], [["U+1F31A"], "🌚", "new moon face"], [["U+1F31B"], "🌛", "first quarter moon face"], [["U+1F31C"], "🌜", "last quarter moon face"], [["U+1F321"], "🌡", "thermometer"], [["U+2600"], "☀", "sun"], [["U+1F31D"], "🌝", "full moon face"], [["U+1F31E"], "🌞", "sun with face"], [["U+1FA90"], "🪐", "ringed planet"], [["U+2B50"], "⭐", "star"], [["U+1F31F"], "🌟", "glowing star"], [["U+1F320"], "🌠", "shooting star"], [["U+1F30C"], "🌌", "milky way"], [["U+2601"], "☁", "cloud"], [["U+26C5"], "⛅", "sun behind cloud"], [["U+26C8"], "⛈", "cloud with lightning and rain"], [["U+1F324"], "🌤", "sun behind small cloud"], [["U+1F325"], "🌥", "sun behind large cloud"], [["U+1F326"], "🌦", "sun behind rain cloud"], [["U+1F327"], "🌧", "cloud with rain"], [["U+1F328"], "🌨", "cloud with snow"], [["U+1F329"], "🌩", "cloud with lightning"], [["U+1F32A"], "🌪", "tornado"], [["U+1F32B"], "🌫", "fog"], [["U+1F32C"], "🌬", "wind face"], [["U+1F300"], "🌀", "cyclone"], [["U+1F308"], "🌈", "rainbow"], [["U+1F302"], "🌂", "closed umbrella"], [["U+2602"], "☂", "umbrella"], [["U+2614"], "☔", "umbrella with rain drops"], [["U+26F1"], "⛱", "umbrella on ground"], [["U+26A1"], "⚡", "high voltage"], [["U+2744"], "❄", "snowflake"], [["U+2603"], "☃", "snowman"], [["U+26C4"], "⛄", "snowman without snow"], [["U+2604"], "☄", "comet"], [["U+1F525"], "🔥", "fire"], [["U+1F4A7"], "💧", "droplet"], [["U+1F30A"], "🌊", "water wave"]]]]], ["Activities", [["event", [[["U+1F383"], "🎃", "jack-o-lantern"], [["U+1F384"], "🎄", "Christmas tree"], [["U+1F386"], "🎆", "fireworks"], [["U+1F387"], "🎇", "sparkler"], [["U+1F9E8"], "🧨", "firecracker"], [["U+2728"], "✨", "sparkles"], [["U+1F388"], "🎈", "balloon"], [["U+1F389"], "🎉", "party popper"], [["U+1F38A"], "🎊", "confetti ball"], [["U+1F38B"], "🎋", "tanabata tree"], [["U+1F38D"], "🎍", "pine decoration"], [["U+1F38E"], "🎎", "Japanese dolls"], [["U+1F38F"], "🎏", "carp streamer"], [["U+1F390"], "🎐", "wind chime"], [["U+1F391"], "🎑", "moon viewing ceremony"], [["U+1F9E7"], "🧧", "red envelope"], [["U+1F380"], "🎀", "ribbon"], [["U+1F381"], "🎁", "wrapped gift"], [["U+1F397"], "🎗", "reminder ribbon"], [["U+1F39F"], "🎟", "admission tickets"], [["U+1F3AB"], "🎫", "ticket"]]], ["award-medal", [[["U+1F396"], "🎖", "military medal"], [["U+1F3C6"], "🏆", "trophy"], [["U+1F3C5"], "🏅", "sports medal"], [["U+1F947"], "🥇", "1st place medal"], [["U+1F948"], "🥈", "2nd place medal"], [["U+1F949"], "🥉", "3rd place medal"]]], ["sport", [[["U+26BD"], "⚽", "soccer ball"], [["U+26BE"], "⚾", "baseball"], [["U+1F94E"], "🥎", "softball"], [["U+1F3C0"], "🏀", "basketball"], [["U+1F3D0"], "🏐", "volleyball"], [["U+1F3C8"], "🏈", "american football"], [["U+1F3C9"], "🏉", "rugby football"], [["U+1F3BE"], "🎾", "tennis"], [["U+1F94F"], "🥏", "flying disc"], [["U+1F3B3"], "🎳", "bowling"], [["U+1F3CF"], "🏏", "cricket game"], [["U+1F3D1"], "🏑", "field hockey"], [["U+1F3D2"], "🏒", "ice hockey"], [["U+1F94D"], "🥍", "lacrosse"], [["U+1F3D3"], "🏓", "ping pong"], [["U+1F3F8"], "🏸", "badminton"], [["U+1F94A"], "🥊", "boxing glove"], [["U+1F94B"], "🥋", "martial arts uniform"], [["U+1F945"], "🥅", "goal net"], [["U+26F3"], "⛳", "flag in hole"], [["U+26F8"], "⛸", "ice skate"], [["U+1F3A3"], "🎣", "fishing pole"], [["U+1F93F"], "🤿", "diving mask"], [["U+1F3BD"], "🎽", "running shirt"], [["U+1F3BF"], "🎿", "skis"], [["U+1F6F7"], "🛷", "sled"], [["U+1F94C"], "🥌", "curling stone"]]], ["game", [[["U+1F3AF"], "🎯", "direct hit"], [["U+1FA80"], "🪀", "yo-yo"], [["U+1FA81"], "🪁", "kite"], [["U+1F3B1"], "🎱", "pool 8 ball"], [["U+1F52E"], "🔮", "crystal ball"], [["U+1FA84"], "🪄", "⊛ magic wand"], [["U+1F9FF"], "🧿", "nazar amulet"], [["U+1F3AE"], "🎮", "video game"], [["U+1F579"], "🕹", "joystick"], [["U+1F3B0"], "🎰", "slot machine"], [["U+1F3B2"], "🎲", "game die"], [["U+1F9E9"], "🧩", "puzzle piece"], [["U+1F9F8"], "🧸", "teddy bear"], [["U+1FA85"], "🪅", "⊛ piñata"], [["U+1FA86"], "🪆", "⊛ nesting dolls"], [["U+2660"], "♠", "spade suit"], [["U+2665"], "♥", "heart suit"], [["U+2666"], "♦", "diamond suit"], [["U+2663"], "♣", "club suit"], [["U+265F"], "♟", "chess pawn"], [["U+1F0CF"], "🃏", "joker"], [["U+1F004"], "🀄", "mahjong red dragon"], [["U+1F3B4"], "🎴", "flower playing cards"]]], ["arts & crafts", [[["U+1F3AD"], "🎭", "performing arts"], [["U+1F5BC"], "🖼", "framed picture"], [["U+1F3A8"], "🎨", "artist palette"], [["U+1F9F5"], "🧵", "thread"], [["U+1FAA1"], "🪡", "⊛ sewing needle"], [["U+1F9F6"], "🧶", "yarn"], [["U+1FAA2"], "🪢", "⊛ knot"]]]]], ["Objects", [["clothing", [[["U+1F453"], "👓", "glasses"], [["U+1F576"], "🕶", "sunglasses"], [["U+1F97D"], "🥽", "goggles"], [["U+1F97C"], "🥼", "lab coat"], [["U+1F9BA"], "🦺", "safety vest"], [["U+1F454"], "👔", "necktie"], [["U+1F455"], "👕", "t-shirt"], [["U+1F456"], "👖", "jeans"], [["U+1F9E3"], "🧣", "scarf"], [["U+1F9E4"], "🧤", "gloves"], [["U+1F9E5"], "🧥", "coat"], [["U+1F9E6"], "🧦", "socks"], [["U+1F457"], "👗", "dress"], [["U+1F458"], "👘", "kimono"], [["U+1F97B"], "🥻", "sari"], [["U+1FA71"], "🩱", "one-piece swimsuit"], [["U+1FA72"], "🩲", "briefs"], [["U+1FA73"], "🩳", "shorts"], [["U+1F459"], "👙", "bikini"], [["U+1F45A"], "👚", "woman’s clothes"], [["U+1F45B"], "👛", "purse"], [["U+1F45C"], "👜", "handbag"], [["U+1F45D"], "👝", "clutch bag"], [["U+1F6CD"], "🛍", "shopping bags"], [["U+1F392"], "🎒", "backpack"], [["U+1FA74"], "🩴", "⊛ thong sandal"], [["U+1F45E"], "👞", "man’s shoe"], [["U+1F45F"], "👟", "running shoe"], [["U+1F97E"], "🥾", "hiking boot"], [["U+1F97F"], "🥿", "flat shoe"], [["U+1F460"], "👠", "high-heeled shoe"], [["U+1F461"], "👡", "woman’s sandal"], [["U+1FA70"], "🩰", "ballet shoes"], [["U+1F462"], "👢", "woman’s boot"], [["U+1F451"], "👑", "crown"], [["U+1F452"], "👒", "woman’s hat"], [["U+1F3A9"], "🎩", "top hat"], [["U+1F393"], "🎓", "graduation cap"], [["U+1F9E2"], "🧢", "billed cap"], [["U+1FA96"], "🪖", "⊛ military helmet"], [["U+26D1"], "⛑", "rescue worker’s helmet"], [["U+1F4FF"], "📿", "prayer beads"], [["U+1F484"], "💄", "lipstick"], [["U+1F48D"], "💍", "ring"], [["U+1F48E"], "💎", "gem stone"]]], ["sound", [[["U+1F507"], "🔇", "muted speaker"], [["U+1F508"], "🔈", "speaker low volume"], [["U+1F509"], "🔉", "speaker medium volume"], [["U+1F50A"], "🔊", "speaker high volume"], [["U+1F4E2"], "📢", "loudspeaker"], [["U+1F4E3"], "📣", "megaphone"], [["U+1F4EF"], "📯", "postal horn"], [["U+1F514"], "🔔", "bell"], [["U+1F515"], "🔕", "bell with slash"]]], ["music", [[["U+1F3BC"], "🎼", "musical score"], [["U+1F3B5"], "🎵", "musical note"], [["U+1F3B6"], "🎶", "musical notes"], [["U+1F399"], "🎙", "studio microphone"], [["U+1F39A"], "🎚", "level slider"], [["U+1F39B"], "🎛", "control knobs"], [["U+1F3A4"], "🎤", "microphone"], [["U+1F3A7"], "🎧", "headphone"], [["U+1F4FB"], "📻", "radio"]]], ["musical-instrument", [[["U+1F3B7"], "🎷", "saxophone"], [["U+1FA97"], "🪗", "⊛ accordion"], [["U+1F3B8"], "🎸", "guitar"], [["U+1F3B9"], "🎹", "musical keyboard"], [["U+1F3BA"], "🎺", "trumpet"], [["U+1F3BB"], "🎻", "violin"], [["U+1FA95"], "🪕", "banjo"], [["U+1F941"], "🥁", "drum"], [["U+1FA98"], "🪘", "⊛ long drum"]]], ["phone", [[["U+1F4F1"], "📱", "mobile phone"], [["U+1F4F2"], "📲", "mobile phone with arrow"], [["U+260E"], "☎", "telephone"], [["U+1F4DE"], "📞", "telephone receiver"], [["U+1F4DF"], "📟", "pager"], [["U+1F4E0"], "📠", "fax machine"]]], ["computer", [[["U+1F50B"], "🔋", "battery"], [["U+1F50C"], "🔌", "electric plug"], [["U+1F4BB"], "💻", "laptop"], [["U+1F5A5"], "🖥", "desktop computer"], [["U+1F5A8"], "🖨", "printer"], [["U+2328"], "⌨", "keyboard"], [["U+1F5B1"], "🖱", "computer mouse"], [["U+1F5B2"], "🖲", "trackball"], [["U+1F4BD"], "💽", "computer disk"], [["U+1F4BE"], "💾", "floppy disk"], [["U+1F4BF"], "💿", "optical disk"], [["U+1F4C0"], "📀", "dvd"], [["U+1F9EE"], "🧮", "abacus"]]], ["light & video", [[["U+1F3A5"], "🎥", "movie camera"], [["U+1F39E"], "🎞", "film frames"], [["U+1F4FD"], "📽", "film projector"], [["U+1F3AC"], "🎬", "clapper board"], [["U+1F4FA"], "📺", "television"], [["U+1F4F7"], "📷", "camera"], [["U+1F4F8"], "📸", "camera with flash"], [["U+1F4F9"], "📹", "video camera"], [["U+1F4FC"], "📼", "videocassette"], [["U+1F50D"], "🔍", "magnifying glass tilted left"], [["U+1F50E"], "🔎", "magnifying glass tilted right"], [["U+1F56F"], "🕯", "candle"], [["U+1F4A1"], "💡", "light bulb"], [["U+1F526"], "🔦", "flashlight"], [["U+1F3EE"], "🏮", "red paper lantern"], [["U+1FA94"], "🪔", "diya lamp"]]], ["book-paper", [[["U+1F4D4"], "📔", "notebook with decorative cover"], [["U+1F4D5"], "📕", "closed book"], [["U+1F4D6"], "📖", "open book"], [["U+1F4D7"], "📗", "green book"], [["U+1F4D8"], "📘", "blue book"], [["U+1F4D9"], "📙", "orange book"], [["U+1F4DA"], "📚", "books"], [["U+1F4D3"], "📓", "notebook"], [["U+1F4D2"], "📒", "ledger"], [["U+1F4C3"], "📃", "page with curl"], [["U+1F4DC"], "📜", "scroll"], [["U+1F4C4"], "📄", "page facing up"], [["U+1F4F0"], "📰", "newspaper"], [["U+1F5DE"], "🗞", "rolled-up newspaper"], [["U+1F4D1"], "📑", "bookmark tabs"], [["U+1F516"], "🔖", "bookmark"], [["U+1F3F7"], "🏷", "label"]]], ["money", [[["U+1F4B0"], "💰", "money bag"], [["U+1FA99"], "🪙", "⊛ coin"], [["U+1F4B4"], "💴", "yen banknote"], [["U+1F4B5"], "💵", "dollar banknote"], [["U+1F4B6"], "💶", "euro banknote"], [["U+1F4B7"], "💷", "pound banknote"], [["U+1F4B8"], "💸", "money with wings"], [["U+1F4B3"], "💳", "credit card"], [["U+1F9FE"], "🧾", "receipt"], [["U+1F4B9"], "💹", "chart increasing with yen"]]], ["mail", [[["U+2709"], "✉", "envelope"], [["U+1F4E7"], "📧", "e-mail"], [["U+1F4E8"], "📨", "incoming envelope"], [["U+1F4E9"], "📩", "envelope with arrow"], [["U+1F4E4"], "📤", "outbox tray"], [["U+1F4E5"], "📥", "inbox tray"], [["U+1F4E6"], "📦", "package"], [["U+1F4EB"], "📫", "closed mailbox with raised flag"], [["U+1F4EA"], "📪", "closed mailbox with lowered flag"], [["U+1F4EC"], "📬", "open mailbox with raised flag"], [["U+1F4ED"], "📭", "open mailbox with lowered flag"], [["U+1F4EE"], "📮", "postbox"], [["U+1F5F3"], "🗳", "ballot box with ballot"]]], ["writing", [[["U+270F"], "✏", "pencil"], [["U+2712"], "✒", "black nib"], [["U+1F58B"], "🖋", "fountain pen"], [["U+1F58A"], "🖊", "pen"], [["U+1F58C"], "🖌", "paintbrush"], [["U+1F58D"], "🖍", "crayon"], [["U+1F4DD"], "📝", "memo"]]], ["office", [[["U+1F4BC"], "💼", "briefcase"], [["U+1F4C1"], "📁", "file folder"], [["U+1F4C2"], "📂", "open file folder"], [["U+1F5C2"], "🗂", "card index dividers"], [["U+1F4C5"], "📅", "calendar"], [["U+1F4C6"], "📆", "tear-off calendar"], [["U+1F5D2"], "🗒", "spiral notepad"], [["U+1F5D3"], "🗓", "spiral calendar"], [["U+1F4C7"], "📇", "card index"], [["U+1F4C8"], "📈", "chart increasing"], [["U+1F4C9"], "📉", "chart decreasing"], [["U+1F4CA"], "📊", "bar chart"], [["U+1F4CB"], "📋", "clipboard"], [["U+1F4CC"], "📌", "pushpin"], [["U+1F4CD"], "📍", "round pushpin"], [["U+1F4CE"], "📎", "paperclip"], [["U+1F587"], "🖇", "linked paperclips"], [["U+1F4CF"], "📏", "straight ruler"], [["U+1F4D0"], "📐", "triangular ruler"], [["U+2702"], "✂", "scissors"], [["U+1F5C3"], "🗃", "card file box"], [["U+1F5C4"], "🗄", "file cabinet"], [["U+1F5D1"], "🗑", "wastebasket"]]], ["lock", [[["U+1F512"], "🔒", "locked"], [["U+1F513"], "🔓", "unlocked"], [["U+1F50F"], "🔏", "locked with pen"], [["U+1F510"], "🔐", "locked with key"], [["U+1F511"], "🔑", "key"], [["U+1F5DD"], "🗝", "old key"]]], ["tool", [[["U+1F528"], "🔨", "hammer"], [["U+1FA93"], "🪓", "axe"], [["U+26CF"], "⛏", "pick"], [["U+2692"], "⚒", "hammer and pick"], [["U+1F6E0"], "🛠", "hammer and wrench"], [["U+1F5E1"], "🗡", "dagger"], [["U+2694"], "⚔", "crossed swords"], [["U+1F52B"], "🔫", "pistol"], [["U+1FA83"], "🪃", "⊛ boomerang"], [["U+1F3F9"], "🏹", "bow and arrow"], [["U+1F6E1"], "🛡", "shield"], [["U+1F527"], "🔧", "wrench"], [["U+1FA9B"], "🪛", "⊛ screwdriver"], [["U+1F529"], "🔩", "nut and bolt"], [["U+2699"], "⚙", "gear"], [["U+1F5DC"], "🗜", "clamp"], [["U+2696"], "⚖", "balance scale"], [["U+1F9AF"], "🦯", "white cane"], [["U+1F517"], "🔗", "link"], [["U+26D3"], "⛓", "chains"], [["U+1FA9D"], "🪝", "⊛ hook"], [["U+1F9F0"], "🧰", "toolbox"], [["U+1F9F2"], "🧲", "magnet"], [["U+1FA9C"], "🪜", "⊛ ladder"]]], ["science", [[["U+2697"], "⚗", "alembic"], [["U+1F9EA"], "🧪", "test tube"], [["U+1F9EB"], "🧫", "petri dish"], [["U+1F9EC"], "🧬", "dna"], [["U+1F52C"], "🔬", "microscope"], [["U+1F52D"], "🔭", "telescope"], [["U+1F4E1"], "📡", "satellite antenna"]]], ["medical", [[["U+1F489"], "💉", "syringe"], [["U+1FA78"], "🩸", "drop of blood"], [["U+1F48A"], "💊", "pill"], [["U+1FA79"], "🩹", "adhesive bandage"], [["U+1FA7A"], "🩺", "stethoscope"]]], ["household", [[["U+1F6AA"], "🚪", "door"], [["U+1F6D7"], "🛗", "⊛ elevator"], [["U+1F6CF"], "🛏", "bed"], [["U+1F6CB"], "🛋", "couch and lamp"], [["U+1FA91"], "🪑", "chair"], [["U+1F6BD"], "🚽", "toilet"], [["U+1FAA0"], "🪠", "⊛ plunger"], [["U+1F6BF"], "🚿", "shower"], [["U+1F6C1"], "🛁", "bathtub"], [["U+1FA92"], "🪒", "razor"], [["U+1F9F4"], "🧴", "lotion bottle"], [["U+1F9F7"], "🧷", "safety pin"], [["U+1F9F9"], "🧹", "broom"], [["U+1F9FA"], "🧺", "basket"], [["U+1F9FB"], "🧻", "roll of paper"], [["U+1FAA3"], "🪣", "⊛ bucket"], [["U+1F9FC"], "🧼", "soap"], [["U+1FAA5"], "🪥", "⊛ toothbrush"], [["U+1F9FD"], "🧽", "sponge"], [["U+1F9EF"], "🧯", "fire extinguisher"], [["U+1F6D2"], "🛒", "shopping cart"]]], ["other-object", [[["U+1F6AC"], "🚬", "cigarette"], [["U+26B0"], "⚰", "coffin"], [["U+26B1"], "⚱", "funeral urn"], [["U+1F5FF"], "🗿", "moai"], [["U+1FAA7"], "🪧", "⊛ placard"]]]]], ["Symbols", [["transport-sign", [[["U+1F3E7"], "🏧", "ATM sign"], [["U+1F6AE"], "🚮", "litter in bin sign"], [["U+1F6B0"], "🚰", "potable water"], [["U+267F"], "♿", "wheelchair symbol"], [["U+1F6B9"], "🚹", "men’s room"], [["U+1F6BA"], "🚺", "women’s room"], [["U+1F6BB"], "🚻", "restroom"], [["U+1F6BC"], "🚼", "baby symbol"], [["U+1F6BE"], "🚾", "water closet"], [["U+1F6C2"], "🛂", "passport control"], [["U+1F6C3"], "🛃", "customs"], [["U+1F6C4"], "🛄", "baggage claim"], [["U+1F6C5"], "🛅", "left luggage"]]], ["warning", [[["U+26A0"], "⚠", "warning"], [["U+1F6B8"], "🚸", "children crossing"], [["U+26D4"], "⛔", "no entry"], [["U+1F6AB"], "🚫", "prohibited"], [["U+1F6B3"], "🚳", "no bicycles"], [["U+1F6AD"], "🚭", "no smoking"], [["U+1F6AF"], "🚯", "no littering"], [["U+1F6B1"], "🚱", "non-potable water"], [["U+1F6B7"], "🚷", "no pedestrians"], [["U+1F4F5"], "📵", "no mobile phones"], [["U+1F51E"], "🔞", "no one under eighteen"], [["U+2622"], "☢", "radioactive"], [["U+2623"], "☣", "biohazard"]]], ["arrow", [[["U+2B06"], "⬆", "up arrow"], [["U+2197"], "↗", "up-right arrow"], [["U+27A1"], "➡", "right arrow"], [["U+2198"], "↘", "down-right arrow"], [["U+2B07"], "⬇", "down arrow"], [["U+2199"], "↙", "down-left arrow"], [["U+2B05"], "⬅", "left arrow"], [["U+2196"], "↖", "up-left arrow"], [["U+2195"], "↕", "up-down arrow"], [["U+2194"], "↔", "left-right arrow"], [["U+21A9"], "↩", "right arrow curving left"], [["U+21AA"], "↪", "left arrow curving right"], [["U+2934"], "⤴", "right arrow curving up"], [["U+2935"], "⤵", "right arrow curving down"], [["U+1F503"], "🔃", "clockwise vertical arrows"], [["U+1F504"], "🔄", "counterclockwise arrows button"], [["U+1F519"], "🔙", "BACK arrow"], [["U+1F51A"], "🔚", "END arrow"], [["U+1F51B"], "🔛", "ON! arrow"], [["U+1F51C"], "🔜", "SOON arrow"], [["U+1F51D"], "🔝", "TOP arrow"]]], ["religion", [[["U+1F6D0"], "🛐", "place of worship"], [["U+269B"], "⚛", "atom symbol"], [["U+1F549"], "🕉", "om"], [["U+2721"], "✡", "star of David"], [["U+2638"], "☸", "wheel of dharma"], [["U+262F"], "☯", "yin yang"], [["U+271D"], "✝", "latin cross"], [["U+2626"], "☦", "orthodox cross"], [["U+262A"], "☪", "star and crescent"], [["U+262E"], "☮", "peace symbol"], [["U+1F54E"], "🕎", "menorah"], [["U+1F52F"], "🔯", "dotted six-pointed star"]]], ["zodiac", [[["U+2648"], "♈", "Aries"], [["U+2649"], "♉", "Taurus"], [["U+264A"], "♊", "Gemini"], [["U+264B"], "♋", "Cancer"], [["U+264C"], "♌", "Leo"], [["U+264D"], "♍", "Virgo"], [["U+264E"], "♎", "Libra"], [["U+264F"], "♏", "Scorpio"], [["U+2650"], "♐", "Sagittarius"], [["U+2651"], "♑", "Capricorn"], [["U+2652"], "♒", "Aquarius"], [["U+2653"], "♓", "Pisces"], [["U+26CE"], "⛎", "Ophiuchus"]]], ["av-symbol", [[["U+1F500"], "🔀", "shuffle tracks button"], [["U+1F501"], "🔁", "repeat button"], [["U+1F502"], "🔂", "repeat single button"], [["U+25B6"], "▶", "play button"], [["U+23E9"], "⏩", "fast-forward button"], [["U+23ED"], "⏭", "next track button"], [["U+23EF"], "⏯", "play or pause button"], [["U+25C0"], "◀", "reverse button"], [["U+23EA"], "⏪", "fast reverse button"], [["U+23EE"], "⏮", "last track button"], [["U+1F53C"], "🔼", "upwards button"], [["U+23EB"], "⏫", "fast up button"], [["U+1F53D"], "🔽", "downwards button"], [["U+23EC"], "⏬", "fast down button"], [["U+23F8"], "⏸", "pause button"], [["U+23F9"], "⏹", "stop button"], [["U+23FA"], "⏺", "record button"], [["U+23CF"], "⏏", "eject button"], [["U+1F3A6"], "🎦", "cinema"], [["U+1F505"], "🔅", "dim button"], [["U+1F506"], "🔆", "bright button"], [["U+1F4F6"], "📶", "antenna bars"], [["U+1F4F3"], "📳", "vibration mode"], [["U+1F4F4"], "📴", "mobile phone off"]]], ["gender", [[["U+2640"], "♀", "female sign"], [["U+2642"], "♂", "male sign"], [["U+26A7"], "⚧", "⊛ transgender symbol"]]], ["math", [[["U+2716"], "✖", "multiply"], [["U+2795"], "➕", "plus"], [["U+2796"], "➖", "minus"], [["U+2797"], "➗", "divide"], [["U+267E"], "♾", "infinity"]]], ["punctuation", [[["U+203C"], "‼", "double exclamation mark"], [["U+2049"], "⁉", "exclamation question mark"], [["U+2753"], "❓", "question mark"], [["U+2754"], "❔", "white question mark"], [["U+2755"], "❕", "white exclamation mark"], [["U+2757"], "❗", "exclamation mark"], [["U+3030"], "〰", "wavy dash"]]], ["currency", [[["U+1F4B1"], "💱", "currency exchange"], [["U+1F4B2"], "💲", "heavy dollar sign"]]], ["other-symbol", [[["U+2695"], "⚕", "medical symbol"], [["U+267B"], "♻", "recycling symbol"], [["U+269C"], "⚜", "fleur-de-lis"], [["U+1F531"], "🔱", "trident emblem"], [["U+1F4DB"], "📛", "name badge"], [["U+1F530"], "🔰", "Japanese symbol for beginner"], [["U+2B55"], "⭕", "hollow red circle"], [["U+2705"], "✅", "check mark button"], [["U+2611"], "☑", "check box with check"], [["U+2714"], "✔", "check mark"], [["U+274C"], "❌", "cross mark"], [["U+274E"], "❎", "cross mark button"], [["U+27B0"], "➰", "curly loop"], [["U+27BF"], "➿", "double curly loop"], [["U+303D"], "〽", "part alternation mark"], [["U+2733"], "✳", "eight-spoked asterisk"], [["U+2734"], "✴", "eight-pointed star"], [["U+2747"], "❇", "sparkle"], [["U+00A9"], "©", "copyright"], [["U+00AE"], "®", "registered"], [["U+2122"], "™", "trade mark"]]], ["keycap", [[["U+0023", "U+FE0F", "U+20E3"], "#️⃣", "keycap: #"], [["U+002A", "U+FE0F", "U+20E3"], "*️⃣", "keycap: *"], [["U+0030", "U+FE0F", "U+20E3"], "0️⃣", "keycap: 0"], [["U+0031", "U+FE0F", "U+20E3"], "1️⃣", "keycap: 1"], [["U+0032", "U+FE0F", "U+20E3"], "2️⃣", "keycap: 2"], [["U+0033", "U+FE0F", "U+20E3"], "3️⃣", "keycap: 3"], [["U+0034", "U+FE0F", "U+20E3"], "4️⃣", "keycap: 4"], [["U+0035", "U+FE0F", "U+20E3"], "5️⃣", "keycap: 5"], [["U+0036", "U+FE0F", "U+20E3"], "6️⃣", "keycap: 6"], [["U+0037", "U+FE0F", "U+20E3"], "7️⃣", "keycap: 7"], [["U+0038", "U+FE0F", "U+20E3"], "8️⃣", "keycap: 8"], [["U+0039", "U+FE0F", "U+20E3"], "9️⃣", "keycap: 9"], [["U+1F51F"], "🔟", "keycap: 10"]]], ["alphanum", [[["U+1F520"], "🔠", "input latin uppercase"], [["U+1F521"], "🔡", "input latin lowercase"], [["U+1F522"], "🔢", "input numbers"], [["U+1F523"], "🔣", "input symbols"], [["U+1F524"], "🔤", "input latin letters"], [["U+1F170"], "🅰", "A button (blood type)"], [["U+1F18E"], "🆎", "AB button (blood type)"], [["U+1F171"], "🅱", "B button (blood type)"], [["U+1F191"], "🆑", "CL button"], [["U+1F192"], "🆒", "COOL button"], [["U+1F193"], "🆓", "FREE button"], [["U+2139"], "ℹ", "information"], [["U+1F194"], "🆔", "ID button"], [["U+24C2"], "Ⓜ", "circled M"], [["U+1F195"], "🆕", "NEW button"], [["U+1F196"], "🆖", "NG button"], [["U+1F17E"], "🅾", "O button (blood type)"], [["U+1F197"], "🆗", "OK button"], [["U+1F17F"], "🅿", "P button"], [["U+1F198"], "🆘", "SOS button"], [["U+1F199"], "🆙", "UP! button"], [["U+1F19A"], "🆚", "VS button"], [["U+1F201"], "🈁", "Japanese “here” button"], [["U+1F202"], "🈂", "Japanese “service charge” button"], [["U+1F237"], "🈷", "Japanese “monthly amount” button"], [["U+1F236"], "🈶", "Japanese “not free of charge” button"], [["U+1F22F"], "🈯", "Japanese “reserved” button"], [["U+1F250"], "🉐", "Japanese “bargain” button"], [["U+1F239"], "🈹", "Japanese “discount” button"], [["U+1F21A"], "🈚", "Japanese “free of charge” button"], [["U+1F232"], "🈲", "Japanese “prohibited” button"], [["U+1F251"], "🉑", "Japanese “acceptable” button"], [["U+1F238"], "🈸", "Japanese “application” button"], [["U+1F234"], "🈴", "Japanese “passing grade” button"], [["U+1F233"], "🈳", "Japanese “vacancy” button"], [["U+3297"], "㊗", "Japanese “congratulations” button"], [["U+3299"], "㊙", "Japanese “secret” button"], [["U+1F23A"], "🈺", "Japanese “open for business” button"], [["U+1F235"], "🈵", "Japanese “no vacancy” button"]]], ["geometric", [[["U+1F534"], "🔴", "red circle"], [["U+1F7E0"], "🟠", "orange circle"], [["U+1F7E1"], "🟡", "yellow circle"], [["U+1F7E2"], "🟢", "green circle"], [["U+1F535"], "🔵", "blue circle"], [["U+1F7E3"], "🟣", "purple circle"], [["U+1F7E4"], "🟤", "brown circle"], [["U+26AB"], "⚫", "black circle"], [["U+26AA"], "⚪", "white circle"], [["U+1F7E5"], "🟥", "red square"], [["U+1F7E7"], "🟧", "orange square"], [["U+1F7E8"], "🟨", "yellow square"], [["U+1F7E9"], "🟩", "green square"], [["U+1F7E6"], "🟦", "blue square"], [["U+1F7EA"], "🟪", "purple square"], [["U+1F7EB"], "🟫", "brown square"], [["U+2B1B"], "⬛", "black large square"], [["U+2B1C"], "⬜", "white large square"], [["U+25FC"], "◼", "black medium square"], [["U+25FB"], "◻", "white medium square"], [["U+25FE"], "◾", "black medium-small square"], [["U+25FD"], "◽", "white medium-small square"], [["U+25AA"], "▪", "black small square"], [["U+25AB"], "▫", "white small square"], [["U+1F536"], "🔶", "large orange diamond"], [["U+1F537"], "🔷", "large blue diamond"], [["U+1F538"], "🔸", "small orange diamond"], [["U+1F539"], "🔹", "small blue diamond"], [["U+1F53A"], "🔺", "red triangle pointed up"], [["U+1F53B"], "🔻", "red triangle pointed down"], [["U+1F4A0"], "💠", "diamond with a dot"], [["U+1F518"], "🔘", "radio button"], [["U+1F533"], "🔳", "white square button"], [["U+1F532"], "🔲", "black square button"]]]]], ["Flags", [["flag", [[["U+1F3C1"], "🏁", "chequered flag"], [["U+1F6A9"], "🚩", "triangular flag"], [["U+1F38C"], "🎌", "crossed flags"], [["U+1F3F4"], "🏴", "black flag"], [["U+1F3F3"], "🏳", "white flag"], [["U+1F3F3", "U+FE0F", "U+200D", "U+1F308"], "🏳️🌈", "rainbow flag"], [["U+1F3F3", "U+FE0F", "U+200D", "U+26A7", "U+FE0F"], "🏳️⚧️", "⊛ transgender flag"], [["U+1F3F4", "U+200D", "U+2620", "U+FE0F"], "🏴☠️", "pirate flag"]]], ["country-flag", [[["U+1F1E6", "U+1F1E8"], "🇦🇨", "flag: Ascension Island"], [["U+1F1E6", "U+1F1E9"], "🇦🇩", "flag: Andorra"], [["U+1F1E6", "U+1F1EA"], "🇦🇪", "flag: United Arab Emirates"], [["U+1F1E6", "U+1F1EB"], "🇦🇫", "flag: Afghanistan"], [["U+1F1E6", "U+1F1EC"], "🇦🇬", "flag: Antigua & Barbuda"], [["U+1F1E6", "U+1F1EE"], "🇦🇮", "flag: Anguilla"], [["U+1F1E6", "U+1F1F1"], "🇦🇱", "flag: Albania"], [["U+1F1E6", "U+1F1F2"], "🇦🇲", "flag: Armenia"], [["U+1F1E6", "U+1F1F4"], "🇦🇴", "flag: Angola"], [["U+1F1E6", "U+1F1F6"], "🇦🇶", "flag: Antarctica"], [["U+1F1E6", "U+1F1F7"], "🇦🇷", "flag: Argentina"], [["U+1F1E6", "U+1F1F8"], "🇦🇸", "flag: American Samoa"], [["U+1F1E6", "U+1F1F9"], "🇦🇹", "flag: Austria"], [["U+1F1E6", "U+1F1FA"], "🇦🇺", "flag: Australia"], [["U+1F1E6", "U+1F1FC"], "🇦🇼", "flag: Aruba"], [["U+1F1E6", "U+1F1FD"], "🇦🇽", "flag: Åland Islands"], [["U+1F1E6", "U+1F1FF"], "🇦🇿", "flag: Azerbaijan"], [["U+1F1E7", "U+1F1E6"], "🇧🇦", "flag: Bosnia & Herzegovina"], [["U+1F1E7", "U+1F1E7"], "🇧🇧", "flag: Barbados"], [["U+1F1E7", "U+1F1E9"], "🇧🇩", "flag: Bangladesh"], [["U+1F1E7", "U+1F1EA"], "🇧🇪", "flag: Belgium"], [["U+1F1E7", "U+1F1EB"], "🇧🇫", "flag: Burkina Faso"], [["U+1F1E7", "U+1F1EC"], "🇧🇬", "flag: Bulgaria"], [["U+1F1E7", "U+1F1ED"], "🇧🇭", "flag: Bahrain"], [["U+1F1E7", "U+1F1EE"], "🇧🇮", "flag: Burundi"], [["U+1F1E7", "U+1F1EF"], "🇧🇯", "flag: Benin"], [["U+1F1E7", "U+1F1F1"], "🇧🇱", "flag: St. Barthélemy"], [["U+1F1E7", "U+1F1F2"], "🇧🇲", "flag: Bermuda"], [["U+1F1E7", "U+1F1F3"], "🇧🇳", "flag: Brunei"], [["U+1F1E7", "U+1F1F4"], "🇧🇴", "flag: Bolivia"], [["U+1F1E7", "U+1F1F6"], "🇧🇶", "flag: Caribbean Netherlands"], [["U+1F1E7", "U+1F1F7"], "🇧🇷", "flag: Brazil"], [["U+1F1E7", "U+1F1F8"], "🇧🇸", "flag: Bahamas"], [["U+1F1E7", "U+1F1F9"], "🇧🇹", "flag: Bhutan"], [["U+1F1E7", "U+1F1FB"], "🇧🇻", "flag: Bouvet Island"], [["U+1F1E7", "U+1F1FC"], "🇧🇼", "flag: Botswana"], [["U+1F1E7", "U+1F1FE"], "🇧🇾", "flag: Belarus"], [["U+1F1E7", "U+1F1FF"], "🇧🇿", "flag: Belize"], [["U+1F1E8", "U+1F1E6"], "🇨🇦", "flag: Canada"], [["U+1F1E8", "U+1F1E8"], "🇨🇨", "flag: Cocos (Keeling) Islands"], [["U+1F1E8", "U+1F1E9"], "🇨🇩", "flag: Congo - Kinshasa"], [["U+1F1E8", "U+1F1EB"], "🇨🇫", "flag: Central African Republic"], [["U+1F1E8", "U+1F1EC"], "🇨🇬", "flag: Congo - Brazzaville"], [["U+1F1E8", "U+1F1ED"], "🇨🇭", "flag: Switzerland"], [["U+1F1E8", "U+1F1EE"], "🇨🇮", "flag: Côte d’Ivoire"], [["U+1F1E8", "U+1F1F0"], "🇨🇰", "flag: Cook Islands"], [["U+1F1E8", "U+1F1F1"], "🇨🇱", "flag: Chile"], [["U+1F1E8", "U+1F1F2"], "🇨🇲", "flag: Cameroon"], [["U+1F1E8", "U+1F1F3"], "🇨🇳", "flag: China"], [["U+1F1E8", "U+1F1F4"], "🇨🇴", "flag: Colombia"], [["U+1F1E8", "U+1F1F5"], "🇨🇵", "flag: Clipperton Island"], [["U+1F1E8", "U+1F1F7"], "🇨🇷", "flag: Costa Rica"], [["U+1F1E8", "U+1F1FA"], "🇨🇺", "flag: Cuba"], [["U+1F1E8", "U+1F1FB"], "🇨🇻", "flag: Cape Verde"], [["U+1F1E8", "U+1F1FC"], "🇨🇼", "flag: Curaçao"], [["U+1F1E8", "U+1F1FD"], "🇨🇽", "flag: Christmas Island"], [["U+1F1E8", "U+1F1FE"], "🇨🇾", "flag: Cyprus"], [["U+1F1E8", "U+1F1FF"], "🇨🇿", "flag: Czechia"], [["U+1F1E9", "U+1F1EA"], "🇩🇪", "flag: Germany"], [["U+1F1E9", "U+1F1EC"], "🇩🇬", "flag: Diego Garcia"], [["U+1F1E9", "U+1F1EF"], "🇩🇯", "flag: Djibouti"], [["U+1F1E9", "U+1F1F0"], "🇩🇰", "flag: Denmark"], [["U+1F1E9", "U+1F1F2"], "🇩🇲", "flag: Dominica"], [["U+1F1E9", "U+1F1F4"], "🇩🇴", "flag: Dominican Republic"], [["U+1F1E9", "U+1F1FF"], "🇩🇿", "flag: Algeria"], [["U+1F1EA", "U+1F1E6"], "🇪🇦", "flag: Ceuta & Melilla"], [["U+1F1EA", "U+1F1E8"], "🇪🇨", "flag: Ecuador"], [["U+1F1EA", "U+1F1EA"], "🇪🇪", "flag: Estonia"], [["U+1F1EA", "U+1F1EC"], "🇪🇬", "flag: Egypt"], [["U+1F1EA", "U+1F1ED"], "🇪🇭", "flag: Western Sahara"], [["U+1F1EA", "U+1F1F7"], "🇪🇷", "flag: Eritrea"], [["U+1F1EA", "U+1F1F8"], "🇪🇸", "flag: Spain"], [["U+1F1EA", "U+1F1F9"], "🇪🇹", "flag: Ethiopia"], [["U+1F1EA", "U+1F1FA"], "🇪🇺", "flag: European Union"], [["U+1F1EB", "U+1F1EE"], "🇫🇮", "flag: Finland"], [["U+1F1EB", "U+1F1EF"], "🇫🇯", "flag: Fiji"], [["U+1F1EB", "U+1F1F0"], "🇫🇰", "flag: Falkland Islands"], [["U+1F1EB", "U+1F1F2"], "🇫🇲", "flag: Micronesia"], [["U+1F1EB", "U+1F1F4"], "🇫🇴", "flag: Faroe Islands"], [["U+1F1EB", "U+1F1F7"], "🇫🇷", "flag: France"], [["U+1F1EC", "U+1F1E6"], "🇬🇦", "flag: Gabon"], [["U+1F1EC", "U+1F1E7"], "🇬🇧", "flag: United Kingdom"], [["U+1F1EC", "U+1F1E9"], "🇬🇩", "flag: Grenada"], [["U+1F1EC", "U+1F1EA"], "🇬🇪", "flag: Georgia"], [["U+1F1EC", "U+1F1EB"], "🇬🇫", "flag: French Guiana"], [["U+1F1EC", "U+1F1EC"], "🇬🇬", "flag: Guernsey"], [["U+1F1EC", "U+1F1ED"], "🇬🇭", "flag: Ghana"], [["U+1F1EC", "U+1F1EE"], "🇬🇮", "flag: Gibraltar"], [["U+1F1EC", "U+1F1F1"], "🇬🇱", "flag: Greenland"], [["U+1F1EC", "U+1F1F2"], "🇬🇲", "flag: Gambia"], [["U+1F1EC", "U+1F1F3"], "🇬🇳", "flag: Guinea"], [["U+1F1EC", "U+1F1F5"], "🇬🇵", "flag: Guadeloupe"], [["U+1F1EC", "U+1F1F6"], "🇬🇶", "flag: Equatorial Guinea"], [["U+1F1EC", "U+1F1F7"], "🇬🇷", "flag: Greece"], [["U+1F1EC", "U+1F1F8"], "🇬🇸", "flag: South Georgia & South Sandwich Islands"], [["U+1F1EC", "U+1F1F9"], "🇬🇹", "flag: Guatemala"], [["U+1F1EC", "U+1F1FA"], "🇬🇺", "flag: Guam"], [["U+1F1EC", "U+1F1FC"], "🇬🇼", "flag: Guinea-Bissau"], [["U+1F1EC", "U+1F1FE"], "🇬🇾", "flag: Guyana"], [["U+1F1ED", "U+1F1F0"], "🇭🇰", "flag: Hong Kong SAR China"], [["U+1F1ED", "U+1F1F2"], "🇭🇲", "flag: Heard & McDonald Islands"], [["U+1F1ED", "U+1F1F3"], "🇭🇳", "flag: Honduras"], [["U+1F1ED", "U+1F1F7"], "🇭🇷", "flag: Croatia"], [["U+1F1ED", "U+1F1F9"], "🇭🇹", "flag: Haiti"], [["U+1F1ED", "U+1F1FA"], "🇭🇺", "flag: Hungary"], [["U+1F1EE", "U+1F1E8"], "🇮🇨", "flag: Canary Islands"], [["U+1F1EE", "U+1F1E9"], "🇮🇩", "flag: Indonesia"], [["U+1F1EE", "U+1F1EA"], "🇮🇪", "flag: Ireland"], [["U+1F1EE", "U+1F1F1"], "🇮🇱", "flag: Israel"], [["U+1F1EE", "U+1F1F2"], "🇮🇲", "flag: Isle of Man"], [["U+1F1EE", "U+1F1F3"], "🇮🇳", "flag: India"], [["U+1F1EE", "U+1F1F4"], "🇮🇴", "flag: British Indian Ocean Territory"], [["U+1F1EE", "U+1F1F6"], "🇮🇶", "flag: Iraq"], [["U+1F1EE", "U+1F1F7"], "🇮🇷", "flag: Iran"], [["U+1F1EE", "U+1F1F8"], "🇮🇸", "flag: Iceland"], [["U+1F1EE", "U+1F1F9"], "🇮🇹", "flag: Italy"], [["U+1F1EF", "U+1F1EA"], "🇯🇪", "flag: Jersey"], [["U+1F1EF", "U+1F1F2"], "🇯🇲", "flag: Jamaica"], [["U+1F1EF", "U+1F1F4"], "🇯🇴", "flag: Jordan"], [["U+1F1EF", "U+1F1F5"], "🇯🇵", "flag: Japan"], [["U+1F1F0", "U+1F1EA"], "🇰🇪", "flag: Kenya"], [["U+1F1F0", "U+1F1EC"], "🇰🇬", "flag: Kyrgyzstan"], [["U+1F1F0", "U+1F1ED"], "🇰🇭", "flag: Cambodia"], [["U+1F1F0", "U+1F1EE"], "🇰🇮", "flag: Kiribati"], [["U+1F1F0", "U+1F1F2"], "🇰🇲", "flag: Comoros"], [["U+1F1F0", "U+1F1F3"], "🇰🇳", "flag: St. Kitts & Nevis"], [["U+1F1F0", "U+1F1F5"], "🇰🇵", "flag: North Korea"], [["U+1F1F0", "U+1F1F7"], "🇰🇷", "flag: South Korea"], [["U+1F1F0", "U+1F1FC"], "🇰🇼", "flag: Kuwait"], [["U+1F1F0", "U+1F1FE"], "🇰🇾", "flag: Cayman Islands"], [["U+1F1F0", "U+1F1FF"], "🇰🇿", "flag: Kazakhstan"], [["U+1F1F1", "U+1F1E6"], "🇱🇦", "flag: Laos"], [["U+1F1F1", "U+1F1E7"], "🇱🇧", "flag: Lebanon"], [["U+1F1F1", "U+1F1E8"], "🇱🇨", "flag: St. Lucia"], [["U+1F1F1", "U+1F1EE"], "🇱🇮", "flag: Liechtenstein"], [["U+1F1F1", "U+1F1F0"], "🇱🇰", "flag: Sri Lanka"], [["U+1F1F1", "U+1F1F7"], "🇱🇷", "flag: Liberia"], [["U+1F1F1", "U+1F1F8"], "🇱🇸", "flag: Lesotho"], [["U+1F1F1", "U+1F1F9"], "🇱🇹", "flag: Lithuania"], [["U+1F1F1", "U+1F1FA"], "🇱🇺", "flag: Luxembourg"], [["U+1F1F1", "U+1F1FB"], "🇱🇻", "flag: Latvia"], [["U+1F1F1", "U+1F1FE"], "🇱🇾", "flag: Libya"], [["U+1F1F2", "U+1F1E6"], "🇲🇦", "flag: Morocco"], [["U+1F1F2", "U+1F1E8"], "🇲🇨", "flag: Monaco"], [["U+1F1F2", "U+1F1E9"], "🇲🇩", "flag: Moldova"], [["U+1F1F2", "U+1F1EA"], "🇲🇪", "flag: Montenegro"], [["U+1F1F2", "U+1F1EB"], "🇲🇫", "flag: St. Martin"], [["U+1F1F2", "U+1F1EC"], "🇲🇬", "flag: Madagascar"], [["U+1F1F2", "U+1F1ED"], "🇲🇭", "flag: Marshall Islands"], [["U+1F1F2", "U+1F1F0"], "🇲🇰", "flag: North Macedonia"], [["U+1F1F2", "U+1F1F1"], "🇲🇱", "flag: Mali"], [["U+1F1F2", "U+1F1F2"], "🇲🇲", "flag: Myanmar (Burma)"], [["U+1F1F2", "U+1F1F3"], "🇲🇳", "flag: Mongolia"], [["U+1F1F2", "U+1F1F4"], "🇲🇴", "flag: Macao SAR China"], [["U+1F1F2", "U+1F1F5"], "🇲🇵", "flag: Northern Mariana Islands"], [["U+1F1F2", "U+1F1F6"], "🇲🇶", "flag: Martinique"], [["U+1F1F2", "U+1F1F7"], "🇲🇷", "flag: Mauritania"], [["U+1F1F2", "U+1F1F8"], "🇲🇸", "flag: Montserrat"], [["U+1F1F2", "U+1F1F9"], "🇲🇹", "flag: Malta"], [["U+1F1F2", "U+1F1FA"], "🇲🇺", "flag: Mauritius"], [["U+1F1F2", "U+1F1FB"], "🇲🇻", "flag: Maldives"], [["U+1F1F2", "U+1F1FC"], "🇲🇼", "flag: Malawi"], [["U+1F1F2", "U+1F1FD"], "🇲🇽", "flag: Mexico"], [["U+1F1F2", "U+1F1FE"], "🇲🇾", "flag: Malaysia"], [["U+1F1F2", "U+1F1FF"], "🇲🇿", "flag: Mozambique"], [["U+1F1F3", "U+1F1E6"], "🇳🇦", "flag: Namibia"], [["U+1F1F3", "U+1F1E8"], "🇳🇨", "flag: New Caledonia"], [["U+1F1F3", "U+1F1EA"], "🇳🇪", "flag: Niger"], [["U+1F1F3", "U+1F1EB"], "🇳🇫", "flag: Norfolk Island"], [["U+1F1F3", "U+1F1EC"], "🇳🇬", "flag: Nigeria"], [["U+1F1F3", "U+1F1EE"], "🇳🇮", "flag: Nicaragua"], [["U+1F1F3", "U+1F1F1"], "🇳🇱", "flag: Netherlands"], [["U+1F1F3", "U+1F1F4"], "🇳🇴", "flag: Norway"], [["U+1F1F3", "U+1F1F5"], "🇳🇵", "flag: Nepal"], [["U+1F1F3", "U+1F1F7"], "🇳🇷", "flag: Nauru"], [["U+1F1F3", "U+1F1FA"], "🇳🇺", "flag: Niue"], [["U+1F1F3", "U+1F1FF"], "🇳🇿", "flag: New Zealand"], [["U+1F1F4", "U+1F1F2"], "🇴🇲", "flag: Oman"], [["U+1F1F5", "U+1F1E6"], "🇵🇦", "flag: Panama"], [["U+1F1F5", "U+1F1EA"], "🇵🇪", "flag: Peru"], [["U+1F1F5", "U+1F1EB"], "🇵🇫", "flag: French Polynesia"], [["U+1F1F5", "U+1F1EC"], "🇵🇬", "flag: Papua New Guinea"], [["U+1F1F5", "U+1F1ED"], "🇵🇭", "flag: Philippines"], [["U+1F1F5", "U+1F1F0"], "🇵🇰", "flag: Pakistan"], [["U+1F1F5", "U+1F1F1"], "🇵🇱", "flag: Poland"], [["U+1F1F5", "U+1F1F2"], "🇵🇲", "flag: St. Pierre & Miquelon"], [["U+1F1F5", "U+1F1F3"], "🇵🇳", "flag: Pitcairn Islands"], [["U+1F1F5", "U+1F1F7"], "🇵🇷", "flag: Puerto Rico"], [["U+1F1F5", "U+1F1F8"], "🇵🇸", "flag: Palestinian Territories"], [["U+1F1F5", "U+1F1F9"], "🇵🇹", "flag: Portugal"], [["U+1F1F5", "U+1F1FC"], "🇵🇼", "flag: Palau"], [["U+1F1F5", "U+1F1FE"], "🇵🇾", "flag: Paraguay"], [["U+1F1F6", "U+1F1E6"], "🇶🇦", "flag: Qatar"], [["U+1F1F7", "U+1F1EA"], "🇷🇪", "flag: Réunion"], [["U+1F1F7", "U+1F1F4"], "🇷🇴", "flag: Romania"], [["U+1F1F7", "U+1F1F8"], "🇷🇸", "flag: Serbia"], [["U+1F1F7", "U+1F1FA"], "🇷🇺", "flag: Russia"], [["U+1F1F7", "U+1F1FC"], "🇷🇼", "flag: Rwanda"], [["U+1F1F8", "U+1F1E6"], "🇸🇦", "flag: Saudi Arabia"], [["U+1F1F8", "U+1F1E7"], "🇸🇧", "flag: Solomon Islands"], [["U+1F1F8", "U+1F1E8"], "🇸🇨", "flag: Seychelles"], [["U+1F1F8", "U+1F1E9"], "🇸🇩", "flag: Sudan"], [["U+1F1F8", "U+1F1EA"], "🇸🇪", "flag: Sweden"], [["U+1F1F8", "U+1F1EC"], "🇸🇬", "flag: Singapore"], [["U+1F1F8", "U+1F1ED"], "🇸🇭", "flag: St. Helena"], [["U+1F1F8", "U+1F1EE"], "🇸🇮", "flag: Slovenia"], [["U+1F1F8", "U+1F1EF"], "🇸🇯", "flag: Svalbard & Jan Mayen"], [["U+1F1F8", "U+1F1F0"], "🇸🇰", "flag: Slovakia"], [["U+1F1F8", "U+1F1F1"], "🇸🇱", "flag: Sierra Leone"], [["U+1F1F8", "U+1F1F2"], "🇸🇲", "flag: San Marino"], [["U+1F1F8", "U+1F1F3"], "🇸🇳", "flag: Senegal"], [["U+1F1F8", "U+1F1F4"], "🇸🇴", "flag: Somalia"], [["U+1F1F8", "U+1F1F7"], "🇸🇷", "flag: Suriname"], [["U+1F1F8", "U+1F1F8"], "🇸🇸", "flag: South Sudan"], [["U+1F1F8", "U+1F1F9"], "🇸🇹", "flag: São Tomé & Príncipe"], [["U+1F1F8", "U+1F1FB"], "🇸🇻", "flag: El Salvador"], [["U+1F1F8", "U+1F1FD"], "🇸🇽", "flag: Sint Maarten"], [["U+1F1F8", "U+1F1FE"], "🇸🇾", "flag: Syria"], [["U+1F1F8", "U+1F1FF"], "🇸🇿", "flag: Eswatini"], [["U+1F1F9", "U+1F1E6"], "🇹🇦", "flag: Tristan da Cunha"], [["U+1F1F9", "U+1F1E8"], "🇹🇨", "flag: Turks & Caicos Islands"], [["U+1F1F9", "U+1F1E9"], "🇹🇩", "flag: Chad"], [["U+1F1F9", "U+1F1EB"], "🇹🇫", "flag: French Southern Territories"], [["U+1F1F9", "U+1F1EC"], "🇹🇬", "flag: Togo"], [["U+1F1F9", "U+1F1ED"], "🇹🇭", "flag: Thailand"], [["U+1F1F9", "U+1F1EF"], "🇹🇯", "flag: Tajikistan"], [["U+1F1F9", "U+1F1F0"], "🇹🇰", "flag: Tokelau"], [["U+1F1F9", "U+1F1F1"], "🇹🇱", "flag: Timor-Leste"], [["U+1F1F9", "U+1F1F2"], "🇹🇲", "flag: Turkmenistan"], [["U+1F1F9", "U+1F1F3"], "🇹🇳", "flag: Tunisia"], [["U+1F1F9", "U+1F1F4"], "🇹🇴", "flag: Tonga"], [["U+1F1F9", "U+1F1F7"], "🇹🇷", "flag: Turkey"], [["U+1F1F9", "U+1F1F9"], "🇹🇹", "flag: Trinidad & Tobago"], [["U+1F1F9", "U+1F1FB"], "🇹🇻", "flag: Tuvalu"], [["U+1F1F9", "U+1F1FC"], "🇹🇼", "flag: Taiwan"], [["U+1F1F9", "U+1F1FF"], "🇹🇿", "flag: Tanzania"], [["U+1F1FA", "U+1F1E6"], "🇺🇦", "flag: Ukraine"], [["U+1F1FA", "U+1F1EC"], "🇺🇬", "flag: Uganda"], [["U+1F1FA", "U+1F1F2"], "🇺🇲", "flag: U.S. Outlying Islands"], [["U+1F1FA", "U+1F1F3"], "🇺🇳", "flag: United Nations"], [["U+1F1FA", "U+1F1F8"], "🇺🇸", "flag: United States"], [["U+1F1FA", "U+1F1FE"], "🇺🇾", "flag: Uruguay"], [["U+1F1FA", "U+1F1FF"], "🇺🇿", "flag: Uzbekistan"], [["U+1F1FB", "U+1F1E6"], "🇻🇦", "flag: Vatican City"], [["U+1F1FB", "U+1F1E8"], "🇻🇨", "flag: St. Vincent & Grenadines"], [["U+1F1FB", "U+1F1EA"], "🇻🇪", "flag: Venezuela"], [["U+1F1FB", "U+1F1EC"], "🇻🇬", "flag: British Virgin Islands"], [["U+1F1FB", "U+1F1EE"], "🇻🇮", "flag: U.S. Virgin Islands"], [["U+1F1FB", "U+1F1F3"], "🇻🇳", "flag: Vietnam"], [["U+1F1FB", "U+1F1FA"], "🇻🇺", "flag: Vanuatu"], [["U+1F1FC", "U+1F1EB"], "🇼🇫", "flag: Wallis & Futuna"], [["U+1F1FC", "U+1F1F8"], "🇼🇸", "flag: Samoa"], [["U+1F1FD", "U+1F1F0"], "🇽🇰", "flag: Kosovo"], [["U+1F1FE", "U+1F1EA"], "🇾🇪", "flag: Yemen"], [["U+1F1FE", "U+1F1F9"], "🇾🇹", "flag: Mayotte"], [["U+1F1FF", "U+1F1E6"], "🇿🇦", "flag: South Africa"], [["U+1F1FF", "U+1F1F2"], "🇿🇲", "flag: Zambia"], [["U+1F1FF", "U+1F1FC"], "🇿🇼", "flag: Zimbabwe"]]], ["subdivision-flag", [[["U+1F3F4", "U+E0067", "U+E0062", "U+E0065", "U+E006E", "U+E0067", "U+E007F"], "🏴", "flag: England"], [["U+1F3F4", "U+E0067", "U+E0062", "U+E0073", "U+E0063", "U+E0074", "U+E007F"], "🏴", "flag: Scotland"], [["U+1F3F4", "U+E0067", "U+E0062", "U+E0077", "U+E006C", "U+E0073", "U+E007F"], "🏴", "flag: Wales"]]]]]]; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EmojiChars); /***/ }), /***/ 2948: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_emojipicker_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6683); /* harmony import */ var _css_emojipicker_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_emojipicker_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _EmojiAnims__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4670); /* harmony import */ var _Sprite__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9950); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function EmojiPicker() { var thisPicker = this; this._aliveTimeout = 90; this._assetRoot = this.attr('data-asset-root'); /*** * * @type {Sprite} */ this.$previewAnim = $('sprite.as-emoji-picker-preview-anim', this) .on('ready', this.eventHandler.previewAnimReady) .on('frame', this.eventHandler.previewAnimFrame); this.$previewAnim.loop = true; this.$previewAnim.src = this._assetRoot + '/anim/x120/' + _EmojiAnims__WEBPACK_IMPORTED_MODULE_2__/* ["default"][0][1] */ .Z[0][1]; this.$previewAnim.fps = 30; this.$desc = $('.as-emoji-picker-preview-desc', this); this.$shortcut = $('.as-emoji-picker-preview-shortcut', this); this.$desc.clearChild().addChild(_({ text: _EmojiAnims__WEBPACK_IMPORTED_MODULE_2__/* ["default"][0][2] */ .Z[0][2] })); this.$shortcut.clearChild().addChild(_({ text: _EmojiAnims__WEBPACK_IMPORTED_MODULE_2__/* ["default"][0][0] */ .Z[0][0] })); this.$list = $('.as-emoji-picker-list', this); this.$items = _EmojiAnims__WEBPACK_IMPORTED_MODULE_2__/* ["default"].reduce */ .Z.reduce(function (ac, it) { var itemElt = _({ tag: 'img', class: 'as-emoji-picker-item', props: { src: thisPicker._assetRoot + '/static/x20/' + it[1] } }).addTo(thisPicker.$list); itemElt.on('mouseenter', thisPicker.eventHandler.mouseenterItem.bind(thisPicker, it, itemElt)); itemElt.on('click', thisPicker.eventHandler.clickItem.bind(thisPicker, it)); ac[it[0]] = itemElt; return ac; }, {}); this.$attachook = _('attachhook').addTo(this).on('error', this.eventHandler.attach); } EmojiPicker.assetRoot = (function (){ if (location.hostname.match(/^.*(\.?absol\.cf|absol\.ddns\.net)$/) ||location.hostname.match(/^localhost$/) ) return 'https://absol.cf/emoji'; return '/emoji'; })(); EmojiPicker.tag = 'EmojiPicker'.toLowerCase(); EmojiPicker.render = function (data) { data = data || {}; data.assetRoot = data.assetRoot || EmojiPicker.assetRoot; return _({ class: 'as-emoji-picker', extendEvent: 'pick', attr: { 'data-asset-root': data.assetRoot }, child: [ { class: 'as-emoji-picker-preview', child: [ { class: '.as-emoji-picker-preview-anim-ctn', child: 'sprite.as-emoji-picker-preview-anim' }, '.as-emoji-picker-preview-desc', '.as-emoji-picker-preview-shortcut' ] }, { tag: 'bscroller', class: 'as-emoji-picker-list' } ] }); }; /** * @type {EmojiPicker} */ EmojiPicker.eventHandler = {}; EmojiPicker.eventHandler.attach = function () { this._aliveTimeout = 90; setTimeout(this.$previewAnim.play.bind(this.$previewAnim), 1); }; EmojiPicker.eventHandler.previewAnimReady = function () { this.$previewAnim.frames = { type: 'grid', col: 1, row: this.$previewAnim.texture.naturalHeight / this.$previewAnim.texture.naturalWidth }; this.$previewAnim.play(); }; EmojiPicker.eventHandler.previewAnimFrame = function () { if (this._aliveTimeout == 0) { var bound = this.getBoundingClientRect(); if (bound.width == 0) { this.$previewAnim.stop(); } else { this._aliveTimeout = 90; } } this._aliveTimeout--; }; EmojiPicker.eventHandler.mouseenterItem = function (itemData, itemElt, event) { if (this.$lastHoverItem == itemElt) return; this.$lastHoverItem = itemElt; this.$previewAnim.src = this._assetRoot + '/anim/x120/' + itemData[1]; this.$desc.clearChild().addChild(_({ text: itemData[2] })); this.$shortcut.clearChild().addChild(_({ text: itemData[0] })); }; EmojiPicker.eventHandler.clickItem = function (itemData, event) { this.emit('pick', { name: 'pick', key: itemData[0], target: this }, this); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(EmojiPicker); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EmojiPicker); /***/ }), /***/ 2917: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "$P": () => (/* binding */ ExpNode), /* harmony export */ "yb": () => (/* binding */ ExpTree), /* harmony export */ "uz": () => (/* binding */ ExpGroup), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony export ExpSearcher */ /* harmony import */ var _css_exptree_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3234); /* harmony import */ var _css_exptree_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_exptree_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3349); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7951); /* harmony import */ var absol_src_String_stringGenerate__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(1334); /* harmony import */ var _list_search__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(2551); /* harmony import */ var absol_src_String_stringUtils__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(2973); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install('toggler-ico', function () { var res = _( '<svg class="toggler-ico" width="14" height="14" version="1.1" viewBox="0 0 3.7042 3.7042" xmlns="http://www.w3.org/2000/svg" >' + ' <rect style="fill: transparent; stroke: none" x="0" y="0" width="3.7042" height="3.7042"></rect>' + ' <g transform="translate(0 -293.3)" class="toggle-close">' + ' <path d="m0.52917 293.82v2.6458l2.6458-1.3229z" />' + ' </g>' + ' <g transform="translate(0 -293.3)" class="toggle-open">' + ' <path d="m3.175 294.09-2.6458 2.1167h2.6458z"/>' + ' </g>' + '</svg>' ); return res; }); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install('remove-ico', function () { return _('<svg class="remove-ico" width="24" height="24" viewBox="0 0 24 24">\ <rect style="fill: transparent; stroke: none" x="0" y="0" width="24" height="24"></rect>\ <path class="close" d="M3,16.74L7.76,12L3,7.26L7.26,3L12,7.76L16.74,3L21,7.26L16.24,12L21,16.74L16.74,21L12,16.24L7.26,21L3,16.74" />\ <circle class="modified" cx="12" cy="12" r="10" />\ </svg>'); }); /*** * @extends AElement * @constructor */ function ExpNode() { var thisEN = this; this.$level = $('.absol-exp-node-level', this); this.$removeIcon = $('remove-ico', this) .on('click', function (event) { thisEN.emit('pressremove', { target: thisEN, type: 'pressremove' }, this); }); this.on('keydown', this.eventHandler.buttonKeydown); this.$toggleIcon = $('toggler-ico', this); this.on('click', (event) => { var toggleBound = this.$toggleIcon.getBoundingClientRect(); if (toggleBound.width > 0 && event.clientX <= toggleBound.right) { this.emit('presstoggle', (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* .copyEvent */ .FG)(event, { target: thisEN, type: 'pressremove' }), this); } else if (!absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].hitElement */ .ZP.hitElement(thisEN.$removeIcon, event)) { this.emit('press', (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* .copyEvent */ .FG)(event, { target: thisEN, type: 'press' }), this); } }); this.$iconCtn = $('div.absol-exp-node-ext-icon', this); this.$extIcon = $('img.absol-exp-node-ext-icon', this); this.$name = $('span.absol-exp-node-name', this); this.$desc = $('span.absol-exp-node-desc', this); (0,_utils__WEBPACK_IMPORTED_MODULE_2__.contenteditableTextOnly)(this.$name, function (text) { return text.replace(/[\\\/\|\?\:\<\>\*\r\n]/, '').trim(); }); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(thisEN, thisEN.$extIcon, 'extSrc', 'src'); this._level = 0; this.__isExpNode__ = true; return thisEN; } ExpNode.tag = 'expnode'; ExpNode.render = function () { return _({ tag: 'button', extendEvent: ['pressremove', 'press', 'presstoggle'], class: 'absol-exp-node', child: [ '.absol-exp-node-level', 'remove-ico', 'toggler-ico', 'img.absol-exp-node-ext-icon', 'div.absol-exp-node-ext-icon', 'span.absol-exp-node-name', 'span.absol-exp-node-desc' ] }); }; ExpNode.property = {}; ExpNode.property.icon = { set: function (value) { if (this.$iconP) { this.$iconP.remove(); this.$iconP = undefined; } if (value) { var newE; if (absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_5__/* ["default"].isDomNode */ .ZP.isDomNode(value)) { newE = value; } else { newE = _(value); } this.$iconP = newE; this.$iconCtn.addChild(newE); this._icon = value; } else { this._icon = undefined; } }, get: function () { return this._icon; } }; ExpNode.property.level = { set: function (value) { value = value || 0; if (value !== this.level) { this._level = value || 0; this.$level.innerHTML = ' '.repeat(this._level * 6); } }, get: function () { return this._level || 0; } }; ExpNode.property.name = { set: function (value) { value = value + ''; this._name = value; this.$name.clearChild(); if (value && value.length > 0) this.$name.addChild(_({ text: value })); }, get: function () { return this._name || ''; } }; ExpNode.property.desc = { set: function (value) { this._desc = (value || '') + ''; this.$desc.clearChild(); this.$desc.addChild(_({ text: this._desc })); }, get: function () { return this._desc || ''; } }; ExpNode.property.status = { set: function (value) { this.removeClass('status-open') .removeClass('status-close') .removeClass('status-modified') .removeClass('status-removable'); if (!value || value == 'none') { //todo } else if (value == 'close') { this.addClass('status-close') } else if (value == 'open') { this.addClass('status-open'); } else if (value == 'removable') { this.addClass('status-removable'); } else if (value == 'modified') { this.addClass('status-modified'); } else { throw new Error('Invalid status ' + value) } this._status = value; }, get: function () { return this._status; } } ExpNode.property.active = { set: function (value) { if (value) { this.addClass('as-active'); this.addClass('active'); } else { this.removeClass('as-active'); this.removeClass('active'); } }, get: function () { return this.hasClass('as-active'); } }; ExpNode.prototype.rename = function (resolveCallback, rejectCallback) { var self = this; var span = this.$name; var lastName = span.innerHTML; span.attr('contenteditable', 'true'); span.focus(); document.execCommand('selectAll', false, null); function keydowEventHandle(event) { var key = event.key; if (key == 'Enter') { event.preventDefault(); span.blur(); span.attr('contenteditable', undefined); } else if (key == "ESC") { event.preventDefault(); span.innerHTML = lastName; span.blur(); span.attr('contenteditable', undefined); } } function blurEventHandle(event) { finish(); var curentName = span.innerHTML.replace(/[\\\/\|\?\:\<\>\*\r\n]/, '').trim(); if (curentName == lastName) { rejectCallback && rejectCallback(); } else { if (curentName.length == 0) { span.innerHTML = lastName; rejectCallback && rejectCallback(); } else { var res = resolveCallback && resolveCallback(curentName); if (res === false) { span.innerHTML = lastName; } else if (res && res.then) { res.then(function (result) { if (result === false) { span.innerHTML = lastName; //faile } else { //success } }, function () { //reject value span.innerHTML = lastName; }) } else { //success } } } } function finish() { span.off('keydown', keydowEventHandle); span.off('blur', blurEventHandle); $(document.body).once('click', function () { setTimeout(function () { span.attr('contenteditable', undefined); }, 2); }); } span.on('keydown', keydowEventHandle); span.on('blur', blurEventHandle); }; ExpNode.prototype.findNodeBefore = function () { var tree = this.parentElement; var root; var prevTree; var res = null; if (tree.__isExpTree__) { root = tree.getRoot(); root.visitRecursive(function (cTree) { if (cTree === tree) { res = prevTree; } prevTree = cTree; }) } return res && res.getNode(); }; ExpNode.prototype.findNodeAfter = function () { var tree = this.parentElement; var root; var prevTree; var res = null; if (tree.__isExpTree__) { root = tree.getRoot(); root.visitRecursive(function (cTree) { if (prevTree === tree) { res = cTree; } prevTree = cTree; }) } return res && res.getNode(); }; ExpNode.eventHandler = {}; /**** * * @param {KeyboardEvent} event */ ExpNode.eventHandler.buttonKeydown = function (event) { if (event.target === this) { if (!event.metaKey && !event.shiftKey && !event.ctrlKey && !event.altKey) { var destNode; var tree = this.parentElement; var parentTree = tree && tree.getParent(); switch (event.key) { case 'ArrowLeft': if (tree.status === 'open') { tree.status = 'close'; tree.notifyStatusChange(); } else { destNode = parentTree && parentTree.getNode(); } break; case 'ArrowRight': if (tree.status === 'close') { tree.status = 'open'; tree.notifyStatusChange(); } else { destNode = this.findNodeAfter(); } break; case 'ArrowUp': destNode = this.findNodeBefore(); break; case 'ArrowDown': destNode = this.findNodeAfter(); break; case 'Space': this.click(); break; } if (destNode) { destNode.focus(); event.preventDefault(); } } } }; /*** * @extends AElement * @constructor */ function ExpTree() { var thisET = this; this.$node = $('expnode', this) .on('press', function (event) { thisET.emit('press', Object.assign({}, { target: thisET, node: this, type: 'press' }, event), this); }) .on('pressremove', function (event) { thisET.emit('pressremove', Object.assign({}, { target: thisET, node: this, type: 'pressremove' }, event), this); }) .on('presstoggle', this.eventHandler.nodePressToggle); this.$itemsContainer = $('.absol-exp-items', thisET); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$node, ['desc', 'name', 'title', 'extSrc', 'active', 'icon']); this.__isExpTree__ = true; this._level = 0; } ExpTree.tag = 'ExpTree'.toLowerCase(); ExpTree.render = function () { return _({ class: 'absol-exp-tree', extendEvent: ['press', 'pressremove', 'statuschange'], child: [ 'expnode', '.absol-exp-items' ] }); }; ExpTree.property = {}; ExpTree.property.level = { set: function (value) { value = value || 0; if (value != this.level) { this.$node.level = value; Array.prototype.forEach.call(this.$itemsContainer.childNodes, function (e) { e.level = value + 1; }) } }, get: function () { return this.$node.level; } }; ExpTree.property.status = { set: function (value) { this.$node.status = value; if (value != 'open') { this.addClass('hide-children'); } else { this.removeClass('hide-children'); } }, get: function () { return this.$node.status; } }; ['findChildBefore', 'findChildAfter', 'removeChild', 'clearChild'] .forEach(function (key) { ExpTree.prototype[key] = function () { this.$itemsContainer[key].apply(this.$itemsContainer, arguments); } }); ExpTree.prototype.addChild = function (child) { if (!child.__isExpTree__) throw new Error('Child node must be a ExpTree'); child.level = this.level + 1; this.$itemsContainer.addChild(child); }; ExpTree.prototype.addChildBefore = function (child, at) { child.level = this.level + 1; this.$itemsContainer.addChildBefore(child, at); }; ExpTree.prototype.addChildAfter = function (child, at) { child.level = this.level + 1; this.$itemsContainer.addChildAfter(child, at); }; /**** * * @return {ExpTree} */ ExpTree.prototype.getParent = function () { var current = this.parentNode; while (current) { if (current.__isExpTree__) break; current = current.parentNode; } return current; }; /*** * * @return {ExpTree} */ ExpTree.prototype.getRoot = function () { var parent = this.getParent(); if (!parent) return this; return parent.getRoot(); } ExpTree.prototype.getNode = function () { return this.$node; }; ExpTree.prototype.getChildren = function () { return Array.apply(null, this.$itemsContainer.childNodes); }; /*** * * @param {function(tree: ExpTree): void} cb */ ExpTree.prototype.visitRecursive = function (cb) { cb(this); if (this.status === 'open') Array.prototype.forEach.call(this.$itemsContainer.childNodes, function (child) { child.visitRecursive(cb); }); }; ExpTree.prototype.getPath = function () { var path = []; var current = this; while (current) { path.push(current.name); current = current.getParent(); } return path.reverse(); }; ExpTree.prototype.accessByPath = function (path) { if (path.length == 0) return this; var childs = this.getChildren(); var res; for (var i = 0; i < childs.length; ++i) { if (childs[i].name == path[0]) { res = childs[i].accessByPath(path.slice(1)); break; } } return res; }; ExpTree.prototype.toggle = function () { switch (this.status) { case 'close': this.status = 'open'; break; case 'open': this.status = 'close'; break; } }; ExpTree.prototype.notifyStatusChange = function (props) { this.emit('statuschange', Object.assign({ type: 'statuschange', target: this }, props), this); }; ExpTree.eventHandler = {}; ExpTree.eventHandler.nodePressToggle = function (event) { this.toggle(); this.notifyStatusChange({ originEvent: event }); }; /*** * @extends ExpTree * @constructor */ function ExpGroup() { this.addClass('as-exp-group'); this.__isExpTree__ = true; this.name = ''; } ExpGroup.tag = 'ExpGroup'.toLowerCase(); ExpGroup.render = function () { return _('div'); }; /*** * * @param {function(tree: ExpTree): void} cb */ ExpGroup.prototype.visitRecursive = function (cb) { Array.prototype.forEach.call(this.childNodes, function (child) { child.visitRecursive(cb); }); }; ExpGroup.prototype.getParent = function () { return null; }; ExpGroup.prototype.getRoot = function () { return this; }; ExpGroup.prototype.getNode = function () { return null; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ExpNode); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ExpTree); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ExpGroup); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ExpTree); /** * * @param {ExpTree|AElement} elt * @param {{inputElt: SearchTextInput}=} opt * @constructor */ function ExpSearcher(elt, opt) { this.elt = elt; this.cache = {}; this.prevHash = null; this.searching = false; this.state = {}; this.ev_stopTyping = this.ev_stopTyping.bind(this); this.inputElt = opt && opt.inputElt; } ExpSearcher.prototype.reset = function () { if (!this.searching) return; this.cache = {}; this.searching = false; this.elt.removeClass('as-searching') var visit = treeNode => { treeNode.removeClass('as-in-search-result').removeStyle('order'); if (this.state[treeNode.id]) { if (treeNode.status === 'open' || treeNode.status === 'close' && this.state[treeNode.id] !== 'none') { treeNode.status = this.state[treeNode.id]; } } this.getChildrenOf(treeNode).forEach(c => visit(c)); } visit(this.elt); }; ExpSearcher.prototype.backupState = function () { this.state = {}; var visit = treeNode => { if (!treeNode.id) treeNode.id = (0,absol_src_String_stringGenerate__WEBPACK_IMPORTED_MODULE_7__.randomIdent)(5); this.state[treeNode.id] = treeNode.status; this.getChildrenOf(treeNode).forEach(c => visit(c)); } visit(this.elt); }; /** * * @param {ExpTree|AElement} nd * @returns {Array<ExpTree|AElement>} */ ExpSearcher.prototype.getChildrenOf = function (nd) { if (nd.getChildren) return nd.getChildren(); return Array.prototype.slice.call(nd.childNodes); }; /** * * @param {ExpTree|AElement} nd * @returns {ExpTree|AElement} */ ExpSearcher.prototype.getParentOf = function (nd) { if (nd.getParent) return nd.getParent(); return nd.parentElement; }; ExpSearcher.prototype.query = function (text) { text = text || ''; text = text.trim(); if (text.length === 0) { this.reset(); return; } if (!this.searching) { this.backupState(); this.searching = true; } var newHash = 0; var makeItem = treeNode => { if (!treeNode.id) treeNode.id = (0,absol_src_String_stringGenerate__WEBPACK_IMPORTED_MODULE_7__.randomIdent)(5); if (!treeNode.__searchItem__) { treeNode.__searchItem__ = { text: treeNode.name.replace(/[_-]/g, ' '), value: treeNode.id }; (0,_list_search__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .ZP)(treeNode.__searchItem__); } var item = treeNode.__searchItem__; newHash = (0,absol_src_String_stringUtils__WEBPACK_IMPORTED_MODULE_9__/* .stringHashCode */ .$)(newHash + item.text); var children = this.getChildrenOf(treeNode); if (children.length > 0) { item.items = children.map(c => makeItem(c)); } else { delete item.items; } return item; } var items = [makeItem(this.elt)]; if (newHash !== this.prevHash) { this.prevHash = newHash; this.cache = {}; } var searchRes = this.cache[text] || (0,_list_search__WEBPACK_IMPORTED_MODULE_8__/* .searchTreeListByText */ .$l)(text, items); var dict = searchRes.reduce(function cb(ac, cr, i) { ac[cr.value] = i; if (cr.items) cr.items.reduce(cb, ac); return ac; }, {}); var visit = treeNode => { if (treeNode.id in dict) { treeNode.addClass('as-in-search-result').addStyle('order', dict[treeNode.id]); } else { treeNode.removeClass('as-in-search-result').removeStyle('order'); } this.getChildrenOf(treeNode).forEach(c => visit(c)); }; visit(this.elt); this.elt.addClass('as-searching'); }; ExpSearcher.prototype.ev_stopTyping = function () { this.query(this.inputElt.value); }; ExpSearcher.prototype.destroy = function () { this.inputElt = null; this.query(''); } Object.defineProperty(ExpSearcher.prototype, 'inputElt', { set: function (elt) { if (this._inputElt) { this._inputElt.off('stoptyping', this.ev_stopTyping); this._inputElt = null; } if (elt) { this._inputElt = elt; elt.on('stoptyping', this.ev_stopTyping); } }, get: function () { return this._inputElt; } }) /***/ }), /***/ 3929: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_flexiconbutton_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(279); /* harmony import */ var _css_flexiconbutton_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_flexiconbutton_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /** * @extends AElement * @constructor */ function FlexiconButton() { this._icon = null; this.$content = $('.as-flexicon-button-content', this); this.$iconCtn = $('.as-flexicon-button-icon-container', this); this.$textCtn = $('.as-flexicon-button-text-container', this); } FlexiconButton.tag = 'FlexiconButton'.toLowerCase(); FlexiconButton.render = function () { return _({ tag: 'button', class: 'as-flexicon-button', child: { class: 'as-icon-button-table-box', child: { class: 'as-flexicon-button-content', child: [ '.as-flexicon-button-icon-container', '.as-flexicon-button-text-container', ] } } }); }; FlexiconButton.property = {}; FlexiconButton.property.icon = { set: function (value) { value = value || null; this._icon = value; this.$iconCtn.clearChild(); if (value !== null) { this.$iconCtn.addChild(_(value)); } }, get: function () { return this._icon; } }; FlexiconButton.property.text = { /*** * * @param {string| {mlKey:string}|*} value */ set: function (value) { value = value || null; this._text = value; this.$textCtn.clearChild(); this.$textCtn.attr('data-ml-key', undefined); if (value === null || value === undefined) { } else if (typeof value === "object") { if (value.mlKey) { this.$textCtn.attr('data-ml-key', value.mlKey); } } else { this.$textCtn.addChild(_({ text: value + '' })); } }, get: function () { return this._text; } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(FlexiconButton); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (FlexiconButton); /***/ }), /***/ 7094: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_follower_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1415); /* harmony import */ var _css_follower_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_follower_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(2759); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7951); /* harmony import */ var absol_src_HTML5_AttachHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(5675); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(1477); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function Follower() { this.$attachhook = _('attachhook', this) .addTo(this) .on('attached', function () { this.requestUpdateSize(); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].addToResizeSystem */ .ZP.addToResizeSystem(this); }); this.$attachhook.requestUpdateSize = this.updatePosition.bind(this); this.$followTarget = undefined; this.$scrollTrackElts = []; this._scrollTrackEventHandler = undefined; this._anchor = Follower.ANCHOR_PRIORITY; this.defineEvent(['updateposition', 'preupdateposition']); /*** * @name followTarget * @type {AElement} * @memberOf Follower# */ } Follower.prototype.cancelWaiting = function () { Array.prototype.forEach.call(this.childNodes, function (elt) { if (elt.emit && elt.isSupportedEvent('attached') && elt.cancelWaiting()) { elt.cancelWaiting(); } }); }; Follower.prototype.revokeResource = function () { this.cancelWaiting(); this.followTarget = null; }; Follower.tag = 'Follower'.toLowerCase(); Follower.render = function () { return _('.absol-follower'); }; Follower.prototype.clearChild = function () { var children = Array.prototype.slice.call(this.children); var attachhookElt = this.$attachhook; children.forEach(function (elt) { if (elt !== attachhookElt) elt.remove(); }); return this; }; Follower.prototype.addTo = function (elt) { if (elt.addChild) { elt.addChild(this); } else if (elt.appendChild) { elt.appendChild(this); } if (this.isDescendantOf(document.body)) { Array.prototype.forEach.call(this.childNodes, function (elt) { if (elt.emit && elt.isSupportedEvent('attached')) { elt.resetState(); elt.emit('attached'); } }); } return this; }; Follower.prototype.selfRemove = function () { Array.prototype.forEach.call(this.childNodes, function (elt) { if (elt.emit && elt.isSupportedEvent('attached')) { elt.cancelWaiting(); } }); this.remove(); return this; }; //Todo: remove child, find child.... /** * X = $target.x + F[anchor_index][0] * $target.width + F[anchor_index][1] * $content.width * Y = $target.y + F[anchor_index][2] * $target.height + F[anchor_index][3] * $content.height */ Follower.ANCHOR_FACTORS = [ [1, 0, 0, 0],//0 [0, 0, 1, 0],//1 [1, -1, 1, 0],//2 [0, -1, 0, 0],//3 [0, -1, 1, -1],//4 [1, -1, 0, -1],//5 [0, 0, 0, -1],//6 [1, 0, 1, -1],//7 [1, 0, 0.5, -0.5],//8 [0.5, -0.5, 1, 0],//9 [0, -1, 0.5, -0.5],//10 [0.5, -0.5, 0, -1],//11 [1, 0, 1, 0],//12 [0, -1, 1, 0],//13 [0, -1, 0, -1],//14 [1, 0, 0, -1],//15 ]; Follower.ANCHOR_PRIORITY = [1, 6, 2, 5, 0, 7, 3, 4, 9, 11, 8, 10, 12, 15, 13, 14]; Follower.prototype.updatePosition = function () { if (!this.$followTarget) return; this.emit('preupdateposition', { target: this }, this); if (!this.$followTarget) return;// target is removed var targetBound = this.$followTarget.getBoundingClientRect(); var screenSize = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].getScreenSize */ .ZP.getScreenSize(); var outRect = new absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(0, 0, screenSize.width, screenSize.height); var bound = this.getBoundingClientRect(); var x = 0; var y = 0; var score; var anchors = this._lastAnchor === undefined ? this.anchor : [this._lastAnchor].concat(this.anchor); var factor; var bestX, bestY, bestScore = -100000; var newContentRect; var bestAnchor; for (var i = 0; i < anchors.length; ++i) { factor = Follower.ANCHOR_FACTORS[anchors[i]]; x = targetBound.left + factor[0] * targetBound.width + factor[1] * bound.width; y = targetBound.top + factor[2] * targetBound.height + factor[3] * bound.height; newContentRect = new absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z(x, y, bound.width, bound.height); score = newContentRect.collapsedSquare(outRect); if (score - 10 > bestScore) { bestAnchor = anchors[i]; bestScore = score; bestX = x; bestY = y; } } if (this._lastAnchor !== bestAnchor) { this.removeClass('as-anchor-' + this._lastAnchor); this._lastAnchor = bestAnchor; this.addClass('as-anchor-' + this._lastAnchor); } this.addStyle({ left: bestX + 'px', top: bestY + 'px' }); this.emit('updateposition', { target: this }, this); }; Follower.prototype.refollow = function () { if (!this.$followTarget) return; this.updatePosition(); this.addClass('following'); if (this._scrollTrackEventHandler) this.unfollow(); this._scrollTrackEventHandler = this.updatePosition.bind(this); this.$scrollTrackElts = []; var trackElt = this.$followTarget; while (trackElt) { if (trackElt.addEventListener) trackElt.addEventListener('scroll', this._scrollTrackEventHandler, false); else trackElt.attachEvent('onscroll', this._scrollTrackEventHandler, false); this.$scrollTrackElts.push(trackElt); trackElt = trackElt.parentElement; } if (document.addEventListener) { document.addEventListener('scroll', this._scrollTrackEventHandler, false); } else { document.attachEvent('onscroll', this._scrollTrackEventHandler, false); } this.$scrollTrackElts.push(document); }; Follower.prototype.unfollow = function () { if (!this._scrollTrackEventHandler) return;// nothing to do this.removeClass('following'); var trackElt; for (var i = 0; i < this.$scrollTrackElts.length; ++i) { trackElt = this.$scrollTrackElts[i]; if (trackElt.removeEventListener) trackElt.removeEventListener('scroll', this._scrollTrackEventHandler, false); else trackElt.dettachEvent('onscroll', this._scrollTrackEventHandler, false); } this.$scrollTrackElts = []; this._scrollTrackEventHandler = undefined; }; Follower.prototype.revokeResource = function () { this.$attachhook.cancelWaiting(); this.followTarget = null; while (this.lastChild) { (0,_utils__WEBPACK_IMPORTED_MODULE_6__.revokeResource)(this.lastChild); this.removeChild(this.lastChild); } }; Follower.property = {}; Follower.property.followTarget = { set: function (elt) { if (elt === null || elt === undefined || !elt) { this.unfollow(); this.$followTarget = undefined; return; } else if (typeof elt == 'string') { elt = $(elt) || document.getElementById(elt); } if (absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].isDomNode */ .ZP.isDomNode(elt)) { this.$followTarget = elt; this._lastAnchor = undefined; this.refollow(); } else throw new Error("Invalid element"); }, get: function () { return this.$followTarget; } } Follower.property.anchor = { set: function (value) { value = value || Follower.ANCHOR_PRIORITY; if (value == 'auto') value = Follower.ANCHOR_PRIORITY; if (typeof value == null) value = [value]; if (!(value instanceof Array)) throw new Error('Invalid anchor ' + value); value = value.map(function (x) { x = Math.floor(x); if (x >= 0 && x < Follower.ANCHOR_FACTORS.length) { return x; } else throw new Error("Invalid anchor: " + x); }); this._anchor = value; this._lastAnchor = undefined; this.updatePosition(); }, get: function () { return this._anchor; } } _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Follower); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Follower); /***/ }), /***/ 655: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_hanger_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8859); /* harmony import */ var _css_hanger_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_hanger_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(557); /* harmony import */ var absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9399); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /**** * @extends AElement * @constructor */ function Hanger() { this.addClass('as-hanger'); this.defineEvent(['predrag', 'dragstart', 'drag', 'dragend', 'draginit', 'dragdeinit']);//predrag is draginit this._hangOn = 0; this._hangerPointerData = null; this.on2({ mousedown: this.eventHandler.hangerPointerDown, touchstart: this.eventHandler.hangerPointerDown, }); this._touchEvents = { touchend: this.eventHandler.hangerPointerFinish, touchcancel: this.eventHandler.hangerPointerFinish, touchmove: this.eventHandler.hangerPointerMove } this._mouseEvents = { mouseup: this.eventHandler.hangerPointerFinish, mouseleave: this.eventHandler.hangerPointerFinish, mousemove: this.eventHandler.hangerPointerMove }; } Hanger.tag = 'hanger'; Hanger.render = function () { return _('div'); }; Hanger.prototype.on2 = function () { if (arguments.length == 1) { for (var name in arguments[0]) { Hanger.prototype.on2.call(this, name, arguments[0][name]); } } else if (arguments.length == 2) { this.addEventListener(arguments[0], arguments[1], absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_3__/* ["default"].supportPassiveEvent */ .Z.supportPassiveEvent ? { passive: false } : true); } }; Hanger.prototype.off2 = function () { if (arguments.length == 1) { for (var name in arguments[0]) { Hanger.prototype.off2.call(this, name, arguments[0][name]); } } else if (arguments.length == 2) { this.removeEventListener(arguments[0], arguments[1], absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_3__/* ["default"].supportPassiveEvent */ .Z.supportPassiveEvent ? { passive: false } : true); } }; Hanger.property = {}; /** * @type {Hanger} */ Hanger.property.hangOn = { set: function (value) { if (!(value > 0)) value = 0; this._hangOn = value; }, get: function () { return this._hangOn; } }; /** * @type {Hanger} */ Hanger.eventHandler = {}; Hanger.eventHandler.hangerPointerDown = function (event) { if (this._hangerPointerData) return; var bound = this.getBoundingClientRect(); var startingPoint; var isTouch = event.type === 'touchstart'; var pointerIdent = -1; var target; if (isTouch) { var touch = event.changedTouches[0]; target = touch.target; pointerIdent = touch.identifier; startingPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(touch.clientX, touch.clientY); } else { startingPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(event.clientX, event.clientY); target = event.target; } var offsetVec = startingPoint.sub(new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(bound.left, bound.top)); this._hangerPointerData = { state: 0, isTouch: isTouch, bound: bound, startingPoint: startingPoint, offsetVec: offsetVec, pointerIdent: pointerIdent, target: target }; var preDragEvent = { type: 'draginit', originEvent: event, isTouch: isTouch, bound: bound, startingPoint: startingPoint, currentPoint: startingPoint, offsetVec: offsetVec, pointerIdent: pointerIdent, canceled: false, cancel: function () { this.canceled = true; }, clientX: startingPoint.x, clientY: startingPoint.y, target: target, preventDefault: function () { event.preventDefault(); } }; this.emit('draginit', preDragEvent, this); this.emit('predrag', Object.assign(preDragEvent, { type: 'predrag' }), this); if (preDragEvent.canceled) { this._hangerPointerData = null; return; } if (isTouch) this.on2.call(document, this._touchEvents) else this.on2.call(document, this._mouseEvents); }; Hanger.eventHandler.hangerPointerMove = function (event) { var pointerData = this._hangerPointerData; var isTouch = pointerData.isTouch; var pointerIdent = -2; var currentPoint; if (isTouch) { var touch = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* .findChangedTouchByIdent */ .VY)(event, pointerData.pointerIdent); if (touch) { pointerIdent = touch.identifier; currentPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(touch.clientX, touch.clientY); } } else { currentPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(event.clientX, event.clientY); pointerIdent = -1; } if (pointerIdent != pointerData.pointerIdent) return; pointerData.currentPoint = currentPoint; if (pointerData.state == 0) { var distance = currentPoint.sub(pointerData.startingPoint).abs(); if (distance >= this._hangOn) { var dragStartEvent = { type: 'dragstart', originEvent: event, isTouch: isTouch, bound: pointerData.bound, startingPoint: pointerData.startingPoint, offsetVec: pointerData.offsetVec, pointerIdent: pointerIdent, currentPoint: currentPoint, target: pointerData.target, clientX: currentPoint.x, clientY: currentPoint.y, preventDefault: function () { event.preventDefault(); } }; pointerData.trackedScrollers = (() => { var res = []; var c = this._hangerPointerData.target; while (c) { c.addEventListener('scroll', this.eventHandler.trackingScroll); res.push(c); c = c.parentElement; } document.addEventListener('scroll', this.eventHandler.trackingScroll); res.push(document); return res; })(); pointerData.state = 1; this.emit('dragstart', dragStartEvent, this); } } if (pointerData.state === 1) { var dragEvent = { type: 'drag', originEvent: event, isTouch: isTouch, bound: pointerData.bound, startingPoint: pointerData.startingPoint, offsetVec: pointerData.offsetVec, pointerIdent: pointerIdent, currentPoint: currentPoint, target: pointerData.target, clientX: currentPoint.x, clientY: currentPoint.y, preventDefault: function () { event.preventDefault(); } }; this.emit('drag', dragEvent, this); } }; Hanger.eventHandler.hangerPointerFinish = function (event) { var pointerData = this._hangerPointerData; var isTouch = event.type === 'touchend'; var dragEndEvent; if (pointerData.isTouch !== isTouch) return; var pointerIdent = -2; var currentPoint; if (isTouch) { var touch = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* .findChangedTouchByIdent */ .VY)(event, pointerData.pointerIdent); if (touch) { pointerIdent = touch.identifier; currentPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(touch.clientX, touch.clientY); } } else { currentPoint = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(event.clientX, event.clientY); pointerIdent = -1; } if (pointerIdent !== pointerData.pointerIdent) return; if (pointerData.state === 1) { pointerData.trackedScrollers.forEach(elt => elt.removeEventListener('scroll', this.eventHandler.trackingScroll)); dragEndEvent = { type: 'dragend', originEvent: event, isTouch: isTouch, bound: pointerData.bound, startingPoint: pointerData.startingPoint, offsetVec: pointerData.offsetVec, pointerIdent: pointerIdent, currentPoint: currentPoint, target: pointerData.target, clientX: currentPoint.x, clientY: currentPoint.y, preventDefault: function () { event.preventDefault(); } }; this.emit('dragend', dragEndEvent, this); } this._hangerPointerData = null; if (isTouch) this.off2.call(document, this._touchEvents) else this.off2.call(document, this._mouseEvents); this.emit('dragdeinit', { type: 'dragdeinit', originEvent: event, isTouch: isTouch, bound: pointerData.bound, startingPoint: pointerData.startingPoint, offsetVec: pointerData.offsetVec, pointerIdent: pointerIdent, currentPoint: currentPoint, target: pointerData.target, clientX: currentPoint.x, clientY: currentPoint.y, }); }; Hanger.eventHandler.trackingScroll = function (event) { var pointerData = this._hangerPointerData; var currentPoint = pointerData.currentPoint; var dragEvent = { type: 'drag', originEvent: event, isTouch: false, bound: pointerData.bound, startingPoint: pointerData.startingPoint, offsetVec: pointerData.offsetVec, pointerIdent: pointerData.pointerIdent, currentPoint: currentPoint, target: pointerData.target, clientX: currentPoint.x, clientY: currentPoint.y, isScrolling: true, preventDefault: function () { // event.preventDefault(); } }; this.emit('drag', dragEvent, this); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Hanger); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Hanger); /***/ }), /***/ 2380: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Ty": () => (/* binding */ EmojiMutedIcon), "Tj": () => (/* binding */ FontColorIcon), "Bm": () => (/* binding */ ImportantOutlineIcon), "CY": () => (/* binding */ MdiStoreMarkerOutline), "V4": () => (/* binding */ ProcedureOutlineIcon), "Vt": () => (/* binding */ ProcessOutlineIcon), "i_": () => (/* binding */ SpinnerIco) }); // UNUSED EXPORTS: CityIcon, ConfigurationFormOutlineIcon, CountryIcon, DataTypeConfiguratorOutlineIcon, FunctionManagerIcon, InputFormOutlineIcon, InsertColLeftIcon, InsertColRightIcon, MobileFormEditOutlineIcon, MobileInputFormOutlineIcon, MobileOutputFormOutlineIcon, OutputFormOutlineIcon, TemplateIcon, TimeBasedPayrollReportIcon, WindowsFormEditOutlineIcon // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/spinner.tpl /* harmony default export */ const spinner = ("<svg class=\"as-spinner-ico\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" viewBox=\"0 0 100 100\" preserveAspectRatio=\"xMidYMid\">\r\n <g><circle cx=\"73.801\" cy=\"68.263\" fill=\"#e15b64\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"0s\"></animateTransform>\r\n </circle><circle cx=\"68.263\" cy=\"73.801\" fill=\"#f47e60\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.062s\"></animateTransform>\r\n </circle><circle cx=\"61.481\" cy=\"77.716\" fill=\"#f8b26a\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.125s\"></animateTransform>\r\n </circle><circle cx=\"53.916\" cy=\"79.743\" fill=\"#abbd81\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.187s\"></animateTransform>\r\n </circle><circle cx=\"46.084\" cy=\"79.743\" fill=\"#849b87\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.25s\"></animateTransform>\r\n </circle><circle cx=\"38.519\" cy=\"77.716\" fill=\"#6492ac\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.312s\"></animateTransform>\r\n </circle><circle cx=\"31.737\" cy=\"73.801\" fill=\"#637cb5\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.375s\"></animateTransform>\r\n </circle><circle cx=\"26.199\" cy=\"68.263\" fill=\"#6a63b6\" r=\"4\">\r\n <animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;360 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\" begin=\"-0.437s\"></animateTransform>\r\n </circle><animateTransform attributeName=\"transform\" type=\"rotate\" calcMode=\"spline\" values=\"0 50 50;0 50 50\" times=\"0;1\" keySplines=\"0.5 0 0.5 1\" repeatCount=\"indefinite\" dur=\"1.4925373134328357s\"></animateTransform></g>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/mdi_store_marker_outline.tpl /* harmony default export */ const mdi_store_marker_outline = ("<svg viewBox=\"0 0 24 24\">\r\n <path fill=\"currentColor\" d=\"M20 6H4V4H20V6M14.3 12C13.5 12.96 13 14.18 13 15.5C13 16.64 13.43 17.86 14 19V20H4V14H3V12L4 7H20L20.7 10.5C20.04 10.18 19.32 10 18.56 10L18.36 9H5.64L5.04 12H14.3M12 14H6V18H12V14M22 15.5C22 18.1 18.5 22 18.5 22S15 18.1 15 15.5C15 13.6 16.6 12 18.5 12S22 13.6 22 15.5M19.7 15.6C19.7 15 19.1 14.4 18.5 14.4S17.3 14.9 17.3 15.6C17.3 16.2 17.8 16.8 18.5 16.8S19.8 16.2 19.7 15.6Z\" />\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/font_color.tpl /* harmony default export */ const font_color = ("<svg height=\"100%\" width=\"100%\" viewBox=\"0,0,2048,2048\" focusable=\"false\">\r\n<path style=\"fill:currentColor\" shape-rendering=\"optimizeQuality\" type=\"path\" class=\"as-font-color-text\" d=\"M 1504 1408 l -156 -392 h -603 l -152 392 h -145 l 536 -1408 h 132 l 533 1408 m -602 -1236 h -4 l -254 725 h 515 m 744 639 v 512 h -2048 v -512 z\"></path>\r\n<path shape-rendering=\"optimizeQuality\" type=\"path\" class=\"as-font-color-contract\" d=\"M 2048 1536 v 512 h -2048 v -512 m 1920 128 h -1792 v 256 h 1792 z\"></path>\r\n<path shape-rendering=\"optimizeQuality\" type=\"path\" class=\"as-font-color-value\" d=\"M 1984 1984 h -1920 v -384 h 1920 z\"></path>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/insert_col_left.tpl /* harmony default export */ const insert_col_left = ("<svg width=\"24px\" height=\"24px\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path style=\"fill:currentColor\" d=\"M20 3c.552 0 1 .448 1 1v16c0 .552-.448 1-1 1h-6c-.552 0-1-.448-1-1V4c0-.552.448-1 1-1h6zm-1 2h-4v14h4V5zM6 7c2.761 0 5 2.239 5 5s-2.239 5-5 5-5-2.239-5-5 2.239-5 5-5zm1 2H5v1.999L3 11v2l2-.001V15h2v-2.001L9 13v-2l-2-.001V9z\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/insert_col_right.tpl /* harmony default export */ const insert_col_right = ("<svg width=\"24px\" height=\"24px\" viewBox=\"0 0 24 24\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path style=\"fill:currentColor\" d=\"M10 3c.552 0 1 .448 1 1v16c0 .552-.448 1-1 1H4c-.552 0-1-.448-1-1V4c0-.552.448-1 1-1h6zM9 5H5v14h4V5zm9 2c2.761 0 5 2.239 5 5s-2.239 5-5 5-5-2.239-5-5 2.239-5 5-5zm1 2h-2v1.999L15 11v2l2-.001V15h2v-2.001L21 13v-2l-2-.001V9z\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/process_outline.tpl /* harmony default export */ const process_outline = ("<svg class=\"process-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"24px\" height=\"24px\">\r\n<path style=\"stroke:none;fill:currentColor\" d=\"M12,15.9h-.4c-2.2,0-4-1.8-4-4s1.8-4,4-4,4.2,1.9,4,4.4c-1.7.6-3,1.9-3.6,3.6M13.6,11.9c0-1.1-.9-2-2-2s-2,.9-2,2,.9,2,2,2,2-.9,2-2M22.6,19.3c0,0,.1.2,0,.3l-1,1.8c0,0-.2.1-.3,0l-1.2-.5c-.3.2-.6.4-.9.5l-.2,1.3c0,.1-.1.2-.2.2h-2.1c-.1,0-.2,0-.2-.2l-.2-1.3c-.3-.1-.7-.3-.9-.6l-1.2.5c0,0-.2,0-.3,0l-1-1.8c0,0,0-.2,0-.3l1.1-.8c0-.2,0-.3,0-.5s0-.4,0-.6l-1-.8c0,0-.1-.2,0-.3l1.1-1.8c0,0,.2-.1.3,0l1.2.5h0c.3-.2.5-.4.9-.5h0s.2-1.3.2-1.3c0-.1.1-.2.2-.2h2.1c.1,0,.2,0,.2.2l.2,1.3h0c.3.1.6.3.9.5h0s1.2-.5,1.2-.5c0,0,.2,0,.3,0l1,1.8c0,0,0,.2,0,.3l-1.1.8h0c0,.2,0,.4,0,.5s0,.3,0,.5h0s1.1.8,1.1.8ZM17.8,16.5c-.8,0-1.5.7-1.5,1.5s.7,1.5,1.5,1.5,1.5-.7,1.5-1.5-.7-1.5-1.5-1.5ZM21.4,8.7l-2-3.5c-.1-.2-.4-.2-.6-.2l-2.5,1c-.5-.4-1.1-.8-1.7-1l-.4-2.7c0-.2-.3-.4-.5-.4h-4c-.3,0-.5.2-.5.4l-.4,2.7c-.6.3-1.2.6-1.7,1l-2.5-1c-.2,0-.5,0-.6.2l-2,3.5c0,.2,0,.5,0,.6l2.1,1.6v2l-2.1,1.7c0,.1-.2.4,0,.6l2,3.5c0,.2.4.2.6.2l2.5-1c.5.4,1.1.8,1.7,1l.4,2.6c0,.2.3.4.5.4h3.4c-.5-.6-.8-1.1-1.1-1.9h-1.1l-.4-2.6c-1.2-.3-2.2-.9-3-1.8l-2.4,1-.8-1.3,2.1-1.6c-.4-1.2-.4-2.4,0-3.6l-2.1-1.6.8-1.3,2.4,1c.7-.9,1.8-1.6,3-1.8l.4-2.6h1.5l.4,2.6c1.2.3,2.2.9,3,1.8l2.4-1,.8,1.3-2.1,1.6c.2.6.3,1.2.3,1.8h.5c.5,0,1,0,1.5.2v-1.2l2.1-1.6c.1,0,.2-.4.1-.6Z\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/procedure_outline.tpl /* harmony default export */ const procedure_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M183.9,209.9h-72.5l35.9-89.9L111.4,30h72.5l35.9,89.9-35.9,89.9ZM140.9,189.9h29.4l27.9-69.9-27.9-69.9h-29.4l27.9,69.9-27.9,69.9ZM89.8,209.9H17.3l35.9-89.9L17.3,30h72.5l35.9,89.9-35.9,89.9ZM46.8,189.9h29.4l27.9-69.9-27.9-69.9h-29.4l27.9,69.9-27.9,69.9Z\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/mobile_form_edit_outline.tpl /* harmony default export */ const mobile_form_edit_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M225.5,147.3l-12.8-12.8c-1.9-1.9-5.1-1.9-7,0l-9.5,9.5,19.8,19.8,9.5-9.5c1.9-1.8,1.9-5,0-7h0ZM209.2,170.6l-39.4,39.4-20,20h-19.8v-19.8l.2-.2,19.6-19.6,39.6-39.6,10.5,10.6,9.2,9.3ZM160,20H60c-11-.1-20,8.8-20,19.9v159.9c0,11,8.9,20,20,20h40c0,0,0-29.7,0-29.7h-40V49.9l100,.2v69.7h20c0,0,0-79.7,0-79.7,0-11-8.9-20-20-20ZM65,39.7c-2.8,0-5-2.2-5-5s2.2-5,5-5,5,2.2,5,5-2.2,5-5,5ZM140,34.6c0,2.8-2.3,5.1-5.1,5.1h-49.9c-2.8,0-5.1-2.3-5.1-5.1v-5.1h60v5.1ZM120,169.9\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/windows_form_edit_outline.tpl /* harmony default export */ const windows_form_edit_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M225.5,144.3l-9.5,9.5-19.8-19.8,9.5-9.5c1.8-1.9,5-1.9,7,0l12.8,12.8c1.9,1.9,1.9,5.1,0,7ZM60,180.4h50v19.6H40c-11,0-20-9-20-20V49.9c0-11,9-20,20-20h160c11,0,20,9,20,20v60h-20v-40H40v90.5c0,11,9,20,20,20ZM170,50c0,5.5,4.5,10,10,10s10-4.5,10-10-4.5-10-10-10-10,4.5-10,10ZM140,50c0,5.5,4.5,10,10,10s10-4.5,10-10-4.5-10-10-10-10,4.5-10,10ZM110,50c0,5.5,4.5,10,10,10s10-4.5,10-10-4.5-10-10-10-10,4.5-10,10ZM189.5,140.8l-39.6,39.6-19.6,19.6-.2.2v19.8h19.8l20-20,39.4-39.4-9.2-9.3-10.5-10.6Z\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/input_form_outline.tpl /* harmony default export */ const input_form_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M200,19.9H40c-11,0-20,9-20,20v160.1c0,11,9,20,20,20h90v-20.1H40v-110.1h160v110.1h-10v20.1h10c11,0,20-9,20-20V39.9c0-11-9-20-20-20ZM200,70H40v-30.1h160v30.1ZM140,139.9h40v10.1h-10v70h10v9.9h-40v-9.9h10v-70h-10v-10.1Z\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/output_form_outline.tpl /* harmony default export */ const output_form_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M200,19.6H40c-11,0-20,8.9-20,20v160.1c0,11,9,20,20,20h89.6c-8.7-5.1-16.2-12-22.2-20.1H40v-110.1h160v66.7c7.4,3.6,14.2,8.5,20,14.3V39.6c0-11.1-9-20-20-20ZM200,69.7H40v-30.1h160v30.1ZM167.4,158.6c-21.8,0-40.7,12.5-50,30.7,9.3,18.2,28.2,30.7,50,30.7s40.7-12.5,50-30.7c-9.3-18.2-28.2-30.7-50-30.7ZM167.4,208c-10.3,0-18.7-8.4-18.7-18.7s8.4-18.7,18.7-18.7,18.7,8.4,18.7,18.7-8.4,18.7-18.7,18.7ZM176.2,189.3c0,4.8-3.9,8.7-8.7,8.7s-8.7-3.9-8.7-8.7,3.9-8.7,8.7-8.7,8.7,3.9,8.7,8.7Z\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/template.tpl /* harmony default export */ const template = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M200.1,20H39.9c-11,0-19.9,8.9-19.9,19.9v160.2c0,11,8.9,19.9,19.9,19.9h160.1c11,0,19.9-8.9,19.9-19.9V39.9c0-11-8.9-19.9-19.9-19.9ZM120,190c0,5.5-4.5,10-10,10h-60c-5.5,0-10-4.5-10-10v-80c0-5.5,4.5-10,10-10h60c5.5,0,10,4.5,10,10v80ZM200,190c0,5.5-4.5,10-10,10h-50c-5.5,0-10-4.5-10-10v-30c0-5.5,4.5-10,10-10h50c5.5,0,10,4.5,10,10v30ZM200,130c0,5.5-4.5,10-10,10h-50c-5.5,0-10-4.5-10-10v-20c0-5.5,4.5-10,10-10h50c5.5,0,10,4.5,10,10v20ZM200,80c0,5.5-4.5,10-10,10H50c-5.5,0-10-4.5-10-10v-30c0-5.5,4.5-10,10-10h140c5.5,0,10,4.5,10,10v30Z\" style=\"stroke:none;fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/mobile_input_form_outline.tpl /* harmony default export */ const mobile_input_form_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<polygon xmlns=\"http://www.w3.org/2000/svg\" points=\"190 130 190 119.9 150 119.9 150 130 160 130 160 200 150 200 150 209.9 190 209.9 190 200 180 200 180 130 190 130\" style=\"fill:currentColor; stroke: none\"/>\r\n<path xmlns=\"http://www.w3.org/2000/svg\" d=\"M60,180V39.9l100,.2v69.7h20c0,0,0-79.7,0-79.7,0-11-8.9-20-20-20H60c-11-.1-20,8.8-20,19.9v159.9c0,11,8.9,20,20,20h40c0,0,40,0,40,0v-29.8H60ZM80,20h60v5.1c0,2.8-2.3,5.1-5.1,5.1h-49.9c-2.8,0-5.1-2.3-5.1-5.1v-5.1ZM65,20c2.8,0,5,2.2,5,5s-2.2,5-5,5-5-2.2-5-5,2.2-5,5-5Z\" style=\"fill:currentColor; stroke: none\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/mobile_output_form_outline.tpl /* harmony default export */ const mobile_output_form_outline = ("<svg class=\"procedure-outline-icon\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24px\" height=\"24px\">\r\n<path d=\"M160,20.3H60c-11-.1-20,8.8-20,19.9v159.9c0,11,8.9,20,20,20h40c0,0,22.9,0,22.9,0-12.1-7-22.1-17.4-28.7-29.8h-34.3V50.1l100,.2v98.3c6.9,0,13.6,1,20,2.7V40.3c0-11-8.9-20-20-20ZM65,40.2c-2.8,0-5-2.2-5-5s2.2-5,5-5,5,2.2,5,5-2.2,5-5,5ZM140,35.3c0,2.8-2.3,5.1-5.1,5.1h-49.9c-2.8,0-5.1-2.3-5.1-5.1v-5.1h60v5.1ZM160,158.6c-21.8,0-40.7,12.5-50,30.7,9.3,18.2,28.2,30.7,50,30.7s40.7-12.5,50-30.7c-9.3-18.2-28.2-30.7-50-30.7ZM160,208c-10.3,0-18.7-8.4-18.7-18.7s8.4-18.7,18.7-18.7,18.7,8.4,18.7,18.7-8.4,18.7-18.7,18.7ZM160,180.6c-4.8,0-8.7,3.9-8.7,8.7s3.9,8.7,8.7,8.7,8.7-3.9,8.7-8.7-3.9-8.7-8.7-8.7Z\" style=\"fill:currentColor; stroke: none\"/></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/city.tpl /* harmony default export */ const city = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24\" height=\"24\" >\r\n<path style=\"fill:currentColor\" d=\"M172.4,229.7c-4.3,0-11.8-1.9-33.7-14.3-3.8-2.1-8.7-1.4-11.6,1.9-7.5,8.3-12.3,11.7-17.4,12.3-5.5.6-10.2-1.5-15.2-3.8-4.1-1.9-8.8-4-15.3-5.4-1.6-.4-3.3-.6-4.8-.9-15.8-2.8-27.6-7.3-36.2-39.7-2.1-7.8-5.2-9.3-10.5-11.9-4.9-2.4-11.5-5.7-15-14.2-3.1-7.6-2.9-18,.5-33.6,8.2-37,29.3-38.6,39.4-39.3.2,0,.4,0,.6,0-.7-10,1.5-17.4,6.6-22.2,5.1-4.8,11.1-5,13.7-4.8h31.6l23.1-8.9c2.3-.9,4.1-2.6,5.1-4.8l1.4-3.1c4.7-10.2,15.1-16.9,26.4-16.9h5.9l28.4,7.7c12.3,3.3,21.1,14.6,21.4,27.3l.4,20.6c0,3.1-.4,6.2-1.3,9.2l-6.3,20.3c-.8,2.6-.4,5.3,1,7.6l4.9,7.8c5.5,8.9,5.8,20.1.8,29.3l-17,30.7c-1.4,2.5-1.5,5.4-.4,8,5.4,12.9.8,27.8-10.9,35.4-5.5,3.6-10,5.4-14.1,5.7-.4,0-.9,0-1.4,0ZM172.9,210.1h0ZM108,210h0ZM134.2,194.6c4.9,0,9.8,1.2,14.2,3.7,16.4,9.3,22.5,11.2,24.1,11.6.6-.2,2.2-.8,4.8-2.6,3.7-2.4,5.1-7.1,3.4-11.3-3.4-8.2-2.9-17.4,1.4-25.1l17-30.7c1.6-2.9,1.5-6.5-.2-9.3l-4.9-7.8c-4.5-7.1-5.6-15.9-3.1-23.9l6.3-20.3c.3-1,.4-1.9.4-2.9l-.4-20.6c0-4.1-2.9-7.7-6.9-8.7l-25.9-7h-3.3c-3.7,0-7,2.1-8.5,5.4l-1.4,3.1c-3.2,6.9-8.8,12.2-15.9,14.9l-26.5,10.2h-35.6c-.3,1.1-.6,3.4-.2,7.3.6,5.6-.5,10.2-3.4,13.6-4.3,5.2-10.5,5.7-15.5,6-8.6.6-16.7,1.3-21.7,24-3.2,14.5-2.3,20-1.5,22,.5,1.3,1.4,1.9,5.5,4,6.5,3.2,16.4,8.1,20.8,24.5,3,11.1,6.2,18.3,9.7,21.5,2.4,2.2,5.3,2.8,11,3.8,1.8.3,3.6.6,5.6,1.1,8.5,1.9,14.7,4.6,19.2,6.7,1.4.6,3.1,1.4,4.3,1.8,1-.8,2.8-2.5,5.6-5.6,5.6-6.2,13.6-9.6,21.7-9.6ZM53.4,83.8h0ZM71.3,73.3s0,0,0,0h0Z\"/>\r\n<circle style=\"fill:currentColor\" cx=\"143.5\" cy=\"150\" r=\"19.9\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/country.tpl /* harmony default export */ const country = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24\" height=\"24\" >\r\n<path d=\"M173.4,159.1c0,11-8.9,19.9-19.9,19.9s-19.9-8.9-19.9-19.9,8.9-19.9,19.9-19.9,19.9,8.9,19.9,19.9ZM201.4,174c-1.3,2.4-1.5,5.2-.4,7.8,5.2,12.5.8,26.9-10.5,34.2-5.3,3.4-9.7,5.2-13.7,5.6-.4,0-.9,0-1.4,0-4.2,0-11.5-1.8-32.6-13.8-3.7-2.1-8.4-1.3-11.2,1.8-7.2,8-11.9,11.3-16.8,11.9-5.3.6-9.9-1.5-14.7-3.6-4-1.8-8.5-3.8-14.9-5.2-1.6-.3-3.1-.6-4.7-.9-15.3-2.7-26.7-7.1-35.1-38.4-2-7.5-5.1-9-10.1-11.5-4.7-2.3-11.2-5.5-14.5-13.8-3-7.4-2.8-17.4.5-32.5,7.9-35.8,28.3-37.3,38.1-38.1.2,0,.4,0,.6,0-.7-9.6,1.4-16.9,6.4-21.5,5-4.7,10.7-4.8,13.3-4.6h30.6l22.4-8.6c2.2-.8,4-2.5,5-4.6l1.4-3c4.6-9.9,14.6-16.3,25.5-16.3h5.7l27.5,7.5c12,3.2,20.5,14.1,20.7,26.4l.4,20c0,3-.4,6-1.3,8.9l-6.1,19.7c-.8,2.5-.4,5.2.9,7.4l4.7,7.5c5.4,8.6,5.7,19.5.8,28.3l-16.4,29.7ZM173.4,159.1c0-11-8.9-19.9-19.9-19.9s-19.9,8.9-19.9,19.9,8.9,19.9,19.9,19.9,19.9-8.9,19.9-19.9ZM153.4,139.2c-11,0-19.9,8.9-19.9,19.9s8.9,19.9,19.9,19.9,19.9-8.9,19.9-19.9-8.9-19.9-19.9-19.9Z\" style=\"fill:currentColor\"/>\r\n</svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/configuration_form_outline.tpl /* harmony default export */ const configuration_form_outline = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 240 240\"><path style=\"fill:currentColor\" d=\"M200,20.1H40c-11,0-20,8.9-20,20v160.1c0,11,9,20,20,20h80.8c-5.6-5.8-10.1-12.6-13.2-20.1H40v-110.1h160v31.9c8.1,5,14.9,11.8,20,19.8V40.1c0-11.1-9-20-20-20ZM200,70.3H40v-30.1h160v30.1ZM216.6,189.7l-11.2-8.9c0-1.3.2-2.7.2-4,0-2.1,0-4.2-.3-6.3l11.1-8.8c.5-.9,1.3-2.3.7-3.2l-10.7-18.2c-.3-.2-.7-.4-1-.6-.7-.4-1.4-.8-1.7-1l-12.8,5.4-9.1-5.2-2.3-14c-.3-.2-.8-1-1.5-1.4,0,0,0,0,0,0-.3-.2-.7-.3-1.1-.2,0,0,0,0,0,0h-10.2s-10.4,0-10.4,0c-1.6,0-2.6,1-2.6,2.1l-2.1,14.2c-3.1,1.6-6.3,3.1-8.9,5.2l-13.1-5.2c-1.1,0-2.6,0-3.2,1l-10.5,18.4v3.2l11,8.4v10.5l-11,8.9c0,.5-1.1,2.1,0,3.2l10.5,18.4c0,1,2.1,1,3.2,1l13.1-5.2c2.6,2.1,5.8,4.2,8.9,5.2l2.1,13.7c0,1,1.6,2.1,2.6,2.1h20.7c1.2,0,2-1.3,2.5-2.2l2-14c3.1-1.2,6.5-2.9,9-5.1l13.3,5.2c.9.5,2.6-.3,3.1-1.2l10.4-18.1c.8-1.4.4-2.8-.5-3.3ZM201.4,200.3l-12.9-5c-4.5,4.7-9.8,7.6-16,8.9l-1.8,14.2h-8.4l-2.1-13.7c-6.3-1.6-11.6-4.7-15.8-9.5l-12.6,5.2-4.2-6.8,11-8.4c-2.1-6.3-2.1-12.6,0-18.9l-11-8.4,4.2-6.8,12.6,5.2c3.7-4.7,9.4-8.4,15.8-9.5l2.1-13.6h7.9l1.8,13.9c3.7.7,7,2,10,3.9,0,0,.1,0,.2.1,2.2,1.4,4.1,3.1,6,5.1,0,0,.1.2.2.2l12.4-5.2h.4c0-.1,3.6,6.4,3.6,6.4v.2c0,0,.2.2.2.2l-10.8,8.3c1.2,2.8,1.8,6,1.9,9.3,0,3-.4,6.1-1.5,9l10.8,8.6-3.9,6.8ZM181.1,175.9c0,8.1-6.6,14.7-14.7,14.7s-14.7-6.6-14.7-14.7,6.6-14.7,14.7-14.7,14.7,6.6,14.7,14.7Z\"/></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/function_manager.tpl /* harmony default export */ const function_manager = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 240 240\"><path style=\"fill:currentColor\" d=\"M116.4,119.8c0,.3,0,.6-.1.9-3.2,20.7-6.4,42.1-17.3,63.7-8.3,16.4-18.7,25-31,25.5-.4,0-.7,0-1.1,0-19.8,0-33.8-22-35.4-24.6-2.9-4.7-1.4-10.9,3.3-13.7,4.7-2.9,10.9-1.4,13.7,3.3,3.8,6.1,12.2,15,18.4,15s.2,0,.3,0c4.3-.2,9.3-5.4,13.9-14.5,9.1-18.1,12.3-37.1,15.1-55.6h-13.4c-7.1,0-12.9-5.8-12.9-12.9h0c0-7.1,5.8-12.9,12.9-12.9h17.8c3.6-17.2,9.3-34.3,21.6-50.1,16.9-21.7,30.6-22.7,39.1-19.8,11.7,4.1,19,18.2,18.8,36,0,5.5-4.5,9.9-10.1,9.9-5.5,0-9.9-4.6-9.9-10.1.1-9.6-3.1-16.1-5.4-16.9-1.3-.5-7.2,1-16.7,13.2-9,11.6-13.7,24.3-16.9,37.8h16.1c7.1,0,12.9,5.8,12.9,12.9h0c0,7.1-5.8,12.9-12.9,12.9h-20.7ZM181.7,174.2v3.5l6.7,4.9c.6.4.9,1.2.6,1.9v.5c-.1,0-.3,1.1-1,1.8l-7,12.6s-1.4.7-2.1,0l-8.4-3.5c-2.1,1.4-4.2,2.8-6.3,3.5l-1.4,9.1c0,.7-.7,1.4-1.4,1.4h-14.7c-.7,0-1.4,0-1.4-1.4l-1.4-9.1c-2.1-.7-4.9-2.1-6.3-4.2l-8.4,3.5h-2.1l-7-12.6v-2.1l7.7-5.6v-7.7l-7-5.6s-.7-1.4,0-2.1l7.7-12.6s1.4-.7,2.1,0l8.4,3.5c2.1-1.4,3.5-2.8,6.3-3.5l1.4-9.1c0-.7.7-1.4,1.4-1.4h14.7c.7,0,1.4,0,1.4,1.4l1.4,9.1c2.1.7,4.2,2.1,6.3,3.5l8.4-3.5h2.1l7,12.6v2.1l-7.7,5.6v3.5ZM164.9,175.6c0-5.6-4.9-10.5-10.5-10.5s-10.5,4.9-10.5,10.5,4.9,10.5,10.5,10.5,10.5-4.9,10.5-10.5Z\" /></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/data_type_configuration_outline.tpl /* harmony default export */ const data_type_configuration_outline = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\" width=\"24\" height=\"24\"><path style=\"fill:currentColor\" d=\"M110,110V20H20v90M40,90v-50h50v50M200,65c0,14-11,25-25,25s-25-11-25-25,11.1-25,25-25,25,11.1,25,25M65,140l-45,80h90M75.8,200h-21.6l10.8-19.2M220,65c0-25-20-45-45-45s-45,20-45,45,20,45,45,45,45-20,45-45M210.8,179.3v4l7.7,5.6c.7.5,1,1.4.7,2.2l-.2.5s-.2,1.3-1,2.1l-8,14.4s-1.6.8-2.4,0l-9.6-4c-2.4,1.6-4.8,3.2-7.2,4l-1.6,10.4c0,.8-.8,1.6-1.6,1.6h-16.8c-.8,0-1.6,0-1.6-1.6l-1.6-10.4c-2.4-.8-5.6-2.4-7.2-4.8l-9.6,4h-2.4l-8-14.4v-2.4l8.8-6.4v-8.8l-8-6.4s-.8-1.6,0-2.4l8.8-14.4s1.6-.8,2.4,0l9.6,4c2.4-1.6,4-3.2,7.2-4l1.6-10.4c0-.8.8-1.6,1.6-1.6h16.8c.8,0,1.6,0,1.6,1.6l1.6,10.4c2.4.8,4.8,2.4,7.2,4l9.6-4h2.4l8,14.4v2.4l-8.8,6.4v4ZM191.6,180.9c0-6.4-5.6-12-12-12s-12,5.6-12,12,5.6,12,12,12,12-5.6,12-12Z\" /></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/time_based_payroll_report.tpl /* harmony default export */ const time_based_payroll_report = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 240 240\"><path style=\"fill:currentColor\" d=\"M160.1,144.7c-6.2-2.8-13-4.3-20.2-4.4h-.2c-27.5,0-49.9,22.3-49.9,49.9s22.3,49.9,49.9,49.9,49.9-22.3,49.9-49.9-1.5-14-4.3-20.2c-5-11.2-14-20.3-25.2-25.3ZM153.9,215.1c-2.8,2.4-5.9,4-9.5,4.7v5.3h-10.1v-5c-2.7-.2-5.2-.7-7.4-1.4-5.1-1.6-7.6-4.1-7.6-7.5s.5-3.1,1.5-4.2c1-1.1,2.3-1.7,3.9-1.7s3.3.6,6.4,1.6c1.2.4,2.2.8,3.2,1,1.6.4,3,.6,4.1.6,2.6,0,4.6-.6,6-1.9,0,0,0,0,.1,0,1.5-1.3,2.2-3,2.2-5.1s-.8-2.7-2.3-3.8c-1.1-.8-2.7-1.6-4.7-2.2-2-.6-3.8-1.2-5.4-1.7-4.3-1.4-6.9-2.4-7.8-2.9-4.8-2.7-7.1-6.8-7.1-12.3s2-10,5.9-13.4c2.6-2.2,5.6-3.8,9-4.5v-5.3h10.1v5.1c1.7.3,3.4.7,5,1.3,4.2,1.5,6.3,3.7,6.3,6.5s-.5,3-1.5,4.2c-1,1.2-2.3,1.8-3.9,1.8s-2.3-.2-3.7-.7c-.8-.3-1.5-.5-2.2-.7-2.2-.7-3.9-1-5.1-1-1.9,0-3.4.4-4.8,1.3-.1,0-.2.2-.3.2-1.1.9-1.7,2.1-1.7,3.7s.5,2,1.7,2.8c1.2.9,3,1.7,5.4,2.5,1.7.5,3.3,1.1,4.7,1.6,4.1,1.4,6.9,2.6,8.5,3.6,4.8,3.1,7.1,7.7,7.1,13.8s-2,10.2-6.1,13.7ZM80.2,199.9c.8,7.1,3,13.9,6.2,20H30c-11,0-20-9-20-20V40.2c0-11,9-20,20-20h159.8c11,0,20,8.9,20,20v42.8c-5.2-1.6-10.8-2.5-16.6-2.5s-2.1,0-3.2,0v-20.6c0-11-9-20-20-20H50c-11,0-20,8.9-20,20v120c0,11,9,20,20,20h30.2ZM239.7,140.3c0,24.2-17.3,44.4-40.1,48.9-.1-6.9-1.4-13.4-3.6-19.6,13.6-2.8,23.9-14.9,23.9-29.4s-13.4-30-30-30-26.5,10.2-29.3,23.7c-6.1-2.3-12.7-3.6-19.5-3.7,4.6-22.8,24.8-39.9,48.9-39.9s49.9,22.3,49.9,49.9ZM199.7,158.1l-15-13.2,1.4-26.3c.1-2,1.8-3.6,3.8-3.6s3.6,1.5,3.8,3.5l1.5,22,10.1,12.2c1.3,1.6,1.1,3.9-.5,5.2h0c-1.4,1.3-3.5,1.2-4.9,0ZM159.8,90.3H49.8v-20h110v20ZM119.8,130.1H49.8v-20h70v20ZM49.8,160.1h20.1v20.1h-20.1v-20.1Z\"/></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/important_outline.tpl /* harmony default export */ const important_outline = ("<svg id=\"Layer_2\" xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 240 240\"><circle cx=\"120\" cy=\"207.26325\" r=\"20.2697\" style=\"fill:none;stroke:currentColor;\" stroke-miterlimit=\"10\" stroke-width=\"20\"/><path style=\"fill:none;stroke:currentColor;\" d=\"M119.91441,162.875h-.00004c-10.3258,0-18.86289-8.04674-19.47299-18.3545l-6.17585-104.34288c-.87661-14.81057,10.89792-27.30262,25.73441-27.30262h.00005c14.85315,0,26.63372,12.51893,25.73189,27.34468l-6.3464,104.33265c-.6262,10.29447-9.15758,18.32267-19.47108,18.32267Z\" stroke-miterlimit=\"10\" stroke-width=\"20\"/></svg>"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/emoji_muted.tpl /* harmony default export */ const emoji_muted = ("<svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 6.3499999 6.3500002\"\n version=\"1.1\"\n id=\"svg5\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:svg=\"http://www.w3.org/2000/svg\">\n <g\n inkscape:label=\"Layer 1\"\n inkscape:groupmode=\"layer\"\n id=\"layer1\">\n <path\n id=\"path1315\"\n style=\"fill:currentColor;fill-opacity:1;fill-rule:evenodd;stroke-width:0.1;stroke-linecap:square;stroke-linejoin:round;paint-order:markers stroke fill\"\n transform=\"matrix(0.26458334,0,0,0.26458334,-1.3750001e-8,0.52916667)\"\n d=\"m 21,10 a 9,9 0 0 1 -9,9 9,9 0 0 1 -9,-9 9,9 0 0 1 9,-9 9,9 0 0 1 9,9 z m 1.999999,-2e-7 A 10.999999,11 0 0 1 12,21 10.999999,11 0 0 1 0.99999998,9.9999998 10.999999,11 0 0 1 12,-0.99999996 10.999999,11 0 0 1 22.999999,9.9999998 Z\" />\n <path\n id=\"path1800\"\n style=\"fill:currentColor;fill-rule:evenodd;stroke-width:0.1;stroke-linecap:square;stroke-linejoin:round;paint-order:markers stroke fill\"\n transform=\"scale(0.26458334)\"\n d=\"M 10,10 A 2,2 0 0 1 8,12 2,2 0 0 1 6,10 2,2 0 0 1 8,8 2,2 0 0 1 10,10 Z\" />\n <path\n id=\"path1802\"\n style=\"fill:currentColor;fill-rule:evenodd;stroke-width:0.1;stroke-linecap:square;stroke-linejoin:round;paint-order:markers stroke fill\"\n transform=\"matrix(0.26458334,0,0,0.26458334,-0.2645834,0)\"\n d=\"m 19,10 a 2,2 0 0 1 -2,2 2,2 0 0 1 -2,-2 2,2 0 0 1 2,-2 2,2 0 0 1 2,2 z\" />\n </g>\n</svg>\n"); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/icons.css var icons = __webpack_require__(6734); // EXTERNAL MODULE: ./node_modules/absol/src/Color/Color.js var Color = __webpack_require__(257); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/Icons.js function SpinnerIco() { return ACore/* default._ */.Z._(spinner); } SpinnerIco.tag = 'SpinnerIco'.toLowerCase(); ACore/* default.install */.Z.install(SpinnerIco); function InsertColLeftIcon() { return ACore/* default._ */.Z._(insert_col_left); } InsertColLeftIcon.tag = 'InsertColLeftIcon'.toLowerCase(); ACore/* default.install */.Z.install(InsertColLeftIcon); function InsertColRightIcon() { return ACore/* default._ */.Z._(insert_col_right); } InsertColRightIcon.tag = 'InsertColRightIcon'.toLowerCase(); ACore/* default.install */.Z.install(InsertColRightIcon); function MdiStoreMarkerOutline() { return ACore/* default._ */.Z._(mdi_store_marker_outline); } MdiStoreMarkerOutline.tag = 'mdi-store-marker-outline'; ACore/* default.install */.Z.install(MdiStoreMarkerOutline); function ProcessOutlineIcon() { return (0,ACore._)(process_outline); } ProcessOutlineIcon.tag = 'ProcessOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(ProcessOutlineIcon); function ProcedureOutlineIcon() { return (0,ACore._)(procedure_outline); } ProcedureOutlineIcon.tag = 'ProcedureOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(ProcedureOutlineIcon); function WindowsFormEditOutlineIcon() { return (0,ACore._)(windows_form_edit_outline); } WindowsFormEditOutlineIcon.tag = 'WindowsFormEditOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(WindowsFormEditOutlineIcon); function MobileFormEditOutlineIcon() { return (0,ACore._)(mobile_form_edit_outline); } MobileFormEditOutlineIcon.tag = 'MobileFormEditOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(MobileFormEditOutlineIcon); function TemplateIcon() { return (0,ACore._)(template); } TemplateIcon.tag = 'TemplateIcon'.toLowerCase(); ACore/* default.install */.Z.install(TemplateIcon); function InputFormOutlineIcon() { return (0,ACore._)(input_form_outline); } InputFormOutlineIcon.tag = 'InputFormOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(InputFormOutlineIcon); function OutputFormOutlineIcon() { return (0,ACore._)(output_form_outline); } OutputFormOutlineIcon.tag = 'OutputFormOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(OutputFormOutlineIcon); function MobileInputFormOutlineIcon() { return (0,ACore._)(mobile_input_form_outline); } MobileInputFormOutlineIcon.tag = 'MobileInputFormOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(MobileInputFormOutlineIcon); function MobileOutputFormOutlineIcon() { return (0,ACore._)(mobile_output_form_outline); } function CityIcon() { return (0,ACore._)(city); } CityIcon.tag = 'CityIcon'.toLowerCase(); ACore/* default.install */.Z.install(CityIcon); function CountryIcon() { return (0,ACore._)(country); } CountryIcon.tag = 'CountryIcon'.toLowerCase(); ACore/* default.install */.Z.install(CountryIcon); MobileOutputFormOutlineIcon.tag = 'MobileOutputFormOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(MobileOutputFormOutlineIcon); function FontColorIcon() { this._value = '#000000'; this.$contract = (0,ACore.$)('.as-font-color-contract', this); this.$value = (0,ACore.$)('.as-font-color-value', this); this.value = 'cyan'; } FontColorIcon.tag = 'FontColorIcon'.toLowerCase(); FontColorIcon.render = function () { return (0,ACore._)(font_color); }; FontColorIcon.property = {}; FontColorIcon.property.value = { set: function (value) { var cValue; if (typeof value === "string") { try { cValue = Color/* default.parse */.Z.parse(value); value = cValue.toString('hex6'); } catch (err) { value = "#000000"; cValue = Color/* default.parse */.Z.parse(value); } } else if (value instanceof Color/* default */.Z) { cValue = value; value = value.toString('hex6'); } else { value = "#000000"; cValue = Color/* default.parse */.Z.parse(value); } this._value = value; var hColor = cValue.getContrastYIQ(); this.$contract.addStyle('fill', hColor.toString("hex6")); this.$value.addStyle('fill', this._value.toString('hex6')); }, get: function () { return this._value; } }; function ConfigurationFormOutlineIcon() { return (0,ACore._)(configuration_form_outline); } ConfigurationFormOutlineIcon.tag = 'ConfigurationFormOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(ConfigurationFormOutlineIcon); function FunctionManagerIcon() { return (0,ACore._)(function_manager); } FunctionManagerIcon.tag = 'FunctionManagerIcon'.toLowerCase(); ACore/* default.install */.Z.install(FunctionManagerIcon); function DataTypeConfiguratorOutlineIcon() { return (0,ACore._)(data_type_configuration_outline); } DataTypeConfiguratorOutlineIcon.tag = 'DataTypeConfiguratorOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(DataTypeConfiguratorOutlineIcon); function TimeBasedPayrollReportIcon() { return (0,ACore._)(time_based_payroll_report); } TimeBasedPayrollReportIcon.tag = 'TimeBasedPayrollReportIcon'.toLowerCase(); ACore/* default.install */.Z.install(TimeBasedPayrollReportIcon); function ImportantOutlineIcon() { return (0,ACore._)(important_outline).addStyle({ width: '1em', height: '1em' }); } ImportantOutlineIcon.tag = 'ImportantOutlineIcon'.toLowerCase(); ACore/* default.install */.Z.install(ImportantOutlineIcon); function EmojiMutedIcon(){ return (0,ACore._)(emoji_muted); } EmojiMutedIcon.tag = 'EmojiMutedIcon'.toLowerCase(); ACore/* default.install */.Z.install(EmojiMutedIcon); /***/ }), /***/ 407: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "j2": () => (/* binding */ MenuButton), /* harmony export */ "Lt": () => (/* binding */ Dropdown), /* harmony export */ "KZ": () => (/* binding */ Dropright), /* harmony export */ "ee": () => (/* binding */ VMenuLine), /* harmony export */ "zV": () => (/* binding */ VMenuItem), /* harmony export */ "T$": () => (/* binding */ VMenu), /* harmony export */ "E": () => (/* binding */ HMenuItem), /* harmony export */ "ch": () => (/* binding */ HMenu), /* harmony export */ "p": () => (/* binding */ VRootMenu) /* harmony export */ }); /* harmony import */ var _css_menu_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4286); /* harmony import */ var _css_menu_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_menu_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3349); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var _tool_BlurTrigger__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(9346); /* harmony import */ var absol_src_HTML5_ResizeSystem__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(6700); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function MenuButton() { this.$text = $('.absol-vmenu-button-text', this); this.$key = $('.absol-vmenu-button-key', this); this.$arrow = $('.absol-vmenu-arrow', this); this.$iconCtn = $('.absol-vmenu-button-ext-icon-container', this); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$text, 'text', 'innerHTML'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$key, 'key', 'innerHTML'); } MenuButton.tag = 'menubutton'; MenuButton.render = function () { return _({ tag: 'button', class: 'absol-vmenu-button', child: [ { class: 'absol-vmenu-button-ext-icon-container', child: 'img.absol-vmenu-button-icon' }, '.absol-vmenu-button-text', '.absol-vmenu-button-key', { class: 'absol-vmenu-arrow-container', child: 'span.absol-vmenu-arrow' } ] }); }; MenuButton.property = {}; MenuButton.property.extendClasses = { set: function (value) { var self = this; this.extendClasses.forEach(function (className) { self.removeClass(className); }); this._extendClass = []; if (!value) return; if (typeof value == 'string') { value = value.split(/\s+/).filter(function (c) { return c.length > 0 }); } if (value instanceof Array) { this._extendClass = value; this._extendClass.forEach(function (className) { self.addClass(className); }); } else { throw new Error('Invalid extendClasses'); } }, get: function () { return this._extendClass || []; } }; MenuButton.property.icon = { set: function (value) { this.$iconCtn.clearChild(); this._icon = value; if (value) { _(value).addTo(this.$iconCtn); } }, get: function () { return this._icon; } }; MenuButton.property.iconSrc = { set: function (value) { if (value) this.icon = { tag: 'img', props: { src: value } }; else this.icon = value; }, get: function () { return this.icon && this.icon.props && this.icon.props.src; } }; MenuButton.property.extendStyle = { set: function (value) { this.removeStyle(this._extendStyle || {}); this._extendStyle = value || {}; this.addStyle(this.extendStyle); }, get: function () { return this._extendStyle || {}; } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(MenuButton); /*** * * @extends Follower * @constructor */ function Dropdown() { this.$container = $('.absol-dropdown-content', this); this.$container.followTarget = this; this.$container.sponsorElement = this; this.$container.anchor = [1, 2, 6, 5]; } Dropdown.tag = 'dropdown'; Dropdown.render = function () { return _({ class: ['absol-drop-hidden', 'absol-dropdown'], child: 'follower.absol-dropdown-content.as-bscroller' }); }; Dropdown.property = {}; Dropdown.property.show = { set: function (value) { if (value) { this.removeClass('absol-drop-hidden'); // ResizeSystem.update(); if (this.$container.lastChild && this.$container.lastChild.$items) { this.$container.lastChild.$items.forEach(function (itemElt) { if (itemElt.autoFixParentSize) { itemElt.autoFixParentSize(); } }); } var aPst = this.findAvailablePosition(); if (aPst.crampedHeight) { this.removeClass('overlap-top'); // this.$container.followTarget = null;? this.$container.addStyle({ 'max-height': aPst.maxHeight + 'px' }); this.$container.refollow(); this.$container.updatePosition(); this.$container.addStyle('top', this.getBoundingClientRect().top + aPst.posTop + 'px'); } else { this.$container.removeStyle('max-height') .removeStyle('top'); this.$container.refollow(); this.$container.updatePosition(); } } else { this.addClass('absol-drop-hidden'); } }, get: function () { return !this.hasClass('absol-drop-hidden'); } }; Dropdown.prototype.findAvailablePosition = function () { var outBound = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].traceOutBoundingClientRect */ .ZP.traceOutBoundingClientRect(document.body); var containerBound = this.$container.getBoundingClientRect(); var bound = this.getBoundingClientRect(); var distTop = bound.top - outBound.top; var distLeft = bound.left - outBound.left; var distRight = -bound.right + outBound.right; var distBottom = -bound.bottom + outBound.bottom; var result = {}; if (distLeft >= containerBound.width) result.left = true; if (distTop >= containerBound.height) result.top = true; if (distRight >= containerBound.width) result.right = true; if (distBottom >= containerBound.height) result.bottom = true; if (distRight + bound.width >= containerBound.width) result.overlapRight = true; if (distLeft + bound.width >= containerBound.width) result.overlapLeft = true; if (distBottom + bound.height >= containerBound.height) result.overlapBottom = true; if (distTop + bound.height >= containerBound.height) result.overlapTop = true; if (!result.overlapTop && !result.overlapBottom) { result.crampedHeight = true; result.maxHeight = outBound.height - 20; result.posTop = distBottom - Math.min(containerBound.height, result.maxHeight) + bound.height - 10; } return result; }; Dropdown.prototype.addChild = function (child) { if (child instanceof Array) { for (var i = 0; i < child.length; ++i) this.addChild(child[i]); } else { if (!this.$trigger) { this.super(child); this.$trigger = child; } else { this.$container.addChild(child); } } }; Dropdown.prototype.clearChild = function () { if (this.$trigger) { this.$trigger.selfRemove(); this.$trigger = undefined; } this.$container.clearChild(); }; Dropdown.prototype.init = function (props) { props = props || {}; Object.assign(this, props); }; function Dropright() { this.$container = $('.absol-dropright-content', this); this.$container.followTarget = this; this.$container.sponsorElement = this; this.$container.anchor = [0, 3, 7, 4]; } Dropright.tag = 'dropright'; Dropright.render = function () { return _({ class: ['absol-drop-hidden', 'absol-dropright'], child: 'follower.absol-dropright-content.as-bscroller', data: { $trigger: undefined, $content: undefined, _isShow: false } }); } Object.assign(Dropright.prototype, Dropdown.prototype); //is the same Dropright.prototype.addChild = Dropdown.prototype.addChild; Dropright.prototype.clearChild = Dropdown.prototype.clearChild; Dropright.property = Object.assign({}, Dropdown.property); function VMenuLine() { return _('<div class="absol-vmenu-line"><div></div></div>'); } VMenuLine.tag = 'VMenuLine'.toLowerCase(); function VMenuItem() { var thisVM = this; this.$dropper = $('dropright', this); this.$vmenu = $('vmenu', this); this.$button = $('menubutton', this); this.$text = thisVM.$button.$text; this.$key = thisVM.$button.$key; this.$arrow = thisVM.$button.$arrow; this.$iconCtn = thisVM.$button.$iconCtn; absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$button, ['text', 'extendClasses', 'extendStyle', 'key', 'icon', 'iconSrc']); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$vmenu, ['activeTab']); this.eventHandler = absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].bindFunctions */ .ZP.bindFunctions(this, VMenuItem.eventHandler); this.$vmenu.on('press', this.eventHandler.pressItem, true); this.$button.on('click', this.eventHandler.clickButton, true); this.$button.on('mouseenter', this.eventHandler.enterButton, true); this._textMarginRight = 0; } VMenuItem.tag = 'VMenuItem'.toLowerCase(); VMenuItem.render = function () { return _({ tag: 'dropright', extendEvent: ['press', 'enter'], child: ['menubutton', { tag: 'vmenu', }] }); }; VMenuItem.prototype.init = function (props) { Object.assign(this, props || {}); }; VMenuItem.prototype.autoFixParentSize = function () { var parentWidth = this.$dropper.getBoundingClientRect().width;// dropper is fixed parent content size if (!parentWidth) return; var buttonWidth = this.$button.getBoundingClientRect().width; var fontSize = this.$text.getFontSize(); this._textMarginRight = parentWidth - buttonWidth + this._textMarginRight; this.$text.addStyle('margin-right', this._textMarginRight / fontSize + 'em'); }; VMenuItem.eventHandler = {}; VMenuItem.eventHandler.enterButton = function (event) { event.menuItem = this; var newEvent = absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event); this.emit('enter', newEvent, this); }; VMenuItem.eventHandler.pressItem = function (event) { var newEvent = absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }); this.emit('press', newEvent, this); }; VMenuItem.eventHandler.clickButton = function (event) { event.menuDontHide = this.items && this.items.length > 0; event.menuItem = this; event.vmenuItem = this; var newEvent = absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }); this.emit('press', newEvent, this); }; VMenuItem.property = {}; VMenuItem.property.items = { set: function (items) { items = items || []; if (items.length > 0) { this.$arrow.addClass(['mdi', 'mdi-chevron-right']); } else { this.$arrow.removeClass(['mdi', 'mdi-chevron-right']); } this.$vmenu.items = items; }, get: function () { return this.$vmenu.items; } }; VMenuItem.property.disabled = { set: function (value) { if (value) { this.addClass('absol-menu-item-disabled'); } else { this.removeClass('absol-menu-item-disabled'); } }, get: function () { return this.hasClass('absol-menu-item-disabled'); } }; VMenuItem.property.hidden = { set: function (value) { if (value) { this.addClass('absol-menu-item-hidden'); } else { this.removeClass('absol-menu-item-hidden'); } }, get: function () { return this.hasClass('absol-menu-item-hidden'); } }; /** * @extends AElement * @constructor */ function VMenu() { } VMenu.tag = 'vmenu'; VMenu.render = function () { return _({ class: 'absol-vmenu', extendEvent: 'press' }); }; VMenu.property = {}; VMenu.property.activeTab = { set: function (tabIndex) { this._activeTab = tabIndex; if (this.$items) { for (var i = 0; i < this.$items.length; ++i) { var item = this.$items[i]; item.show = i == tabIndex && !item.disabled; item.activeTab = -1; if (i == tabIndex && !item.disabled) { item.$button && item.items && item.items.length > 0 && item.$button.addClass('absol-vmenu-button-hover'); } else { item.$button && item.$button.removeClass('absol-vmenu-button-hover'); } } } }, get: function () { return this._activeTab; } }; VMenu.property.extendStyle = { set: function (value) { this.removeStyle(this._extendStyle || {}); this._extendStyle = value || {}; this.addStyle(this.extendStyle); }, get: function () { return this._extendStyle || {}; } }; VMenu.property.extendClasses = { set: function (value) { var self = this; this.extendClasses.forEach(function (className) { self.removeClass(className); }); this._extendClass = []; if (!value) return; if (typeof value == 'string') { value = value.split(/\s+/).filter(function (c) { return c.length > 0 }); } if (value instanceof Array) { this._extendClass = value; this._extendClass.forEach(function (className) { self.addClass(className); }); } else { throw new Error('Invalid extendClasses'); } }, get: function () { return this._extendClass || []; } }; VMenu.eventHandler = {}; VMenu.eventHandler.enterItem = function (event) { var tabIndex = event.menuItem._tabIndex; this.activeTab = tabIndex; }; VMenu.eventHandler.pressItem = function (event) { this.emit('press', absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }), this); }; VMenu.property.items = { set: function (items) { this._childFromItems(items || []); }, get: function () { return this.$items; } } VMenu.prototype.init = function (props) { Object.assign(this, props || {}); }; VMenu.prototype._childFromItems = function (items) { this.clearChild(); this.$items = items.map(function (item, index) { var itemElt; if (typeof item === 'string' && (item.substr(0, 1) === '-' || item.substr(0, 1) === '=')) { itemElt = _('vmenuline'); } else if ((0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* .isDomNode */ .mV)(item)) { itemElt = item; } else if (item.child || item.class || item.tag || item.style || typeof item === 'string') { itemElt = _(item); } else { itemElt = _({ tag: 'vmenuitem', props: Object.assign({ _tabIndex: index }, item), on: { enter: { callback: this.eventHandler.enterItem, cap: true }, press: { callback: this.eventHandler.pressItem, cap: true } } }); } this.addChild(itemElt); return itemElt; }.bind(this)); //todo }; function HMenuItem() { this.blurTrigger = null; this.$vmenu = $('vmenu', this); this.$dropDown = this; this.$button = $('button.absol-hmenu-button', this); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$button, 'text', 'innerHTML'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$vmenu, 'items'); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$vmenu, 'activeTab'); this.$button.on('click', this.eventHandler.clickButton); this.$button.on('mouseenter', this.eventHandler.enterButton, true); this.$vmenu.on('press', this.eventHandler.pressItem, true); //property show not need because dropdown is itself return this; } HMenuItem.tag = 'HMenuItem'.toLowerCase(); HMenuItem.render = function () { return _({ tag: 'dropdown', extendEvent: ['press', 'enter'], child: ['button.absol-hmenu-button', 'vmenu' ] }); }; HMenuItem.eventHandler = {}; HMenuItem.eventHandler.clickButton = function (event) { event.menuItem = this; event.hmenuItem = this; this.emit('press', absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }), this); }; HMenuItem.eventHandler.enterButton = function (event) { event.menuItem = this; this.emit('enter', absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }), this); }; HMenuItem.eventHandler.pressItem = function (event) { this.emit('press', absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].copyEvent */ .ZP.copyEvent(event, { target: this }), this); }; HMenuItem.property = {}; HMenuItem.property.disabled = VMenuItem.property.disabled; HMenuItem.property.hidden = VMenuItem.property.hidden; HMenuItem.prototype.init = function (props) { props = props || {}; Object.assign(this, props); }; /*** * @extends AElement * @constructor */ function HMenu() { } HMenu.tag = 'hmenu'; HMenu.render = function () { return _({ class: 'absol-hmenu', extendEvent: ['press', 'enter', 'activetab', 'cancel'] }); }; HMenu.eventHandler = {}; HMenu.eventHandler.pressItem = function (event) { /** * this.activeTab can be undefined * undefine >= 0 => false * undefine < 0 => false */ if (event.menuItem.items && event.menuItem.items.length > 0 && !(this.activeTab >= 0)) { this.activeTab = event.menuItem._tabIndex; } else { event.isLeaf = (!event.menuItem.items || !event.menuItem.items.length); this.emit('press', event, this); } }; HMenu.eventHandler.enterItem = function (event) { if (this.activeTab >= 0) { this.activeTab = event.menuItem._tabIndex; } }; HMenu.eventHandler.clickSomewhere = function (event) { // if (EventEmitter.hitElement(this, event)) return; this.activeTab = -1; // window.removeEventListener('blur', this.eventHandler.clickSomewhere); }; HMenu.prototype._childFromItems = function (items) { this.clearChild(); this.$items = items.map(function (item, index) { var res = _({ tag: 'hmenuitem', props: Object.assign({ _tabIndex: index }, item), on: { press: { callback: this.eventHandler.pressItem, cap: true }, enter: { callback: this.eventHandler.enterItem, cap: true } } }); this.addChild(res); return res; }.bind(this)); }; HMenu.prototype.init = function (props) { Object.assign(this, props || {}); }; HMenu.property = {}; HMenu.property.items = { set: function (items) { this._childFromItems(items || []); }, get: function () { return this.$items; } }; HMenu.property.activeTab = { /*** * @this HMenu * @param tabIndex */ set: function (tabIndex) { var lastValue = this._activeTab; this._activeTab = tabIndex; for (var i = 0; i < this.$items.length; ++i) { var item = this.$items[i]; item.show = i == tabIndex && !item.disabled; item.activeTab = -1; if (i == tabIndex && !item.disabled) { item.$button && item.items && item.items.length > 0 && item.$button.addClass('absol-hmenu-button-hover'); } else { item.$button && item.$button.removeClass('absol-hmenu-button-hover'); } } if (!(lastValue >= 0) && (this._activeTab >= 0)) { if (this.blurTrigger) { this.blurTrigger.destroy(); } this.blurTrigger = new _tool_BlurTrigger__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z([this], "click", this.eventHandler.clickSomewhere, 100, 10); } else if ((lastValue >= 0) && !(this._activeTab >= 0)) { if (this.blurTrigger) { this.blurTrigger.destroy(); this.blurTrigger = null; } } if (lastValue >= 0) { if (tabIndex >= 0 && tabIndex != lastValue) { this.emit('activetab', { type: 'activetab', tabIndex: tabIndex, target: this }, this); } else if (!(tabIndex >= 0)) { this.emit('cancel', { type: 'cancel', lastActiveIndex: lastValue, target: this }, this); } } else { if (tabIndex >= 0) { this.emit('activetab', { type: 'activetab', tabIndex: tabIndex, target: this }, this); } } }, get: function () { return this._activeTab; } }; /*** * @extends AElement * @constructor */ function VRootMenu() { this._items = []; this.$attachhook = _({ tag: 'attachhook', props: { prevWidth: 0, requestUpdateSize: () => { var newWidth = this.getBoundingClientRect().width; if (newWidth === this.$attachhook.prevWidth) return; this.$attachhook.prevWidth = newWidth; Array.prototype.forEach.call(this.childNodes, elt => { if (elt.autoFixParentSize) { elt.autoFixParentSize(); } }); } }, on: { attached: () => { absol_src_HTML5_ResizeSystem__WEBPACK_IMPORTED_MODULE_6__/* ["default"].add */ .Z.add(this.$attachhook); this.$attachhook.requestUpdateSize(); } } }).addTo(this); this.items = []; } VRootMenu.tag = 'VRootMenu'.toLowerCase(); VRootMenu.render = function () { return _({ class: ['as-v-root-menu'], extendEvent: ['press', 'enter', 'activetab', 'cancel'] }); }; VRootMenu.prototype._childFromItems = function (items) { var thisM = this; while (this.lastChild && this.lastChild !== this.$attachhook) this.lastChild.remove(); while (this.firstChild && this.firstChild !== this.$attachhook) this.firstChild.remove(); this.$items = items.map(function (item, i) { var itemElt; if (typeof item === 'string' && (item.substr(0, 1) === '-' || item.substr(0, 1) === '=')) { itemElt = _('vmenuline'); } else if ((0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* .isDomNode */ .mV)(item)) { itemElt = item; } else if (item.child || item.class || item.tag || item.style || typeof item === 'string') { itemElt = _(item); } else { itemElt = _({ tag: 'vmenuitem', props: item, on: { enter: thisM.eventHandler.enterItem, press: thisM.eventHandler.pressItem } }); } itemElt._tabIndex = i; thisM.addChild(itemElt); return itemElt; }); this.$attachhook.prevWidth = 0; this.$attachhook.requestUpdateSize(); (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$$)('img', this).filter(x => !!x.getAttribute('src') && !x.classList.contains('absol-vmenu-button-icon')).forEach(elt => { (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* .waitImageLoaded */ .Lp)(elt).then(() => this.$attachhook.requestUpdateSize()); }); }; VRootMenu.property = Object.assign({}, HMenu.property); VRootMenu.eventHandler = Object.assign({}, HMenu.eventHandler); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install([HMenu, VMenuItem, VMenu, Dropright, VMenuLine, Dropdown, HMenuItem, VRootMenu]); /***/ }), /***/ 3488: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var _FlexiconButton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3929); /* harmony import */ var _css_messagedialog_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3163); /* harmony import */ var _css_messagedialog_css__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_css_messagedialog_css__WEBPACK_IMPORTED_MODULE_2__); /*** * @extends AElement * @constructor */ function MessageDialog() { this.$header = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-message-dialog-header', this); this.$title = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: 'span', class: 'as-message-dialog-title', child: { text: '' } }); this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-message-dialog-body', this); this.$footer = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-message-dialog-footer', this); this.$actionBtns = []; } MessageDialog.tag = 'MessageDialog'.toLowerCase(); MessageDialog.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ extendEvent: ['action'], class: 'as-message-dialog', child: [ { class: 'as-message-dialog-header', }, { class: 'as-message-dialog-body' }, { class: 'as-message-dialog-footer' } ] }); }; ['addChild', 'removeChild', 'clearChild', 'addChildBefore', 'addChildAfter'].forEach(key => { MessageDialog.prototype[key] = function () { this.$body[key].apply(this.$body, arguments); return this; }; }); MessageDialog.prototype._makeActionBtn = function (action) { var button = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: _FlexiconButton__WEBPACK_IMPORTED_MODULE_1__/* ["default"].tag */ .Z.tag, class: action.class || [], props: { text: action.text || action.name, icon: action.icon || null }, on: { click: (event) => { this.emit('action', { type: 'action', target: this, originalEvent: event, action: action }, this); } } }); if (action.name) button.attr('data-name', action.name); return button; }; MessageDialog.property = {}; MessageDialog.property.dialogActions = { /*** * @this MessageDialog * @param actions */ set: function (actions) { this._actions = actions || []; this.$actionBtns.forEach(button => button.remove()); this.$actionBtns = this._actions.map(action => this._makeActionBtn(action)); this.$footer.addChild(this.$actionBtns); }, get: function () { return this._actions; } }; MessageDialog.property.dialogTitle = { set: function (value) { this._dialogTitle = value; this.$title.firstChild.data = ''; this.$title.attr('data-ml-key', undefined); if (typeof value === "string") { this.$title.firstChild.data = value; } else if (value && value.mlKey) { this.$title.firstChild.data = ''; this.$title.attr('data-ml-key', value.mlKey); } if (value && !this.$title.parentElement) { this.$header.addChild(this.$title); } else if (!value && this.$title.parentElement) { this.$title.remove(); } }, get: function () { return this._dialogTitle; } }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(MessageDialog); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (MessageDialog); /***/ }), /***/ 9826: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_modal_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6881); /* harmony import */ var _css_modal_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_modal_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; function Modal() { this._contentAlign = []; this.contentAlign = 'middle center'; this.$content = $('.as-modal-content', this); } Modal.tag = 'modal'; Modal.render = function () { return _({ class: 'as-modal', child: '.as-modal-content' }); }; ['findChildBefore', 'findChildAfter', 'removeChild', 'clearChild', 'addChild'].forEach(function (key) { Modal.prototype[key] = function () { this.$content[key].apply(this.$content, arguments); } }); Modal.prototype.getChildren = function (){ return this.$content.children; }; Modal.property = {}; Modal.property.show = { set: function (value) { if (value) this.removeClass('as-hidden'); else this.addClass('as-hidden'); }, get: function () { return !this.hasClass('as-hidden'); } }; Modal.property.contentAlign = { set: function (value) { var thisM = this; this._contentAlign.forEach(function (name) { thisM.removeClass('as-' + name); }) value = value || ''; if (typeof value === 'string') { this._contentAlign = value.split(/\s+/); } else if (value instanceof Array) { this._contentAlign = value; } else { throw new Error("Invalid contentAlign!"); } var thisM = this; this._contentAlign.forEach(function (name) { thisM.addClass('as-' + name); }) }, get: function () { return this._contentAlign.join(' '); } } _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Modal); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Modal); /***/ }), /***/ 1812: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "q": () => (/* binding */ loadLanguageModule) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); var counter = 30; function makeCss(data) { var cssText = Object.keys(data).map(key => { return [ '[data-ml-key=' + JSON.stringify(key) + ']::before {', ' content: ' + JSON.stringify(data[key]) + ';', '}' ].join('\n'); }).join('\n\n'); (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: 'style', attr: { type: 'text/css' }, props: { innerHTML: cssText } }).addTo(document.head); } var data = { txt_ok: 'OK', txt_cancel: 'Cancel', txt_close: 'Close', txt_option: 'Option', txt_check_all: 'Check All', txt_select_value: '-- Select values --' }; makeCss(data); var overrideData = {}; var LanguageModuleLoaded = false; function loadLanguageModule() { if (LanguageModuleLoaded) return; var text; var newest = false, key; if (window['LanguageModule'] && window['LanguageModule'].data && window['LanguageModule'].data.length > 0) { LanguageModuleLoaded = true; for (key in data) { text = window['LanguageModule'].text(key); if (!text.startsWith('[key:') && text !== data[key]) { overrideData[key] = text; newest = true; } } if (newest) makeCss(overrideData); } } function waitLanguage() { if (window['LanguageModule'] && window['LanguageModule'].data && window['LanguageModule'].data.length > 0) { loadLanguageModule(); } else { if (counter--) setTimeout(waitLanguage, 400 + Math.floor(16000 / counter / counter)); } } waitLanguage(); /* unused harmony default export */ var __WEBPACK_DEFAULT_EXPORT__ = ({}); /***/ }), /***/ 7570: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__), /* harmony export */ "sP": () => (/* binding */ NPDropdownButton), /* harmony export */ "PL": () => (/* binding */ NPSection), /* harmony export */ "Bd": () => (/* binding */ NPList), /* harmony export */ "Ee": () => (/* binding */ NPItem), /* harmony export */ "FW": () => (/* binding */ MNPNotificationVirtualDropdown) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1477); /* harmony import */ var _css_notificationpanel_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5810); /* harmony import */ var _css_notificationpanel_css__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_css_notificationpanel_css__WEBPACK_IMPORTED_MODULE_2__); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7951); /* harmony import */ var absol_src_HTML5_ResizeSystem__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(6700); /* harmony import */ var _QuickMenu__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(1274); /* harmony import */ var absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7807); /* harmony import */ var _RelativeTimeText__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(9441); /* harmony import */ var _FlexiconButton__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(3929); /* harmony import */ var _mobile_MHeaderBar__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(9277); /** * @extends AElement * @constructor */ function NotificationPanel() { } NotificationPanel.tag = 'NotificationPanel'.toLowerCase(); NotificationPanel.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-notification-panel', }); }; NotificationPanel.prototype.addChild = function () { var res = absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_5__/* ["default"].prototype.addChild.apply */ .Z.prototype.addChild.apply(this, arguments); absol_src_HTML5_ResizeSystem__WEBPACK_IMPORTED_MODULE_6__/* ["default"].updateUp */ .Z.updateUp(this, true); return res; }; NotificationPanel.prototype.closeAllDropdown = function () { Array.prototype.forEach.call(this.childNodes, c => { if (typeof c.close === "function") c.close(); }); }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(NotificationPanel); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (NotificationPanel); /** /** * @extends AElement * @constructor */ function NPDropdownButton() { this.$dropdown = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-dropdown', this); this.$iconCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-icon-ctn', this); this.$icon = null this.$count = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-count', this); this._count = 0; this.$btn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-btn', this); this.$btn.on('click', this.eventHandler.click); this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-dropdown-body', this); this.$quickMenuBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-quick-menu-btn', this); this.$quickMenuCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-db-dropdown-quick-menu-ctn', this); /** * @name count * @type {number} * @memberOf NPDropdownButton# */ } NPDropdownButton.tag = 'NPDropdownButton'.toLowerCase(); NPDropdownButton.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-np-dropdown-button', extendEvent: ['click', 'close', 'open'], child: [ { tag: 'button', class: 'as-np-db-btn', child: [ { class: 'as-np-db-icon-ctn', }, { class: 'as-np-db-count' } ] }, { class: ['as-np-db-dropdown', 'as-dropdown-box-common-style'], child: [ { class: 'as-np-db-dropdown-quick-menu-ctn', style: { display: 'none' }, child: [ { tag: 'button', class: ['as-transparent-button', 'as-np-db-quick-menu-btn'], child: 'span.mdi.mdi-dots-horizontal' } ] }, { class: 'as-np-db-dropdown-body' } ] } ] }); }; ['addChild', 'removeChild', 'clearChild'].forEach(function (key) { NPDropdownButton.prototype[key] = function () { return this.$body[key].apply(this.$body, arguments); }; }); NPDropdownButton.prototype.getChildNodes = function () { return Array.prototype.slice.call(this.$body.childNodes); }; NPDropdownButton.prototype.getFirstChild = function () { return this.$body.firstChild; }; NPDropdownButton.prototype.getLastChild = function () { return this.$body.lastChild; }; NPDropdownButton.prototype.addChildBefore = function (child, bf) { //adapt method if (bf && bf === this.lastChild) bf = this.$body.lastChild; else if (bf && bf === this.firstChild) bf = this.$body.firstChild; return this.$body.addChildBefore(child, bf); }; NPDropdownButton.prototype.addChildAfter = function (child, at) { if (at === this.lastChild) at = this.$dropdown.lastChild; else if (at === this.firstChild) at = this.$dropdown.firstChild; return this.$body.addChildAfter(child, at); }; NPDropdownButton.prototype.open = function () { if (this.hasClass('as-active')) return; this.addClass('as-active'); var bound = this.getBoundingClientRect(); var screenSize = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* .getScreenSize */ .tE)(); if (bound.left < screenSize.width / 2) { this.$dropdown.addStyle({ top: bound.bottom + 5 + 'px', '--max-height': `calc(90vh - ${bound.bottom + 110}px)`, left: '20px', right: 'unset' }); } else { this.$dropdown.addStyle({ top: bound.bottom + 5 + 'px', '--max-height': `calc(90vh - ${bound.bottom + 110}px)`, right: '20px', left: 'unset' }); } this.$dropdown.addStyle('z-index', (0,_utils__WEBPACK_IMPORTED_MODULE_1__.findMaxZIndex)(this) + 2); setTimeout(() => { if (this.hasClass('as-active')) window.addEventListener('click', this.eventHandler.clickOut); }, 3); this.emit('open', { type: 'open' }, this); }; NPDropdownButton.prototype.close = function () { if (!this.hasClass('as-active')) return; this.removeClass('as-active'); window.removeEventListener('click', this.eventHandler.clickOut); this.emit('close', { type: 'close' }, this); }; NPDropdownButton.property = {}; NPDropdownButton.property.count = { set: function (value) { value = Math.round(value); if (!(0,_utils__WEBPACK_IMPORTED_MODULE_1__.isNaturalNumber)(value)) value = 0; this._count = value; if (value > 0) { this.$count.attr('data-count', value); } else { this.$count.attr('data-count', null); } }, get: function () { return this._count; } }; NPDropdownButton.property.icon = { set: function (value) { if (this.$icon) this.$icon.remove(); this.$iconCtn.clearChild(); var elt; if ((0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* .isDomNode */ .mV)(value)) { if (value.parentElt) value = value.cloneNode(true); elt = value; } else if (value && (typeof value === 'string' || typeof value === 'object')) { if (value === 'default') value = 'span.mdi.mdi-equal'; elt = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)(value); } if (elt) { this.$iconCtn.addChild(elt); this.$icon = elt; this.addClass('as-has-icon'); } else { this.$icon = null; value = null; this.removeClass('as-has-icon'); } this._icon = value; }, get: function () { return this._icon; } }; NPDropdownButton.property.quickmenu = { set: function (value) { value = value || null; if (this.quickmenuInstance) { this.quickmenuInstance.remove(); } this._quickmenu = value; if (value) { this.$quickMenuCtn.removeStyle('display'); this.$dropdown.addClass('as-has-quick-menu'); this.quickmenuInstance = new _QuickMenu__WEBPACK_IMPORTED_MODULE_7__/* .QuickMenuInstance */ .U(this.$quickMenuBtn, Object.assign({ triggerEvent: 'click', anchor: [2, 5], menuCtn: this.$quickMenuCtn }, value)); } else { this.$dropdown.removeClass('as-has-quick-menu'); this.$quickMenuCtn.addStyle('display', 'none'); } }, get: function () { return this._quickmenu; } } NPDropdownButton.eventHandler = {}; /** * @this NPDropdownButton * @param {MouseEvent} event */ NPDropdownButton.eventHandler.click = function (event) { this.emit('click', { type: 'click', originalEvent: event }, this); if (this.hasClass('as-active')) { this.close(); } else { this.open(); } }; /** * @this NPDropdownButton * @param {MouseEvent} event */ NPDropdownButton.eventHandler.clickOut = function (event) { if ((0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* .hitElement */ .EY)(this, event)) return; this.close(); } _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(NPDropdownButton); /** * @extends AElement * @constructor */ function NPSection() { this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-section-body', this); this.$name = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-section-name', this); this.$action = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-section-action', this); this.$action.on('click', (event) => { this.emit('action', { type: 'action', originalEvent: event }, this); }); } NPSection.tag = 'NPSection'.toLowerCase(); NPSection.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-np-section', extendEvent: ['action'], child: [ { class: 'as-np-section-header', child: [ { class: 'as-np-section-name', attr: { 'data-name': '' } }, { class: 'as-np-section-action' } ] }, { class: 'as-np-section-body', } ] }); }; ['addChild', 'removeChild', 'findChildAfter', 'findChildBefore'].forEach(key => { NPSection.prototype[key] = function () { return this.$body[key].apply(this.$body, arguments); } }); NPSection.prototype.getChildNodes = function () { return Array.prototype.slice.call(this.$body.childNodes); }; NPSection.prototype.getFirstChild = function () { return this.$body.firstChild; }; NPSection.prototype.getLastChild = function () { return this.$body.lastChild; }; NPSection.prototype.addChildBefore = function (child, bf) { if (bf === this.firstChild) bf = this.$body.firstChild; else if (bf === this.lastChild) bf = this.$body.lastChild; return this.$body.addChildBefore(child, bf); }; NPSection.prototype.addChildAfter = function (child, at) { if (at === this.firstChild) at = this.$body.firstChild; else if (at === this.lastChild) at = this.$body.lastChild; return this.$body.addChildAfter(child, at); }; NPSection.property = {}; NPSection.property.name = { set: function (value) { value = value || ''; value = value + ''; this.$name.attr('data-name', value); }, get: function () { return this.attr('data-name'); } }; NPSection.property.actionText = { set: function (value) { value = value || ''; value = value + ''; if (value) this.$action.attr('data-text', value); else { this.$action.attr('data-text', null); } }, get: function () { return this.attr('data-text'); } }; /** * @extends AElement * @constructor */ function NPList() { this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-list-body', this); this._moreText = ''; this.$moreCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-list-more-ctn', this); this.$moreBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-list-more-btn', this.$moreCtn); this.$moreBtn.on('click', (event) => { this.emit('more', { type: 'more', originalEvent: event, target: this }, this); }); /** * @name moreText * @type {string} * @memberOf NPList# */ } NPList.tag = "NPList".toLowerCase(); NPList.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-np-list', extendEvent: ['more'], child: [ { class: 'as-np-list-body', }, { class: 'as-np-list-more-ctn', style: { display: 'none' }, child: { tag: _FlexiconButton__WEBPACK_IMPORTED_MODULE_10__/* ["default"] */ .Z, class: 'as-np-list-more-btn' } } ] }); }; ['addChild', 'removeChild', 'findChildAfter', 'findChildBefore'].forEach(key => { NPList.prototype[key] = function () { return this.$body[key].apply(this.$body, arguments); } }); NPList.prototype.getChildNodes = function () { return Array.prototype.slice.call(this.$body.childNodes); }; NPList.prototype.getFirstChild = function () { return this.$body.firstChild; }; NPList.prototype.getLastChild = function () { return this.$body.lastChild; }; NPList.prototype.addChildBefore = function (child, bf) { if (bf === this.firstChild) bf = this.$body.firstChild; else if (bf === this.lastChild) bf = this.$body.lastChild; return this.$body.addChildBefore(child, bf); }; NPList.prototype.addChildAfter = function (child, at) { if (at === this.firstChild) at = this.$body.firstChild; else if (at === this.lastChild) at = this.$body.lastChild; return this.$body.addChildAfter(child, at); }; NPList.prototype.scrollToEnd = function () { this.scrollTop = this.scrollHeight; }; NPList.property = {}; NPList.property.moreText = { set: function (value) { value = value || ''; if (value) { this.$moreCtn.removeStyle('display'); } else { this.$moreCtn.addStyle('display', 'none'); } this.$moreBtn.text = value; }, get: function () { return this.$moreBtn.text; } }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(NPList); /** * @extends AElement * @constructor */ function NPItem() { this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-item-body', this); this.$body.on('click', event => { this.emit('click', { type: 'click', originalEvent: event }, this); }); this.$unreadBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-item-unread-btn', this); this.$unreadBtn.on('click', event => { this.unread = false; this.emit('unreadchange', { type: 'unreadchange', target: this }, this); }); this.$pinBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-item-pin-btn', this); this.$pinBtn.on('click', event => { this.pin = false; this.emit('pinchange', { type: 'pinchange', target: this }, this); }); this.$quickMenuBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-item-quick-menu-btn', this); this.$quickMenuCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-np-item-quick-menu-ctn', this); this._quickmenu = null; this.quickmenuInstance = null; } NPItem.tag = 'NPItem'.toLowerCase(); ['addChild', 'removeChild', 'addChildBefore', 'addChildAfter', 'findChildAfter', 'findChildBefore', 'clearChild'].forEach(key => { NPItem.prototype[key] = function () { return this.$body[key].apply(this.$body, arguments); } }); NPItem.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-np-item', extendEvent: ['click', 'unreadchange', 'pinchange'], child: [ { tag: _RelativeTimeText__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, class: 'as-np-item-body', }, { tag: 'button', class: 'as-np-item-unread-btn' }, { tag: 'button', class: 'as-np-item-pin-btn', child: 'span.mdi.mdi-pin' }, { class: 'as-np-item-quick-menu-ctn', style: { display: 'none' }, child: [ { tag: 'button', class: ['as-np-item-quick-menu-btn'], child: 'span.mdi.mdi-dots-horizontal' } ] } ] }); }; NPItem.property = {}; NPItem.property.time = { set: function (value) { value = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_8__.implicitDate)(value); this.$body.time = value; }, get: function () { return this.$time.time; } }; NPItem.property.unread = { set: function (value) { if (value) { this.addClass('as-unread'); } else { this.removeClass('as-unread'); } }, get: function () { return this.hasClass('as-unread'); } }; NPItem.property.pin = { set: function (value) { if (value) { this.addClass('as-pin'); } else { this.removeClass('as-pin'); } }, get: function () { return this.hasClass('as-pin'); } }; NPItem.property.quickmenu = { set: function (value) { value = value || null; if (this.quickmenuInstance) { this.quickmenuInstance.remove(); } this._quickmenu = value; if (value) { this.$quickMenuCtn.removeStyle('display'); this.quickmenuInstance = new _QuickMenu__WEBPACK_IMPORTED_MODULE_7__/* .QuickMenuInstance */ .U(this.$quickMenuBtn, Object.assign({ triggerEvent: 'click', anchor: [2, 5], menuCtn: this.$quickMenuCtn }, value)); } else { this.$quickMenuCtn.addStyle('display', 'none'); } }, get: function () { return this._quickmenu; } }; /** * similar to NPDropdownButton interface * @extends AElement * @constructor */ function MNPNotificationVirtualDropdown() { document.body.appendChild(this); this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-mb-vd-body', this); this.$headerBar = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-mb-vd-header-bar', this) .on('action', this.eventHandler.action); _mobile_MHeaderBar__WEBPACK_IMPORTED_MODULE_11__/* ["default"].on */ .Z.on('clicknotification', () => { this.open(); }); } MNPNotificationVirtualDropdown.tag = 'MNPNotificationVirtualDropdown'.toLowerCase(); MNPNotificationVirtualDropdown.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ extendEvent: ['click', 'close', 'open'], class: ['as-mobile-notification-virtual-dropdown', 'as-hidden'], child: [ { tag: _mobile_MHeaderBar__WEBPACK_IMPORTED_MODULE_11__/* ["default"] */ .Z, class: 'as-mb-vd-header-bar', props: { actionIcon: 'span.mdi.mdi-arrow-left' } }, { class: 'as-mb-vd-body' } ] }); }; MNPNotificationVirtualDropdown.prototype.open = function () { this.emit('click', { type: 'click' }, this); if (!this.hasClass('as-hidden')) return; this.removeClass('as-hidden'); this.emit('open', { type: 'close' }, this); }; MNPNotificationVirtualDropdown.prototype.close = function () { this.emit('click', { type: 'click' }, this); if (this.hasClass('as-hidden')) return; this.addClass('as-hidden'); this.emit('close', { type: 'close' }, this); }; MNPNotificationVirtualDropdown.prototype.getChildNodes = function () { return Array.prototype.slice.call(this.$body.childNodes); }; MNPNotificationVirtualDropdown.prototype.getChildren = function () { return this.getChildNodes(); }; MNPNotificationVirtualDropdown.prototype.getFirstChild = function () { return this.$body.firstChild; }; MNPNotificationVirtualDropdown.prototype.getLastChild = function () { return this.$body.lastChild; }; MNPNotificationVirtualDropdown.prototype.addChild = function (elt) { if (elt.tagName === 'H3' || elt.tagName === 'H4') { this.$headerBar.title = elt.innerText; elt.addStyle('display', 'none'); } return this.$body.addChild(...arguments); } MNPNotificationVirtualDropdown.property = {}; MNPNotificationVirtualDropdown.property.count = { set: function (value) { _mobile_MHeaderBar__WEBPACK_IMPORTED_MODULE_11__/* ["default"].notificationCount */ .Z.notificationCount = value; }, get: function () { return _mobile_MHeaderBar__WEBPACK_IMPORTED_MODULE_11__/* ["default"].notificationCount */ .Z.notificationCount; } }; MNPNotificationVirtualDropdown.property.quickmenu = { set: function (value) { this.$headerBar.quickmenu = value; }, get: function () { return this.$headerBar.quickmenu } }; MNPNotificationVirtualDropdown.eventHandler = {}; MNPNotificationVirtualDropdown.eventHandler.action = function () { this.close(); }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(MNPNotificationVirtualDropdown); /***/ }), /***/ 7315: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_onscreenwidget_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7832); /* harmony import */ var _css_onscreenwidget_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_onscreenwidget_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _Hanger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(655); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6628); /* harmony import */ var absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(557); /* harmony import */ var absol_src_String_stringGenerate__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(1334); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var $$ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$$ */ .Z.$$; /*** * @extends Hanger * @constructor */ function OnScreenWidget() { this.id = 'unset-id-' + (0,absol_src_String_stringGenerate__WEBPACK_IMPORTED_MODULE_5__.randomIdent)(); this.on({ dragstart: this.eventHandler.widgetStartDrag, drag: this.eventHandler.widgetDrag, dragend: this.eventHandler.widgetDragEnd }); this.addEventListener('click', function (event) { if (!this._preventClick) this.emit('click', event, this); }); this.$attachhook = _('attachhook').addTo(this); this.$attachhook.on('attached', this.eventHandler.attached); this.config = null; } OnScreenWidget.tag = 'OnScreenWidget'.toLowerCase(); OnScreenWidget.render = function () { return _({ tag: 'hanger', extendEvent: 'click', class: ['as-onscreen-widget', 'as-size-loading'], props: { hangOn: 3 } }); }; OnScreenWidget.prototype.configPrefix = 'on-screen-widget-'; OnScreenWidget.prototype._genConfig = function () { this._widgetBound = this.getBoundingClientRect(); var screenSize = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* .getScreenSize */ .tE)(); return { cx: (this._widgetBound.left + this._widgetBound.width / 2) * 100 / screenSize.width, cy: (this._widgetBound.top + this._widgetBound.height / 2) * 100 / screenSize.height }; }; OnScreenWidget.prototype._saveConfig = function () { var id = this.id || ''; if (id.startsWith('unset-id-') || !this.config) return; localStorage.setItem(this.configPrefix + id, JSON.stringify(this.config)); }; OnScreenWidget.prototype._loadConfig = function () { var id = this.id || ''; if (id.startsWith('unset-id-')) return; var config = null; try { config = JSON.parse(localStorage.getItem(this.configPrefix + id)); if ((typeof config !== "object") || (typeof config.cx !== "number") || (typeof config.cy !== 'number')) { config = this.config || this._genConfig(); } } catch (error) { config = this.config || this._genConfig(); } var cx = config.cx || 0; var cy = config.cy || 0; this.addStyle({ '--cx': cx / 100, '--cy': cy / 100 }); this.config = config; }; OnScreenWidget.prototype._updateCSSSize = function () { var bound = this.getBoundingClientRect(); this.addStyle({ '--client-height': bound.height + 'px', '--client-width': bound.width + 'px' }); this.removeClass('as-size-loading'); }; /*** * * @type {OnScreenWidget|{}} */ OnScreenWidget.eventHandler = {}; OnScreenWidget.eventHandler.attached = function () { var images = $$('img', this); var syncs = images.map(function (img) { if (img.classList.contains('absol-attachhook')) return Promise.resolve(); return (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* .waitImageLoaded */ .Lp)(img, 100); }); var thisW = this; Promise.all(syncs).then(function () { thisW._updateCSSSize(); thisW._loadConfig(); }); }; OnScreenWidget.eventHandler.widgetStartDrag = function (event) { this._widgetBound = this.getBoundingClientRect(); this._preventClick = true; }; OnScreenWidget.eventHandler.widgetDrag = function (event) { event.preventDefault(); var screenSize = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* .getScreenSize */ .tE)(); var p0 = new absol_src_Math_Vec2__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z(this._widgetBound.left, this._widgetBound.top); var dv = event.currentPoint.sub(event.startingPoint); var p1 = p0.add(dv); var cx = (p1.x - 2) * 100 / (screenSize.width - this._widgetBound.width - 4); var cy = (p1.y - 2) * 100 / (screenSize.height - this._widgetBound.height - 4); cx = Math.max(0, Math.min(100, cx)); cy = Math.max(0, Math.min(100, cy)); this.addStyle({ '--cx': cx / 100, '--cy': cy / 100 }); if (this.config) { this.config.cx = cx; this.config.cy = cy; } }; OnScreenWidget.eventHandler.widgetDragEnd = function () { var thisWG = this; setTimeout(function () { thisWG._preventClick = false; }, 100); this._saveConfig(); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(OnScreenWidget); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (OnScreenWidget); /***/ }), /***/ 6535: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_progressbar_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9862); /* harmony import */ var _css_progressbar_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_progressbar_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; function ProgressBar() { this._value = 0; this._variant = null; this.$value = $('.as-progress-bar-value', this); this._striped = false; this._animated = false; } ProgressBar.tag = 'ProgressBar'.toLowerCase(); ProgressBar.render = function () { return _({ class: 'as-progress-bar', child: { class: 'as-progress-bar-value' } }); }; ProgressBar.property = {}; /** * @type {ProgressBar} */ ProgressBar.property.variant = { set: function (value) { if (this._variant) { this.removeClass('as-variant-' + this._variant); } if (value) { this.addClass('as-variant-' + value) } else { value = null; } this._variant = value; }, get: function () { return this._variant; } }; /** * @type {ProgressBar} */ ProgressBar.property.value = { set: function (value) { value = Math.max(0, Math.min(1, value || 0)); this._value = value; this.$value.addStyle('width', value * 100 + '%'); }, get: function () { return this._value; } }; ProgressBar.property.animated = { set: function (value) { value = !!value; this._striped = value; if (value) { this.addClass('as-animated'); } else { this.removeClass('as-animated'); } }, get: function () { return this._animated; } } ProgressBar.property.striped = { set: function (value) { value = !!value; this._striped = value; if (value) { this.addClass('as-striped'); } else { this.removeClass('as-striped'); } }, get: function () { return this._striped; } } _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ProgressBar); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ProgressBar); /***/ }), /***/ 1274: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "U": () => (/* binding */ QuickMenuInstance), /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6628); /* harmony import */ var absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9399); /* harmony import */ var _Menu__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(407); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1477); /* harmony import */ var _Follower__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7094); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(863); /* harmony import */ var absol_src_Code_safeThrow__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(5650); /* harmony import */ var absol_src_Code_noop__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(1432); var isMobile = absol_src_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_2__/* ["default"].isMobile */ .Z.isMobile; var _ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$ */ .Z.$; function QuickMenu() { //like context menu without right-click this._contextMenuSync = Promise.resolve(); } QuickMenu.tag = 'QuickMenu'.toLowerCase(); QuickMenu.render = function () { return _({ tag: 'vmenu', extendEvent: 'requestcontextmenu', class: [ 'as-quick-menu', 'as-bscroller' ], style: { 'overflow-y': 'auto', 'box-sizing': 'border-box' } }); }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(QuickMenu); /*** * * @param {AElement} elt * @param opt * @constructor */ function QuickMenuInstance(elt, opt) { this.id = (Math.random() * 10000 >> 0) + '' + new Date().getTime(); /*** * * @type {"OPEN"|"CLOSE"} */ this.state = 'CLOSE'; this._willAddClickOut = -1; this.elt = elt; /** * * @type {object|{triggerEvent:string, menuProps,getMenuProps, anchor, onClick, onSelect,onOpen, onClose, menuCtn, getAnchor}} */ this.opt = Object.assign({}, opt); for (var key in this) { if (key.startsWith('_on')) { this[key] = this[key].bind(this); } } this._init(); } QuickMenuInstance.prototype._init = function () { this.elt.classList.add('as-quick-menu-trigger'); if (this.opt.triggerEvent === 'mousedown') $(this.elt).on('contextmenu', function (event) { event.preventDefault(); }).attr('oncontextmenu', "return false;"); if (this.opt.triggerEvent) { this.elt.addEventListener(this.opt.triggerEvent, this._onClick, true); } else this.elt.addEventListener('click', this._onClick, true); if (!this.elt.revokeResource) { this.elt.revokeResource = ()=>{ this.elt.revokeResource = absol_src_Code_noop__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z; this.remove(); } } }; QuickMenuInstance.prototype._deinit = function () { if (this.state === "OPEN") this.close(); this.elt.classList.remove('as-quick-menu-trigger'); if (this.opt.triggerEvent) { this.elt.removeEventListener(this.opt.triggerEvent, this._onClick, true); } else { this.elt.removeEventListener('click', this._onClick, true); } this.elt = null; this.opt = null; for (var key in this) { if (key.startsWith('_on')) { this[key] = absol_src_Code_noop__WEBPACK_IMPORTED_MODULE_7__/* ["default"] */ .Z; } } }; QuickMenuInstance.prototype.getMenuProps = function () { var props; if (this.opt.getMenuProps) { props = this.opt.getMenuProps(); } else { props = this.opt.menuProps; } props = props || {}; return Object.assign({ extendClasses: [], extendStyle: {} }, props); }; QuickMenuInstance.prototype.remove = function () { this._deinit(); }; QuickMenuInstance.prototype._onClick = function (event) { if (this.opt.triggerEvent === 'mousedown') { event.preventDefault(); } var event = (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_6__/* .copyEvent */ .FG)(event, { canceled: false, cancel: function () { this.canceled = true; } }); if (this.opt.onClick) { this.opt.onClick.call(this, event); } if (!event.canceled) this.toggle(); }; QuickMenuInstance.prototype._onClickOut = function (event) { if ((0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_6__/* .hitElement */ .EY)(this.elt, event) || (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_6__/* .hitElement */ .EY)(QuickMenu.$elt, event)) return; this.close(); }; QuickMenuInstance.prototype.onSelect = function (item) { item = item.__originalItem__ || item; if (item.items && item.items.length > 0) return; if (this.opt.onSelect) this.opt.onSelect(item); this.close(); } QuickMenuInstance.prototype.open = function () { if (QuickMenu.runningInstance === this) return; if (this.state !== "CLOSE") return; if (QuickMenu.runningInstance) QuickMenu.runningInstance.close(); QuickMenu.runningInstance = this; this.state = 'OPEN'; this.elt.classList.add('as-quick-menu-attached'); this._willAddClickOut = setTimeout(() => { this._willAddClickOut = -1; document.addEventListener('click', this._onClickOut, false); followerElt.updatePosition(); menuElt.addStyle('visibility', 'visible'); }, isMobile ? 33 : 2); var anchor = this.getAnchor(); var followerElt = QuickMenu.$follower; var menuElt = QuickMenu.$elt; this.originProps = this.getMenuProps(); this.copyProps = Object.assign({}, this.originProps); if (typeof this.originProps.items === "function") { this.copyProps.items = this.originProps.items.call(this); } else { this.copyProps.items = this.originProps.items || []; } this.copyProps.items = this.copyProps.items.map(function visit(item) { var cpyItem = item; if (typeof item === "string") cpyItem = item; else if (item && (typeof item.text === "string")) { cpyItem = Object.assign({ __originalItem__: item }, item); if (cpyItem.items && cpyItem.items.map) cpyItem.items = cpyItem.items.map(visit); } return cpyItem; }); Object.assign(menuElt, this.copyProps); followerElt.addClass('absol-active'); if (anchor === 'modal') { followerElt.addClass('as-anchor-modal'); followerElt.anchor = []; } else { followerElt.removeClass('as-anchor-modal'); followerElt.anchor = anchor; } this._onSizeNeedUpdate(); QuickMenu.$follower.on('preupdateposition', this._onSizeNeedUpdate); followerElt.followTarget = this.elt; followerElt.sponsorElement = this.elt; menuElt.addStyle('visibility', 'hidden'); followerElt.addTo(this.opt.menuCtn || document.body); followerElt.addClass('absol-active'); if (this.opt.onOpen) { try { this.opt.onOpen.call(this); } catch (err) { (0,absol_src_Code_safeThrow__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z)(err); } } }; QuickMenuInstance.prototype.close = function () { if (QuickMenu.runningInstance !== this) return; if (this.state !== "OPEN") return; if (this.opt.onClose) { try { this.opt.onClose.call(this); } catch (err) { (0,absol_src_Code_safeThrow__WEBPACK_IMPORTED_MODULE_8__/* ["default"] */ .Z)(err); } } this.state = 'CLOSE'; this.elt.classList.remove('as-quick-menu-attached'); QuickMenu.$elt.removeStyle('--available-height'); var followerElt = QuickMenu.$follower; followerElt.addClass('absol-active'); followerElt.remove(); QuickMenu.$follower.off('preupdateposition', this._onSizeNeedUpdate); if (this._willAddClickOut >= 0) { clearTimeout(this._willAddClickOut); } else { document.removeEventListener('click', this._onClickOut, false); } QuickMenu.runningInstance = null; }; QuickMenuInstance.prototype._onSizeNeedUpdate = function () { (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$$)('VMenuItem'.toLowerCase(), QuickMenu.$elt).forEach(e => { if (e.autoFixParentSize) e.autoFixParentSize(); }); var screenSize = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* .getScreenSize */ .tE)(); var eltBound = this.elt.getBoundingClientRect(); var outRect = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* .traceOutBoundingClientRect */ .DI)(this.elt); var isOut = false; if (eltBound.left > outRect.right || eltBound.right < outRect.left || eltBound.top > outRect.bottom || eltBound.bottom < outRect.top) isOut = true; if (isOut || (!eltBound.width && !eltBound.height)) { setTimeout(() => { this.close(); }, 0); } var aTop = eltBound.bottom; var aBottom = screenSize.height - eltBound.top; QuickMenu.$elt.addStyle('--available-height', (Math.max(aTop, aBottom) - 10) + 'px'); }; QuickMenuInstance.prototype.toggle = function () { if (this.state === "OPEN") { this.close(); } else if (this.state === 'CLOSE') { this.open(); } }; QuickMenuInstance.prototype.getAnchor = function () { var menuAnchors; var anchor = this.opt.getAnchor ? this.opt.getAnchor() : this.opt.anchor; if (typeof anchor == 'number') { menuAnchors = [anchor]; } else if (anchor instanceof Array) { menuAnchors = anchor; } else if (anchor === 'modal') { menuAnchors = 'modal'; } else { menuAnchors = QuickMenu.PRIORITY_ANCHORS; } return menuAnchors; }; QuickMenu.PRIORITY_ANCHORS = [0, 3, 7, 4, 1, 2, 6, 5]; QuickMenu.$elt = _('quickmenu'); /*** * * @type {Follower} */ QuickMenu.$follower = _({ tag: _Follower__WEBPACK_IMPORTED_MODULE_5__/* ["default"].tag */ .Z.tag, class: 'absol-context-menu-anchor', child: QuickMenu.$elt, on: { preupdateposition: function () { var bound = this.getBoundingClientRect(); var outBound = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* .traceOutBoundingClientRect */ .DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { QuickMenu.close(QuickMenu._session); } } } }); QuickMenu.$follower.cancelWaiting(); /*** * * @type {null|QuickMenuInstance} */ QuickMenu.runningInstance = null; QuickMenu._session = Math.random() * 10000000000 >> 0; QuickMenu._menuListener = undefined; QuickMenu.$elt.on('press', function (event) { if (QuickMenu.runningInstance) QuickMenu.runningInstance.onSelect((0,_utils__WEBPACK_IMPORTED_MODULE_4__.cleanMenuItemProperty)(event.menuItem)); if (QuickMenu._menuListener) QuickMenu._menuListener((0,_utils__WEBPACK_IMPORTED_MODULE_4__.cleanMenuItemProperty)(event.menuItem)); }); QuickMenu.show = function (element, menuProps, anchor, menuListener, darkTheme) { var instance = new QuickMenuInstance(element, { menuProps: menuProps, anchor: anchor, onSelect: menuListener, darkTheme: darkTheme }); instance.open(); }; QuickMenu.close = function (session) { if (QuickMenu.runningInstance && QuickMenu.runningInstance.id === session) QuickMenu.runningInstance.close(); }; QuickMenu.showWhenClick = function (element, menuProps, anchor, menuListener, darkTheme) { return new QuickMenuInstance(element, { menuProps: menuProps, anchor: anchor, onSelect: menuListener, darkTheme: darkTheme }); }; /** * @typedef {Object} QuickMenuAdaptor * @property {Function} getFlowedElement default is trigger * @property {Function} getMenuProps define menuProps if un-change * @property {Function} getAnchor default is 'auto', define anchor if un-change * @property {Function} onClose callback * @property {Function} onOpen callback * @property {Function} onSelect calback * @property {Function} isDarkTheme default is false, define darkThem if un-change * * * @typedef {Object} QuickMenuDataHolder * @property {Function} remove * * @param {Element} trigger * @param {QuickMenuAdaptor} adaptor * @returns {QuickMenuDataHolder} */ QuickMenu.toggleWhenClick = function (trigger, adaptor) { return new QuickMenuInstance(trigger, adaptor); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (QuickMenu); /***/ }), /***/ 7002: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_radio_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(330); /* harmony import */ var _css_radio_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_radio_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /* harmony import */ var _RadioButton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7234); /* harmony import */ var absol_src_HTML5_Svg__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(6821); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7951); /* harmony import */ var absol_src_Print_printer__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(2691); /* harmony import */ var absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(2759); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var $$ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$$ */ .Z.$$; var _svg = absol_src_HTML5_Svg__WEBPACK_IMPORTED_MODULE_4__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._; /*** * @extends AElement * @constructor */ function Radio() { var thisR = this; this.defineEvent('change'); this.$input = $('input', this) .on('change', this.notifyChange.bind(this)); this.$labels = $$('span', this); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$input, ['value', 'checked']); } Radio.tag = 'radio'; Radio.radioProto = _( '<svg class="absol-radio-icon" width="20" height="20" version="1.1" viewBox="0 0 5.2917 5.2917"' + ' xmlns="http://www.w3.org/2000/svg">' + ' <g transform="translate(0 -291.71)">' + ' <circle class="bound" cx="2.6458" cy="294.35" r="2.4626" style="stroke-opacity:.99497;stroke-width:.26458;" />' + ' <circle class="dot" cx="2.6458" cy="294.35" r= "0.92604" style="fill-rule:evenodd;" />' + ' </g>' + '</svg>' ) Radio.render = function () { return _({ tag: 'label', class: 'absol-radio', child: [ { tag: 'input', attr: { type: 'radio' } }, { tag: 'span', class: 'absol-radio-left-label' }, Radio.radioProto.cloneNode(true), { tag: 'span', class: 'absol-radio-right-label' } ] }); }; Radio.prototype.notifyChange = function () { this.emit('change', { type: 'change', checked: this.checked, target: this }, this); }; Radio.prototype.getAllFriend = function () { return Radio.getAllByName(this.name); }; Radio.attribute = _RadioButton__WEBPACK_IMPORTED_MODULE_3__/* ["default"].attribute */ .Z.attribute; Radio.property = { name: { set: function (name) { this.$input.setAttribute('name', name); }, get: function () { return this.$input.getAttribute('name'); } }, text: { set: function (value) { value = (value || '').trim(); this.$labels[0].clearChild(); this.$labels[1].clearChild(); if (value) { this.$labels[0].addChild(_({ text: value })); this.$labels[1].addChild(_({ text: value })); } }, get: function () { return this.$labels[0].firstChild.data; } }, disabled: { set: function (value) { this.$input.disabled = !!value; if (value) { this.addClass('disabled'); } else { this.removeClass('disabled'); } }, get: function () { return this.$input.disabled; } } }; Radio.getAllByName = function (name) { return (Array.apply(null, document.getElementsByTagName('input')) || []).filter(function (elt) { return elt.getAttribute('type') == 'radio' && elt.getAttribute('name') == name; }); }; Radio.getValueByName = function (name) { var inputs = Radio.getAllByName(name); var res = null; var input; for (var i = 0; i < inputs.length; ++i) { input = inputs[i]; if (input.checked) { res = input.value; } } return res; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Radio); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Radio); var radioImageCache = {}; absol_src_Print_printer__WEBPACK_IMPORTED_MODULE_6__.ShareSerializer.addHandlerBefore({ match: (elt, scope, stack) => { if ((elt.hasClass('absol-radio-icon') || elt.hasClass('as-checkbox-input-check-icon')) && (elt.parentElement.hasClass('absol-radio') || elt.parentElement.hasClass('absol-radio-button') || elt.parentElement.hasClass('as-checkbox-input'))) { return true; } return false; }, exec: (printer, elt, scope, stack, accept) => { var type = elt.hasClass('absol-radio-icon') ? 'radio' : 'check'; var fontSize = elt.getFontSize(); var checked = !!elt.parentElement.__origin__.checked; var disabled = !!elt.parentElement.__origin__.disabled; var bound = absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_7__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); if (bound.width === 0) return; var rect = bound.clone(); rect.x -= printer.O.x; rect.y -= printer.O.y; var key = type + fontSize + checked + disabled; var res; if (radioImageCache[key]) { res = radioImageCache[key]; } else { res = absol_src_HTML5_Svg__WEBPACK_IMPORTED_MODULE_4__/* ["default"].svgToCanvas */ .ZP.svgToCanvas(elt.__origin__).catch(err => { console.error(err); }); radioImageCache[key] = res; } res.elt = elt; printer.image(res, rect); }, id: 'Radio' }, 'SVG'); /***/ }), /***/ 7234: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_radiobutton_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2578); /* harmony import */ var _css_radiobutton_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_radiobutton_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function RadioButton() { var thisRB = this; this.defineEvent('change'); this.$input = $('input', this).on('change', this.notifyChange.bind(this)); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$input, ['value', 'checked']); } RadioButton.tag = 'radiobutton'; RadioButton.radioProto = _( '<svg class="absol-radio-icon" width="20" height="20" version="1.1" viewBox="0 0 5.2917 5.2917"' + ' xmlns="http://www.w3.org/2000/svg">' + ' <g transform="translate(0 -291.71)">' + ' <circle class="bound" cx="2.6458" cy="294.35" r="2.4626" style="stroke-opacity:.99497;stroke-width:.26458;" />' + ' <circle class="dot" cx="2.6458" cy="294.35" r= "0.92604" style="fill-rule:evenodd;" />' + ' </g>' + '</svg>' ) RadioButton.render = function () { return _({ tag:'label', class: 'absol-radio-button', child: [ { tag: 'input', attr: { type: 'radio' } }, RadioButton.radioProto.cloneNode(true) ] }); }; RadioButton.prototype.notifyChange = function () { this.emit('change', { type: 'change', checked: this.checked, target: this }, this); }; RadioButton.prototype.getAllFriend = function () { return Radio.getAllByName(this.name); }; RadioButton.attribute = { checked: { set: function (value) { if (value == 'false' || value == null) { this.checked = false; } else { this.checked = true; } }, get: function () { return this.checked ? 'true' : 'false' }, remove: function () { this.checked = false; } }, disabled: { set: function (value) { if (value == 'false' || value == null) { this.disabled = false; } else { this.disabled = true; } }, get: function () { return this.disabled ? 'true' : 'false' }, remove: function () { this.disabled = false; } }, name: { set: function (value) { this.name = value; }, get: function () { return this.name; }, remove: function () { this.name = null; } } } RadioButton.property = { name: { set: function (name) { if (name == null) this.$input.removeAttribute('name'); else this.$input.setAttribute('name', name); }, get: function () { return this.$input.getAttribute('name'); } }, disabled: { set: function (value) { this.$input.disabled = !!value; if (value) { this.addClass('disabled'); } else { this.removeClass('disabled'); } }, get: function () { return this.$input.disabled; } } }; RadioButton.getAllByName = function (name) { return (document.getElementsByTagName('input') || []).filter(function (elt) { return elt.getAttribute('type') == 'radio' && elt.getAttribute('name') == name; }); }; RadioButton.getValueByName = function (name) { var inputs = RadioButton.getAllByName(name); var res = null; var input; for (var i = 0; i < inputs.length; ++i) { input = inputs[i]; if (input.checked) { res = input.value; } } return res; }; RadioButton.autoReplace = function () { var placeHolders = Array.prototype.slice.call(document.getElementsByTagName(this.tag)); var ph; var attOfPH; var attrs; var style; var classList; var attNode; var attrName, attrValue; var props; for (var i = 0; i < placeHolders.length; ++i) { ph = placeHolders[i]; attOfPH = ph.attributes; classList = []; style = {}; attrs = {}; props = {}; for (var j = 0; j < attOfPH.length; ++j) { attNode = attOfPH[j]; attrName = attNode.nodeName; attrValue = attNode.nodeValue; if (attrName == 'style') { attrValue.trim().split(';').reduce(function (style, prop) { var p = prop.split(':'); if (p.length == 2) { style[p[0].trim()] = p[1].trim(); } return style; }, style); } else if (attrName == 'class') { classList = attrValue.trim().split(/\s+/); } else if (attrName == 'onchange') { props.onchange = new Function('event', 'sender', attrValue); } else { attrs[attrName] = attrValue; } } var newElt = _({ tag: this.tag, attr: attrs, class: classList, style: style, props: props }); $(ph).selfReplace(newElt); } }; RadioButton.initAfterLoad = function (){ absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].documentReady.then */ .ZP.documentReady.then(function (){ RadioButton.autoReplace(); }) }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install('RadioButton'.toLowerCase(), RadioButton); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (RadioButton); /***/ }), /***/ 9441: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7807); /** * @extends AElement * @constructor */ function RelativeTimeText() { if (!this.share.manager) this.share.manager = new RTTManager(); this.share.manager.add(this); this.addClass('as-relative-time-text'); /** * * @type {null|Date} * @private */ this._time = null; /** * @name timeText * @type {string} * @memberOf RelativeTimeText# */ /** * @name time * @type {Date} * @memberOf RelativeTimeText# */ } RelativeTimeText.tag = 'RelativeTimeText'.toLowerCase(); RelativeTimeText.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({}); }; RelativeTimeText.prototype.updateText = function () { if (!this._time) return; var now = Date.now(); var diff = now - this._time.getTime(); var min = Math.round(diff / 6e4); var lang = this.getLanguage(); var hour = Math.round(min / 60); var day = Math.round(hour / 24); if (min < 1) { this.timeText = lang === 'vi' ? "Vừa xong" : "Just now"; } else if (min < 60) { this.timeText = lang === 'vi' ? min + ' phút' : min + ' minutes'; } else if (hour < 24) { this.timeText = lang === 'vi' ? hour + ' giờ' : hour + ' hours'; } else { this.timeText = lang === 'vi' ? day + ' ngày' : day + ' days'; } }; RelativeTimeText.prototype.getLanguage = function () { if (window.systemconfig && window.systemconfig.language) { return window.systemconfig.language === 'VN' ? 'vi' : 'en'; } else { return navigator.language === 'vi' ? 'vi' : 'en'; } }; RelativeTimeText.prototype.share = { manager: null }; RelativeTimeText.property = {}; RelativeTimeText.property.timeText = { set: function (value) { if (value instanceof Date) { value = value.toLocaleDateString() + ' ' + value.toLocaleTimeString(); } this.attr('data-time-text', value); }, get: function () { return this.attr('data-time-text'); } }; RelativeTimeText.property.time = { set: function (value) { value = (0,absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_1__.implicitDate)(value); this._time = value; this.updateText(); if (value) { this.attr('title', value.toLocaleDateString() + ' ' + value.toLocaleTimeString()); } else { this.attr('title', null); } }, get: function () { return this._time; } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (RelativeTimeText); _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(RelativeTimeText); function RTTManager() { /** * * @type {{elt:RelativeTimeText, time: number}[]} */ this.arr = []; this.update = this.update.bind(this); } RTTManager.prototype.add = function (element) { this.arr.push({ elt: element, time: Date.now() }); if (this.arr.length === 1) { setTimeout(this.update, 20000); } }; RTTManager.prototype.update = function () { var remainArr = []; var now = Date.now(); var it, ok; for (var i = 0; i < this.arr.length; i++) { it = this.arr[i]; ok = now - it.time < 60000; if (!ok) { if (it.elt.isDescendantOf(document.body)) { it.time = now; ok = true; } } if (ok) { it.elt.updateText(); remainArr.push(it); } } this.arr = remainArr; if (this.arr.length > 0) { setTimeout(this.update, 20000); } }; /***/ }), /***/ 4860: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_resizebox_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7585); /* harmony import */ var _css_resizebox_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_resizebox_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(863); /* harmony import */ var _Hanger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(655); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends Hanger * @constructor */ function ResizeBox() { this.on({ draginit: this.eventHandler.rbDragInit, dragdeinit: this.eventHandler.rbDragDeinit }); this.hangon = 3; this._mousedownEventData = undefined; this._mousemoveEventData = undefined; this._lastClickTime = 0; } ResizeBox.tag = 'ResizeBox'.toLowerCase(); ResizeBox.render = function () { return _({ tag: _Hanger__WEBPACK_IMPORTED_MODULE_3__/* ["default"].tag */ .Z.tag, class: 'as-resize-box', extendEvent: ['beginmove', 'endmove', 'moving', 'click', 'dblclick'],//override click event child: { class: 'as-resize-box-body', child: [ '.as-resize-box-dot.left-top', '.as-resize-box-dot.top', '.as-resize-box-dot.right-top', '.as-resize-box-dot.right', '.as-resize-box-dot.right-bottom', '.as-resize-box-dot.bottom', '.as-resize-box-dot.left-bottom', '.as-resize-box-dot.left' ] } }); }; ResizeBox.eventHandler = {}; ResizeBox.eventHandler.rbDragInit = function (event) { if ((0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__/* .isMouseRight */ .Ed)(event.originEvent)) { event.cancel(); return; } var target = event.target; if (!target.attr) return; if (!target.hasClass('as-resize-box-dot') && !target.hasClass('as-resize-box-body')) return; var optionNames = event.target.attr('class').match(/body|left|top|right|bottom/g); if (optionNames.length === 0) return; this._mouseOptionNames = optionNames; this._mouseOptionDict = this._mouseOptionNames.reduce((ac, cr) => { ac[cr] = true; return ac }, {}); this.on({ drag: this.eventHandler.rbDrag, dragend: this.eventHandler.rbDragEnd, dragstart: this.eventHandler.rbDragStart }); this._dragged = false; }; ResizeBox.eventHandler.rbDragDeinit = function (event) { this.off({ drag: this.eventHandler.rbDrag, dragend: this.eventHandler.rbDragEnd, dragstart: this.eventHandler.rbDragStart }); var now = new Date().getTime(); if (!this._dragged) { if (now - this._lastClickTime < 400) { this.emit('dblclick', Object.assign({}, event, { type: 'dblclick' }), this); this._lastClickTime = 0; } else { this.emit('click', Object.assign({}, event, { type: 'click' }), this); this._lastClickTime = now; } } }; ResizeBox.eventHandler.rbDrag = function (event) { if (this._mousedownEventData.option.body && !this.canMove) return; this._dragged = true; event.preventDefault(); this._mousemoveEventData = { clientX: event.clientX, clientY: event.clientY, clientX0: this._mousedownEventData.clientX, clientY0: this._mousedownEventData.clientY, clientDX: event.clientX - this._mousedownEventData.clientX, clientDY: event.clientY - this._mousedownEventData.clientY, target: this, originEvent: event, option: this._mousedownEventData.option, type: 'moving', begin: true }; this.emit('moving', this._mousemoveEventData, this); }; ResizeBox.eventHandler.rbDragStart = function (event) { event.preventDefault(); this._optionNames = event.target.attr('class').match(/body|left|top|right|bottom/g); this._dragged = true; $(document.body) .addClass('as-resize-box-overiding') .addClass(this._optionNames.join('-')); var option = this._optionNames.reduce(function (ac, key) { ac[key] = true; return ac; }, {}); this._mousedownEventData = { clientX: event.clientX, clientY: event.clientY, target: this, originEvent: event, prevented: false, preventDefault: function () { this.prevented = true; }, option: option, begin: false, type: 'beginmove' }; this.emit('beginmove', this._mousedownEventData, this); }; ResizeBox.eventHandler.rbDragEnd = function (event) { document.body.classList.remove('as-resize-box-overiding') document.body.classList.remove(this._optionNames.join('-')); this._mousefinishEventData = { clientX: event.clientX, clientY: event.clientY, clientX0: this._mousedownEventData.clientX, clientY0: this._mousedownEventData.clientY, clientDX: event.clientX - this._mousedownEventData.clientX, clientDY: event.clientY - this._mousedownEventData.clientY, target: this, originEvent: event, option: this._mousedownEventData.option, type: 'endmove' }; this.emit('endmove', this._mousefinishEventData, this); }; ResizeBox.property = {}; ResizeBox.property.canMove = { set: function (value) { if (value) { this.addClass('as-can-move'); } else { this.removeClass('as-can-move'); } }, get: function () { return this.hasClass('as-can-move'); } }; ResizeBox.property.canResize = { set: function (value) { if (value) { this.addClass('as-can-resize'); } else { this.removeClass('as-can-resize'); } }, get: function () { return this.hasClass('as-can-resize'); } }; ResizeBox.property.canClick = { set: function (value) { if (value) { this.addClass('as-can-click'); } else { this.removeClass('as-can-click'); } }, get: function () { return this.hasClass('as-can-click'); } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ResizeBox); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ResizeBox); /***/ }), /***/ 9664: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_ribbonbutton_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8896); /* harmony import */ var _css_ribbonbutton_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_ribbonbutton_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); /* harmony import */ var _RibbonSplitButton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6455); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function RibbonButton() { this.$icon = null; this._icon = null; this.$text = $('.as-ribbon-button-text', this); this.$textNode = this.$text.firstChild; this._menuHolder = null; } RibbonButton.tag = 'RibbonButton'.toLowerCase(); RibbonButton.render = function () { return _({ tag: 'button', extendEvent: ['select'], attr: { 'tabindex': '0' }, class: ['as-ribbon-button', 'as-no-dropdown'], child: [ { tag: 'span', class: 'as-ribbon-button-text', child: { text: '' } }, 'span.mdi.mdi-chevron-down.as-ribbon-dropdown-icon' ] }); }; RibbonButton.property = Object.assign({}, _RibbonSplitButton__WEBPACK_IMPORTED_MODULE_3__/* ["default"].property */ .Z.property); RibbonButton.property.icon = { set: function (icon) { icon = icon || null; this._icon = icon; if (this.$icon) this.removeChild(this.$icon); if (icon) { this.$icon = _(icon); this.addChildBefore(this.$icon, this.$text); if (this.$icon.addClass) this.$icon.addClass('as-ribbon-button-icon'); } else { this.$icon = null; } }, get: function () { return this._icon; } }; RibbonButton.eventHandler = {}; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(RibbonButton); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (RibbonButton); /***/ }), /***/ 6455: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_ribbonsplitbutton_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6949); /* harmony import */ var _css_ribbonsplitbutton_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_ribbonsplitbutton_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _QuickMenu__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1274); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function RibbonSplitButton() { this.$icon = null; this._icon = null; this.$text = $('.as-ribbon-split-button-text', this); this.$primaryBtn = $('.as-ribbon-split-button-primary', this) .on('click', this.eventHandler.clickPrimaryBtn); this.$extendBtn = $('.as-ribbon-split-button-extend', this); this.$extendText = $('.as-ribbon-split-button-text', this.$extendBtn);//for big style this._menuHolder = null; } RibbonSplitButton.tag = 'RibbonSplitButton'.toLowerCase(); RibbonSplitButton.render = function () { return _({ extendEvent: ['press', 'select'], attr: { 'tabindex': '0' }, class: ['as-ribbon-split-button', 'as-no-dropdown'], child: { class: 'as-ribbon-split-button-content', child: [ { tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-primary', child: { tag: 'span', class: 'as-ribbon-split-button-text' } }, { tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-extend', child: ['span.as-ribbon-split-button-text', 'span.mdi.mdi-chevron-down.as-ribbon-dropdown-icon'] } ] } }); }; RibbonSplitButton.property = {}; RibbonSplitButton.property.items = { set: function (items) { var thisB = this; this._items = items || []; if (this._items && this._items.length > 0) { if (!this._menuHolder) { this.removeClass('as-no-dropdown'); this._menuHolder = _QuickMenu__WEBPACK_IMPORTED_MODULE_2__/* ["default"].toggleWhenClick */ .Z.toggleWhenClick(this.$extendBtn || this, { getMenuProps: function () { return { extendStyle: { 'min-width': thisB.getBoundingClientRect().width + 'px' }, items: thisB._items } }, getFlowedElement: function () { return thisB; }, anchor: [1, 2, 6, 5], onSelect: function (item) { thisB.emit('select', { item: (0,_utils__WEBPACK_IMPORTED_MODULE_3__.cleanMenuItemProperty)(item), type: 'select', target: thisB }); } }); } } else { if (this._menuHolder) { this.addClass('as-no-dropdown'); this._menuHolder.remove(); this._menuHolder = null; } } }, get: function () { return this._items; } }; RibbonSplitButton.property.text = { set: function (value) { value = value || ''; this.$text.attr('data-text', value); if (this.$extendText) this.$extendText.attr('data-text', value); }, get: function () { return this.$text.attr('data-text') | ''; } }; RibbonSplitButton.property.icon = { set: function (icon) { icon = icon || null; this._icon = icon; if (this.$icon) this.$primaryBtn.removeChild(this.$icon); if (icon) { this.$icon = _(icon); this.$primaryBtn.addChildBefore(this.$icon, this.$text); if (this.$icon.addClass) this.$icon.addClass('as-ribbon-split-button-icon'); } else { this.$icon = null; } }, get: function () { return this._icon; } }; RibbonSplitButton.eventHandler = {}; RibbonSplitButton.eventHandler.clickPrimaryBtn = function () { this.emit('press', { type: 'press', target: this, item: (0,_utils__WEBPACK_IMPORTED_MODULE_3__.cleanMenuItemProperty)(this) }) } _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(RibbonSplitButton); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (RibbonSplitButton); /***/ }), /***/ 9246: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "k$": () => (/* binding */ VScroller), /* harmony export */ "bJ": () => (/* binding */ HScroller), /* harmony export */ "LW": () => (/* binding */ Scrollbar), /* harmony export */ "eP": () => (/* binding */ VScrollbar), /* harmony export */ "MP": () => (/* binding */ HScrollbar) /* harmony export */ }); /* harmony import */ var _css_scroller_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6618); /* harmony import */ var _css_scroller_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_scroller_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3349); /* harmony import */ var absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1487); /* harmony import */ var absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7988); /* harmony import */ var _Hanger__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(655); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$scrollStyle */ .Z.$scrollStyle = (function () { var element = _('style#vscroller-style'); element.innerHTML = [ '.absol-vscroller-viewport{ margin-right: ' + (-17) + 'px; min-width: calc(100% + ' + (17) + 'px);}', '.absol-hscroller-viewport{ margin-bottom: ' + (-17) + 'px; min-height: calc(100% + ' + (17) + 'px);}' ].join('\n'); document.head.appendChild(element); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].getScrollSize */ .ZP.getScrollSize().then(function (size) { element.innerHTML = [ '.absol-vscroller-viewport{ margin-right: ' + (-size.width) + 'px; min-width: calc(100% + ' + (size.width) + 'px);}', '.absol-hscroller-viewport{ margin-bottom: ' + (-size.height) + 'px; min-height: calc(100% + ' + (size.height) + 'px);}' ].join('\n'); }); return element; } )(); /*** * @extends AElement * @constructor */ function VScroller() { var thisVS = this; this.$attachHook = $('attachhook', this); this.sync = new Promise(function (rs) { thisVS.$attachHook.once('error', function () { rs(); }); }); this.$attachHook.on('error', function () { thisVS.requestUpdateSize(); }); this.$vscrollbar = $('vscrollbar', this).on('scroll', this.eventHandler.scrollScrollbar); this.$viewport = $('.absol-vscroller-viewport', this) .on('scroll', this.eventHandler.scrollViewport); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"]["extends"] */ .ZP["extends"](thisVS.$viewport, { removeChild: function () { this.super.apply(this, arguments); thisVS.requestUpdateSize(); return thisVS; } }) } VScroller.tag = 'vscroller'; VScroller.render = function () { return _({ class: 'absol-vscroller', child: ['.absol-vscroller-viewport', { class: ['absol-scrollbar-container', 'vertical'], child: 'vscrollbar' }, 'attachhook' ] }); }; VScroller.prototype.requestUpdateSize = function () { // return; if (this._isRequestingUpdateSize) return this.sync; this._isRequestingUpdateSize = true; this.sync = this.sync.then(function () { this.$vscrollbar.outerHeight = this.$viewport.clientHeight; this.$vscrollbar.innerHeight = this.$viewport.scrollHeight - 2; this.$vscrollbar.innerOffset = this.$viewport.scrollTop; if (this.$vscrollbar.innerHeight <= this.$vscrollbar.outerHeight) { this.$vscrollbar.hidden = true; this.addClass('disabled'); } else { this.removeClass('disabled'); this.$vscrollbar.hidden = false; } this._isRequestingUpdateSize = false; }.bind(this)); return this.sync; }; VScroller.prototype.init = function (props) { this.super(props); this.requestUpdateSize(); }; VScroller.prototype.addChild = function () { var res = this.$viewport.addChild.apply(this.$viewport, arguments); this.requestUpdateSize(); return res; }; VScroller.prototype.clearChild = function () { var res = this.$viewport.clearChild.apply(this.$viewport, arguments); this.requestUpdateSize(); return res; }; VScroller.prototype.addChildBefore = function () { var res = this.$viewport.addChildBefore.apply(this.$viewport, arguments); this.requestUpdateSize(); return res; }; VScroller.prototype.addChildAfter = function () { var res = this.$viewport.addChildAfter.apply(this.$viewport, arguments); this.requestUpdateSize(); return res; }; VScroller.prototype.findChildAfter = function () { return this.$viewport.findChildAfter.apply(this.$viewport, arguments); }; VScroller.prototype.findChildBefore = function () { return this.$viewport.findChildBefore.apply(this.$viewport, arguments); }; VScroller.prototype.removeChild = function () { var res = this.$viewport.removeChild.apply(this.$viewport, arguments); this.requestUpdateSize(); return res; }; VScroller.prototype.scrollInto = function (element, padding, scrollTime, beforFrame, afterFrame) { padding = padding || 0; scrollTime = scrollTime || 0; var frameCount = Math.ceil(scrollTime / 15 + 1); var self = this; function onFrame() { beforFrame && beforFrame(); var elementBound = element.getBoundingClientRect(); var viewportBound = self.$viewport.getBoundingClientRect(); var currentScrollTop = self.$viewport.scrollTop; var newScrollTop = currentScrollTop; if (elementBound.bottom + padding > viewportBound.bottom) { newScrollTop = currentScrollTop + ((elementBound.bottom + padding) - viewportBound.bottom) / (Math.log(frameCount) + 1); } if (elementBound.top - padding < viewportBound.top) { newScrollTop = currentScrollTop - (viewportBound.top - (elementBound.top - padding)) / (Math.log(frameCount) + 1); } if (newScrollTop != currentScrollTop) { self.$viewport.scrollTop = newScrollTop; } afterFrame && afterFrame(); frameCount--; if (frameCount > 0) setTimeout(onFrame, 15) } if (absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__/* ["default"].prototype.isDescendantOf.call */ .Z.prototype.isDescendantOf.call(element, this.$viewport)) { onFrame(); } }; VScroller.prototype.scrollBy = function (dy, duration) { duration = duration || 0; var frameCount = Math.ceil(duration / 20); var timeOut = duration / frameCount; var i = 0; var self = this; var start = self.$viewport.scrollTop; var end = start + dy; function onFrame() { self.$viewport.scrollTop = Math.max((0,absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__.map)(i, 0, frameCount, start, end), 0); ++i; if (i <= frameCount) { setTimeout(onFrame, timeOut); } else { setTimeout(finish, timeOut) } } function finish(){ self.$viewport.scrollTop = Math.max(end, 0); } onFrame(); }; VScroller.eventHandler = {}; VScroller.eventHandler.scrollViewport = function (event) { this.$vscrollbar.outerHeight = this.$viewport.clientHeight; this.$vscrollbar.innerHeight = this.$viewport.scrollHeight; this.$vscrollbar.innerOffset = this.$viewport.scrollTop; }; VScroller.eventHandler.scrollScrollbar = function (event) { this.$viewport.scrollTop = this.$vscrollbar.innerOffset; }; /*** * @extends AElement * @constructor */ function HScroller() { var thisHS = this; this.$attachHook = $('attachhook', this) .on('error', function () { this.requestUpdateSize = this.requestUpdateSize || thisHS.requestUpdateSize.bind(thisHS); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].addToResizeSystem */ .ZP.addToResizeSystem(this); }); this.sync = new Promise(function (rs, rj) { thisHS.$attachHook.once('error', rs); }); this.$hscrollbar = $('hscrollbar', this).on('scroll', this.eventHandler.scrollScrollbar); this.$viewport = $('.absol-hscroller-viewport', this) .on('scroll', this.eventHandler.scrollViewport); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"]["extends"] */ .ZP["extends"](this.$viewport, { removeChild: function () { this.super.apply(this, arguments); thisHS.requestUpdateSize(); return thisHS; } }); } HScroller.tag = 'hscroller'; HScroller.render = function () { return _({ class: 'absol-hscroller', child: ['.absol-hscroller-viewport', { class: ['absol-scrollbar-container', 'horizontal'], child: 'hscrollbar' }, 'attachhook' ] }); }; HScroller.eventHandler = {}; HScroller.eventHandler.scrollViewport = function (event) { this.$hscrollbar.outerWidth = this.$viewport.clientWidth; this.$hscrollbar.innerWidth = this.$viewport.scrollWidth; this.$hscrollbar.innerOffset = this.$viewport.scrollLeft; }; HScroller.eventHandler.scrollScrollbar = function (event) { this.$viewport.scrollLeft = this.$hscrollbar.innerOffset; }; Object.assign(HScroller.prototype, VScroller.prototype); HScroller.prototype.requestUpdateSize = function () { // return; if (this._isRequestingUpdateSize) return this.sync; this._isRequestingUpdateSize = true; this.sync = this.sync.then(function () { this.$hscrollbar.outerWidth = this.$viewport.clientWidth; this.$hscrollbar.innerWidth = this.$viewport.scrollWidth; this.$hscrollbar.innerOffset = this.$viewport.scrollLeft; if (this.$hscrollbar.innerWidth <= this.$hscrollbar.outerWidth) { this.$hscrollbar.hidden = true; this.addClass('disabled'); } else { this.removeClass('disabled'); this.$hscrollbar.hidden = false; } this._isRequestingUpdateSize = false; }.bind(this)); return this.sync; }; HScroller.prototype.scrollInto = function (element) { if (absol_src_HTML5_Element__WEBPACK_IMPORTED_MODULE_4__/* ["default"].prototype.isDescendantOf.call */ .Z.prototype.isDescendantOf.call(element, this.$viewport)) { var elementBound = element.getBoundingClientRect(); var viewportBound = this.$viewport.getBoundingClientRect(); var currentScrollLeft = this.$viewport.scrollLeft; var newScrollLeft = currentScrollLeft; if (elementBound.right > viewportBound.right) { newScrollLeft = currentScrollLeft + (elementBound.right - viewportBound.right); } if (elementBound.left < viewportBound.left) { newScrollLeft = currentScrollLeft - (viewportBound.left - elementBound.left); } if (newScrollLeft != currentScrollLeft) { this.$viewport.scrollLeft = newScrollLeft; } } } /*** * @extends AElement * @constructor */ function Scrollbar() { var thisSB = this; this.$button = $('.absol-scrollbar-button', this); this.on('inactive', function (event, sender) { this.emit('deactive', event, sender); }); } Scrollbar.tag = 'scrollbar'; Scrollbar.render = function () { return _({ tag: _Hanger__WEBPACK_IMPORTED_MODULE_5__/* ["default"].tag */ .Z.tag, class: ['absol-scrollbar'], extendEvent: ['scroll', 'active', 'inactive', 'deactive'], child: '.absol-scrollbar-button' }); }; Scrollbar.property = {}; Scrollbar.property.hidden = { set: function (value) { value = !!value; if (value !== this._hidden) { this._hidden = value; if (value) this.addClass('absol-hidden'); else this.removeClass('absol-hidden'); } }, get: function () { return this.hasClass('absol-hidden') } }; /*** * @extends Scrollbar * @constructor */ function VScrollbar() { this.on('draginit', this.eventHandler.dragInit, true) .on('drag', this.eventHandler.drag, true) .on('dragend', this.eventHandler.dragEnd, true); /*** * @type {number} * @name outerHeight * @memberOf VScrollbar# */ /*** * @type {number} * @name innerHeight * @memberOf VScrollbar# */ /*** * @type {number} * @name innerHeight * @memberOf VScrollbar# */ } VScrollbar.tag = 'vscrollbar'; VScrollbar.render = function () { return _({ tag: 'scrollbar', class: 'absol-vscrollbar' }, true); }; VScrollbar.prototype.updateValue = function () { this.$button.addStyle('height', Math.min(this.outerHeight / this.innerHeight, 1) * 100 + '%'); this.$button.addStyle('top', this.innerOffset / this.innerHeight * 100 + '%'); }; VScrollbar.prototype.updateStatus = function () { if (this.innerHeight > this.outerHeight) { this.addClass('as-overflow'); } else { this.removeClass('as-overflow'); } }; VScrollbar.eventHandler = {}; VScrollbar.eventHandler.dragInit = function (event) { event.preventDefault(); var boundRes = this.getBoundingClientRect(); var boundButton = this.$button.getBoundingClientRect(); if (event.target === this.$button) { this.innerOffset0 = this.innerOffset; } else { var newInnerOffset = (0,absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__.map)(event.startingPoint.y - boundButton.height / 2 - boundRes.top, 0, boundRes.height, 0, this.innerHeight); if (newInnerOffset + this.outerHeight > this.innerHeight) newInnerOffset = this.innerHeight - this.outerHeight; if (newInnerOffset < 0) newInnerOffset = 0; this.innerOffset = newInnerOffset; //todo event.innerOffset = newInnerOffset; this.innerOffset0 = newInnerOffset; this.emit('scroll', event); } this.addClass('absol-active'); this.emit('active', { type: 'active', originEvent: event, target: this, originalEvent: event.originalEvent || event }); }; VScrollbar.eventHandler.drag = function (event) { event.preventDefault(); var dy = event.currentPoint.sub(event.startingPoint).y; var newInnerOffset = this.innerOffset0 + dy * (this.innerHeight / this.outerHeight) * (this.outerHeight / this.getBoundingClientRect().height); if (newInnerOffset + this.outerHeight > this.innerHeight) newInnerOffset = this.innerHeight - this.outerHeight; if (newInnerOffset < 0) newInnerOffset = 0; this.innerOffset = newInnerOffset; event.innerOffset = newInnerOffset; this.emit('scroll', event); }; VScrollbar.eventHandler.dragEnd = function (event) { this.removeClass('absol-active'); this.emit('inactive', { type: 'inactive', originEvent: event, target: this, originalEvent: event.originalEvent || event }); }; VScrollbar.property = { innerOffset: { set: function (value) { value = value || 0; if (this._innerOffset != value) { this._innerOffset = value; this.updateValue(); } }, get: function () { return this._innerOffset || 0; } }, innerHeight: { set: function (value) { value = value || 1; value = Math.max(value, 1); if (this._innerHeight !== value) { this._innerHeight = value; this.updateValue(); } this.updateStatus(); }, get: function () { return this._innerHeight || 1; } }, outerHeight: { set: function (value) { value = value || 0; value = Math.max(value, 0); if (this._outerHeight !== value) { this._outerHeight = value; this.updateValue(); } this.updateStatus(); }, get: function () { return this._outerHeight || 0; } } }; /*** * @extends Scrollbar * @constructor */ function HScrollbar() { this.on('draginit', this.eventHandler.dragInit, true) .on('drag', this.eventHandler.drag, true) .on('dragend', this.eventHandler.dragEnd, true); /*** * @type {number} * @name innerOffset * @memberOf HScrollbar# */ /*** * @type {number} * @name innerWidth * @memberOf HScrollbar# */ /*** * @type {number} * @name outerWidth * @memberOf HScrollbar# */ } HScrollbar.tag = 'hscrollbar'; HScrollbar.render = function () { return _({ tag: 'scrollbar', class: 'absol-hscrollbar' }, true); } HScrollbar.prototype.updateValue = function () { this.$button.addStyle('width', Math.min(this.outerWidth / this.innerWidth, 1) * 100 + '%'); this.$button.addStyle('left', this.innerOffset / this.innerWidth * 100 + '%'); }; HScrollbar.prototype.updateStatus = function () { if (this.innerWidth > this.outerWidth) { this.addClass('as-overflow'); } else { this.removeClass('as-overflow'); } }; /** * * @type {{[key: string]:function}} */ HScrollbar.eventHandler = {}; /** * @this HScrollbar * @param event */ HScrollbar.eventHandler.dragInit = function (event) { event.preventDefault(); var boundRes = this.getBoundingClientRect(); var boundButton = this.$button.getBoundingClientRect(); if (event.target === this.$button) { this.innerOffset0 = this.innerOffset; } else { var newInnerOffset = (0,absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__.map)(event.startingPoint.x - boundButton.width / 2 - boundRes.left, 0, boundRes.width, 0, this.innerWidth); if (newInnerOffset + this.outerWidth > this.innerWidth) newInnerOffset = this.innerWidth - this.outerWidth; if (newInnerOffset < 0) newInnerOffset = 0; this.innerOffset = newInnerOffset; //todo event.innerOffset = newInnerOffset; this.innerOffset0 = newInnerOffset; this.emit('scroll', event); } var body = $(document.body); this.addClass('absol-active'); this.emit('active', { type: 'inactive', originEvent: event, target: this }); }; /** * @this HScrollbar * @param event */ HScrollbar.eventHandler.drag = function (event) { event.preventDefault(); var dy = event.currentPoint.x - event.startingPoint.x; var newInnerOffset = this.innerOffset0 + dy * (this.innerWidth / this.outerWidth) * (this.outerWidth / this.getBoundingClientRect().width); if (newInnerOffset + this.outerWidth > this.innerWidth) newInnerOffset = this.innerWidth - this.outerWidth; if (newInnerOffset < 0) newInnerOffset = 0; this.innerOffset = newInnerOffset; //todo event.innerOffset = newInnerOffset; this.emit('scroll', event); }; /** * @this HScrollbar * @param event */ HScrollbar.eventHandler.dragEnd = function (event) { this.removeClass('absol-active'); this.emit('inactive', { type: 'inactive', originEvent: event, target: this }); }; HScrollbar.property = { innerOffset: { set: function (value) { value = value || 0; if (this._innerOffset !== value) { this._innerOffset = value; this.updateValue(); } }, get: function () { return this._innerOffset || 0; } }, innerWidth: { set: function (value) { value = value || 1; value = Math.max(value, 1); if (this._innerWidth !== value) { this._innerWidth = value; this.updateValue(); } this.updateStatus(); }, get: function () { return this._innerWidth || 1; } }, outerWidth: { set: function (value) { value = value || 0; value = Math.max(value, 0); if (this._outerWidth !== value) { this._outerWidth = value; this.updateValue(); } this.updateStatus(); }, get: function () { return this._outerWidth || 0; } } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install([VScrollbar, HScrollbar, Scrollbar, VScroller, HScroller]); /***/ }), /***/ 9024: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_searcher_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1696); /* harmony import */ var _css_searcher_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_searcher_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7951); /* harmony import */ var _Icons__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(2380); /* harmony import */ var absol_src_HTML5_LanguageSystem__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(6013); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].creator["find-ico"] */ .Z.creator["find-ico"] = function () { var res = _( '<svg class="find" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">' + ' <g transform="matrix(-1 0 0 1 99.478 -193.73)">' + ' <path d="m62.128 199.18c-18.859 0-34.148 15.289-34.148 34.148 0 5.4138 1.26 10.533 3.5026 15.081 0.6886 1.3965 1.4698 2.7392 2.3357 4.02-1.9962 2.1685-31.467 31.596-31.404 33.295 0.21757 5.8346 4.9404 8.7289 9.464 7.855 1.3264-0.25627 30.938-30.639 31.774-31.529 1.3906 0.89633 2.8508 1.6948 4.3702 2.3848 4.2995 1.9526 9.0756 3.04 14.105 3.04 18.859 0 34.147-15.288 34.147-34.147 3e-6 -18.859-15.288-34.148-34.147-34.148zm0.49444 8.2454a26.067 26.067 0 0 1 26.068 26.067 26.067 26.067 0 0 1-26.068 26.068 26.067 26.067 0 0 1-26.067-26.068 26.067 26.067 0 0 1 26.067-26.067z"/>' + ' </g>' + '</svg>' ); return res; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].creator["times-circle-ico"] */ .Z.creator["times-circle-ico"] = function () { var res = _( '<svg class="times" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">\ <g transform="translate(0,-197)">\ <path d="m49.979 236.2-14.231-14.231-10.696 10.696 14.257 14.257-14.351 14.351 10.737 10.737 14.292-14.292 14.292 14.292 10.761-10.761-14.257-14.257 14.316-14.316-10.725-10.725zm50.021 10.804a50 50 0 0 1-50 50 50 50 0 0 1-50-50 50 50 0 0 1 50-50 50 50 0 0 1 50 50z" />\ </g>\ </svg>' ); return res; }; /** * @extends {AElement} * @constructor */ function SearchTextInput() { var thisSTI = this; this.defineEvent(['change', 'modify', 'stoptyping']); this.eventHandler = absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].bindFunctions */ .ZP.bindFunctions(this, SearchTextInput.eventHandler); this.$button = $('button', this); this.$input = $('input', this); ['keyup', 'keydown', 'focus', 'blur'].forEach(function (evName) { thisSTI.defineEvent(evName); thisSTI.$input.on(evName, function (event) { thisSTI.emit(evName, event, thisSTI); }); }); this.$input.on('change', this.eventHandler.inputChange); this.$input.on('keyup', this.eventHandler.inputKeyUp); this.$button.on('click', function (event) { thisSTI.$input.value = ''; thisSTI.eventHandler.inputKeyUp(event); setTimeout(function () { thisSTI.focus(); }, 50); }); /** * @type {string} * @name value * @memberOf SearchTextInput# */ } SearchTextInput.tag = 'SearchTextInput'.toLowerCase(); SearchTextInput.render = function () { return _( { class: 'absol-search-text-input', child: [ { class: 'absol-search-text-input-container', child: { tag: 'input', attr: { type: 'search', placeholder: absol_src_HTML5_LanguageSystem__WEBPACK_IMPORTED_MODULE_5__/* ["default"].getText */ .ZP.getText('txt_search')|| 'Search...' } } }, { class: 'absol-search-text-button-container', child: { tag: 'button', child: ['find-ico', 'times-circle-ico', { tag:_Icons__WEBPACK_IMPORTED_MODULE_4__/* .SpinnerIco.tag */ .i_.tag, style:{margin: 0} }] } } ] } ); }; SearchTextInput.property = { value: { set: function (value) { value = value || ''; this.$input.value = value; this._lastTextModified = value; if (this.value.length > 0) { this.addClass('searching'); } else { this.removeClass('searching'); } }, get: function () { return this.$input.value; } }, placeholder: { set: function (value) { this.$input.attr('placeholder', value); }, get: function () { return this.$placeholder.getAttribute('placeholder'); } } }; SearchTextInput.property.waiting = { set: function (value) { value = value || false; this._waiting = value; if (value) { this.addClass('as-waiting'); } else { this.removeClass('as-waiting'); } }, get: function () { return this._waiting || false; } } SearchTextInput.prototype.focus = function () { this.$input.focus(); }; SearchTextInput.prototype.blur = function () { this.$input.blur(); }; SearchTextInput.eventHandler = {}; SearchTextInput.eventHandler.inputChange = function (event) { event.value = this.value; if (typeof this.onchange == 'function') { this.onchange(event, this); } this.emit('change', event); }; SearchTextInput.eventHandler.inputKeyUp = function (event) { if (this._lastTextModified != this.value) { if (this.value.length > 0) { this.addClass('searching'); } else { this.removeClass('searching'); } event.value = this.value; if (typeof this.onchange == 'function') { this.onchange(event, this); } this.emit('modify', event); if (this._updateTimeOut !== undefined) { clearTimeout(this._updateTimeOut); this._updateTimeOut = undefined; } this._updateTimeOut = setTimeout(function () { this.emit('stoptyping', event); }.bind(this), 500); this._lastTextModified = this.value; } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].creator.searchcrosstextinput */ .Z.creator.searchcrosstextinput = function () { var res = _('searchtextinput', true); return res; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].creator.searchtextinput */ .Z.creator.searchtextinput = SearchTextInput; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SearchTextInput); /***/ }), /***/ 133: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "wA": () => (/* binding */ requireItem), /* harmony export */ "Ag": () => (/* binding */ releaseItem), /* harmony export */ "jG": () => (/* binding */ measureMaxDescriptionWidth), /* harmony export */ "up": () => (/* binding */ measureMaxTextWidth), /* harmony export */ "bw": () => (/* binding */ measureListSize), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports makeItem, measureListHeight */ /* harmony import */ var _css_selectlist_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5121); /* harmony import */ var _css_selectlist_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_selectlist_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1477); /* harmony import */ var _SelectListItem__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6843); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var itemPool = []; function onMousedownItem(event) { if (absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__/* ["default"].isMouseRight */ .ZP.isMouseRight(event)) return; var thisSL = this.$parent; if (thisSL) { thisSL.value = this.value; thisSL.emit('pressitem', { type: 'pressitem', target: thisSL, itemElt: this, value: this.value, data: this.data }); } } function makeItem() { return _({ tag: 'selectlistitem', on: { mousedown: onMousedownItem } }); } function requireItem($parent) { var item; if (itemPool.length > 0) { item = itemPool.pop(); } else { item = makeItem(); } item.$parent = $parent; return item; } function releaseItem(item) { item.$parent = null; item.removeClass('selected'); itemPool.push(item); }; function measureMaxDescriptionWidth(items) { var maxDescWidth = 0; var maxText = 0; var maxEst = 0; var est; for (var i = 0; i < items.length; ++i) { if (items[i].desc) { est = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.estimateWidth14)(items[i].desc); if (est > maxEst) { maxEst = est; maxText = items[i].desc; } } } if (maxText) maxDescWidth = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.measureText)(maxText, 'italic 14px sans-serif').width; return maxDescWidth; }; function measureMaxTextWidth(items) { var maxTextWidth = 0; var maxText = 0; var maxEst = 0; var maxLv = 0; var est; var text; var item; for (var i = 0; i < items.length; ++i) { item = items[i]; if (item.text) { text = item.text; est = (0,_utils__WEBPACK_IMPORTED_MODULE_2__.estimateWidth14)(text) + 14 * 0.9 * (item.level || 0); if (est > maxEst) { maxEst = est; maxText = text; maxLv = item.level || 0; } } } if (maxText) maxTextWidth = 14 * 0.9 * maxLv + (0,_utils__WEBPACK_IMPORTED_MODULE_2__.measureText)(maxText, '14px Arial, Helvetica, sans-serif').width + 14;//padding left, right 7px return maxTextWidth; } function measureListHeight(items) { var border = 0; var n = items.length - 1; return items.length * 20 + border; } function measureListSize(items) { var descWidth = measureMaxDescriptionWidth(items); var textWidth = measureMaxTextWidth(items); var width = textWidth; if (descWidth > 0) { width += descWidth + 14; } var height = measureListHeight(items); return { width: width, height: height, descWidth: descWidth, textWidth: textWidth }; } /*global absol*/ /*** * @extends AElement * @constructor */ function SelectList() { var thisSL = this; this.defineEvent(['pressitem', 'cancelasync', 'valuevisibilityasync', 'finishasync', 'sizechangeasync']); this.$attachhook = _('attachhook').addTo(this); this.sync = new Promise(function (rs) { thisSL.$attachhook.once('error', rs); }); this.$items = []; this.$itemByValue = {};//quick find element this.$selectedItem = undefined; this.measuredSize = { width: 0, height: 0, descWidth: 0, textWidth: 0 }; this._itemSession = 0; this._finished = true; }; SelectList.tag = "SelectList".toLowerCase(); SelectList.render = function () { return _('.absol-selectlist'); }; SelectList.prototype._updateSelectedItem = function () { var newSelectedItemElt = this.$itemByValue[this._selectValue]; if (newSelectedItemElt != this.$selectedItem) { if (this.$selectedItem) { this.$selectedItem.removeClass('selected'); } if (newSelectedItemElt) { newSelectedItemElt.addClass('selected'); this.$selectedItem = newSelectedItemElt; } } }; SelectList.prototype._requireItems = function (itemCout) { var item; while (this.$items.length < itemCout) { item = requireItem(this); this.$items.push(item); this.addChild(item); } while (this.$items.length > itemCout) { item = this.$items.pop(); item.remove(); releaseItem(item); } }; SelectList.prototype._assignItems = function (from, to) { var foundSelected = false; var itemElt; var item; for (var i = from; i < to; ++i) { itemElt = this.$items[i]; item = this._items[i]; itemElt.data = item; itemElt.__index__ = i; if (this.$itemByValue[item.value]) { console.warn('Value ' + this.$items[i].value + ' is duplicated!'); } else { this.$itemByValue[item.value] = itemElt; if (this._selectValue == item.value) { itemElt.addClass('selected'); this.$selectedItem = itemElt; foundSelected = true; } else { itemElt.removeClass('selected'); } } } return foundSelected; }; SelectList.prototype.setItemsAsync = function (items) { //start process this._finished = false; var session = Math.floor(Math.random() * 1000000); this._itemSession = session; this._items = items || []; this.$itemByValue = {}; this.measuredSize = measureListSize(items); this.style.setProperty('--select-list-desc-width', (this.measuredSize.descWidth/14) + 'em'); //addStyle notWork because of convert to cameCase var thisSL = this; var i = 0; var limit = 20; function tick() { if (thisSL._itemSession != session) { thisSL.emit('cancelasync', {session: session, type: 'cancelasync'}, this); return; } if (i >= items.length) { thisSL._updateSelectedItem(); thisSL._finished = false; thisSL.emit('finishasync', {session: session, type: 'finishasync'}, this); return; } var n = Math.min(items.length - i, limit); var itemCout = i + n; thisSL._requireItems(itemCout); i = itemCout; var foundSelected = thisSL._assignItems(itemCout - n, itemCout); if (foundSelected) { thisSL.emit('valuevisibilityasync', { session: session, type: 'valuevisibilityasync', itemElt: thisSL.$items[i] }, thisSL); } thisSL.emit('sizechangeasync', {session: session, type: 'sizechangeasync'}, this); setTimeout(tick, 2); } setTimeout(tick, 2); return Object.assign({session: session}, this.measuredSize); }; SelectList.prototype.setItems = function (items) { this._finished = false; var session = Math.floor(Math.random() * 1000000); this._itemSession = session; this._items = items || []; this.$itemByValue = {}; this.measuredSize = measureListSize(items); this.style.setProperty('--select-list-desc-width', (this.measuredSize.descWidth/14) + 'em'); //addStyle notWork because of convert to cameCase var itemCount = items.length; this._requireItems(itemCount); this._assignItems(0, itemCount); this._finished = true; return { session: this._itemSession, width: this._descWidth + this._textWidth + 14, height: this._height } }; SelectList.property = {}; /** * @type {SelectList} */ SelectList.property.items = { set: function (value) { value = value || []; this.setItems(value); }, get: function () { return this._items || []; } }; SelectList.property.value = { set: function (value) { this._selectValue = value; this._updateSelectedItem(); }, get: function () { return this._selectValue; } }; SelectList.property.item = { get: function () { if (this.$selectedItem) return this.$selectedItem.data; return undefined; } }; SelectList.property.selectedIndex = { get: function () { throw new Error("selectedIndex getter is deprecated"); } }; SelectList.prototype.init = function (props) { props = props || {}; var value = props.value; delete props.value; this.super(props); if (value !== undefined) this.value = value; }; SelectList.eventHandler = {}; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(SelectList); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SelectList); /***/ }), /***/ 6843: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__), /* harmony export */ "sk": () => (/* binding */ getTextOfListItem), /* harmony export */ "_l": () => (/* binding */ getDescriptionOfListItem) /* harmony export */ }); /* unused harmony export getValueOfListItem */ /* harmony import */ var _css_selectlist_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5121); /* harmony import */ var _css_selectlist_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_selectlist_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _CheckboxButton__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4654); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3349); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * * @extends AElement * @constructor */ function SelectListItem() { this.$text = $('span.absol-selectlist-item-text', this); this.$textValue = this.$text.childNodes[0]; this.$descCtn = $('.absol-selectlist-item-desc-container', this); this.$desc = $('span.absol-selectlist-item-desc', this.$descCtn); this.$descValue = this.$desc.childNodes[0]; this.$icon = null; this._extendClasses = []; this._extendStyle = {}; this._data = ""; this._level = 0; this._icon = null; absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__/* ["default"].drillProperty */ .ZP.drillProperty(this, this, 'noSelect', 'disabled'); /*** * @type {AbsolConstructDescriptor|null} * @name icon * @memberOf SelectListItem# */ } SelectListItem.tag = 'SelectListItem'.toLowerCase(); SelectListItem.render = function () { return _({ class: 'absol-selectlist-item', child: [ { tag: 'span', class: 'absol-selectlist-item-text', child: { text: '' } }, { class: 'absol-selectlist-item-desc-container', child: { tag: 'span', class: 'absol-selectlist-item-desc', child: { text: '' } } } ] }) }; SelectListItem.property = {}; SelectListItem.property.extendClasses = { set: function (value) { var i; for (i = 0; i < this._extendClasses.length; ++i) { this.removeClass(this._extendClasses[i]); } this._extendClasses = []; if (typeof value == 'string') value = value.trim().split(/\s+/); value = value || []; for (i = 0; i < value.length; ++i) { this._extendClasses.push(value[i]); this.addClass(value[i]); } }, get: function () { return this._extendClasses; } }; SelectListItem.property.extendStyle = { set: function (value) { this.removeStyle(this._extendStyle); this._extendStyle = Object.assign({}, value || {}); this.addStyle(this._extendStyle); }, get: function () { return this._extendClasses; } }; SelectListItem.property.icon = { /*** * @this SelectListItem * @param icon */ set: function (icon) { if (this.$icon) { this.$icon.remove(); this.$icon = null; } this._icon = icon || null; if (this._icon) { this.$icon = _(this._icon); this.$icon.addClass('as-select-list-icon'); this.addChildBefore(this.$icon, this.$text); } }, get: function () { return this._icon; } }; SelectListItem.property.data = { set: function (value) { this._data = value; if (typeof value == 'string') { this.$textValue.data = value; this.$descValue.data = ''; this.level = 0; this.extendClasses = ''; this.extendStyle = {}; this.lastInGroup = false; this.isLeaf = false; this.selected = false; this.disabled = false; this.icon = null; } else { this.$textValue.data = value.text || ''; this.$descValue.data = value.desc || ''; this.level = value.level || 0; this.extendClasses = value.extendClasses; this.extendStyle = value.extendStyle; this.lastInGroup = !!(value.lastInGroup); this.isLeaf = !!(value.isLeaf); this.selected = !!(value.selected); this.disabled = value.disabled || value.noSelect; this.icon = value.icon; } }, get: function () { return this._data; } }; SelectListItem.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; SelectListItem.property.value = { get: function () { return getValueOfListItem(this._data); } }; SelectListItem.property.text = { get: function () { return getTextOfListItem(this._data); } }; SelectListItem.property.desc = { get: function () { return getDescriptionOfListItem(this._data); } }; SelectListItem.property.level = { set: function (value) { value = value || 0; this._level = value; this.addStyle('--level', value); }, get: function () { return this._level; } }; SelectListItem.property.lastInGroup = { set: function (value) { if (value) { this.addClass('as-last-in-group'); } else { this.removeClass('as-last-in-group'); } }, get: function () { return this.hasClass('as-last-in-group'); } }; SelectListItem.property.isLeaf = { set: function (value) { if (value) { this.addClass('as-is-leaf'); } else { this.removeClass('as-is-leaf'); } }, get: function () { return this.hasClass('as-is-leaf'); } }; SelectListItem.property.selected = { set: function (value) { if (value) { this.addClass('as-selected'); } else { this.removeClass('as-selected'); } }, get: function () { return this.hasClass('as-selected'); } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(SelectListItem); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SelectListItem); function getTextOfListItem(item) { if (item) { if (item.match) { } else if (item.text && item.text.match) { return item.text; } else return ''; } else return ''; } function getValueOfListItem(item) { if (item) { if (item.match) { return item; } else if (typeof item === "object") return item.value; else return item; } else return item; } function getDescriptionOfListItem(item) { return (item && (typeof item == "object")) ? item.desc : undefined; } /***/ }), /***/ 5357: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_selectmenu_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7001); /* harmony import */ var _css_selectmenu_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_selectmenu_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(863); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6628); /* harmony import */ var _list_search__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(2551); /* harmony import */ var _SelectList__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(133); /*global absol*/ var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].creator["dropdown-ico"] */ .Z.creator["dropdown-ico"] = function () { return _([ '<svg class="dropdown" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">', '<g transform="translate(0,-197)">', '<path d="m6.3152 218.09a4.5283 4.5283 0 0 0-3.5673 7.3141l43.361 55.641a4.5283 4.5283 0 0 0 7.1421 7e-3l43.496-55.641a4.5283 4.5283 0 0 0-3.5673-7.3216z" />', '</g>', '</svg>' ].join('')); }; function SelectMenu() { var thisSM = this; this._items = []; this._value = null; this._lastValue = null; this.$holderItem = $('.absol-selectmenu-holder-item', this); this.$anchorCtn = SelectMenu.getAnchorCtn(); this.$anchor = _('.absol-selectmenu-anchor.absol-disabled').addTo(this.$anchorCtn); this.$anchorContentCtn = _('.absol-selectmenu-anchor-content-container').addTo(this.$anchor); this.$dropdownBox = _('.absol-selectmenu-dropdown-box').addTo(this.$anchorContentCtn); this.$searchTextInput = _('searchtextinput').addStyle('display', 'none').addTo(this.$dropdownBox); this.$vscroller = _('bscroller').addTo(this.$dropdownBox); this.$selectlist = _('selectlist', this).addTo(this.$vscroller) .on('sizechangeasync', this.eventHandler.listSizeChangeAsync) .on('valuevisibilityasync', this.eventHandler.listValueVisibility); this.$scrollTrackElts = []; this.$removableTrackElts = []; this._itemsByValue = {}; this.$searchTextInput.on('stoptyping', this.eventHandler.searchModify); this._searchCache = {}; this.$selectlist.on('pressitem', this.eventHandler.selectlistPressItem, true); this.$selectlist.on('pressitem', function () { thisSM.isFocus = false; }, true); this._lastValue = "NOTHING_VALUE"; this._resourceReady = true; this.on('mousedown', this.eventHandler.click, true); this.on('blur', this.eventHandler.blur); this.selectListBound = { height: 0, width: 0 }; this.$attachhook = $('attachhook', this) .on('error', this.eventHandler.attached); this.sync = new Promise(function (rs) { $('attachhook', this).once('error', function () { rs(); }); }); this._selectListScrollSession = null; this._itemIdxByValue = null; return this; } SelectMenu.tag = 'selectmenu-old'; SelectMenu.render = function () { return _({ class: ['absol-selectmenu'], extendEvent: ['change', 'minwidthchange'], attr: { tabindex: '1' }, child: [ '.absol-selectmenu-holder-item', { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] }, 'attachhook', ] }); }; SelectMenu.optimizeResource = true; // //will remove after SelectMenu completed SelectMenu.getRenderSpace = function () { if (!SelectMenu.getRenderSpace.warned) { // console.warn('SelectMenu.getRenderSpace() will be removed in next version'); } SelectMenu.getRenderSpace.warned = true; if (!SelectMenu.$renderSpace) { SelectMenu.$renderSpace = _('.absol-selectmenu-render-space') .addTo(document.body); } return SelectMenu.$renderSpace; }; SelectMenu.getAnchorCtn = function () { if (!SelectMenu.$anchorCtn) { SelectMenu.$anchorCtn = _('.absol-selectmenu-anchor-container') .addTo(document.body); } return SelectMenu.$anchorCtn; }; SelectMenu.prototype.updateItem = function () { this.$holderItem.clearChild(); if (this._itemsByValue[this.value]) { var elt = _({ tag: 'selectlistitem', props: { data: this._itemsByValue[this.value] } }).addTo(this.$holderItem); elt.$descCtn.addStyle('width', this.$selectlist._descWidth + 'px'); } }; SelectMenu.prototype._dictByValue = function (items) { var dict = {}; var item; for (var i = 0; i < items.length; ++i) { item = items[i]; dict[item.value + ''] = item; } return dict; }; SelectMenu.prototype.init = function (props) { props = props || {}; Object.keys(props).forEach(function (key) { if (props[key] === undefined) delete props[key]; }); if (!('value' in props)) { if (props.items && props.items.length > 0) props.value = typeof props.items[0] == 'string' ? props.items[0] : props.items[0].value; } var value = props.value; delete props.value; this.super(props); this.value = value; }; SelectMenu.property = {}; SelectMenu.property.items = { set: function (value) { this._searchCache = {}; this._itemIdxByValue = null; /** * verity data */ if (value) { value.forEach(function (it) { if (it && it.text) { it.text = it.text + ''; } }); } this._items = value; this._itemsByValue = this._dictByValue(value); if (!this._itemsByValue[this.value] && value.length > 0) { this.value = value[0].value; } else this.updateItem(); this.$dropdownBox.removeStyle('min-width'); this.selectListBound = this.$selectlist.setItemsAsync(value || []); this.style.setProperty('--select-list-desc-width', this.$selectlist.measuredSize.descWidth + 'px'); this._resourceReady = true; this.addStyle('min-width', this.selectListBound.width + 2 + 23 + 'px'); this.emit('minwidthchange', { target: this, value: this.selectListBound.width + 2 + 23, type: 'minwidthchange' }, this); }, get: function () { return this._items || []; } }; SelectMenu.property.value = { set: function (value) { this.$selectlist.value = value; this._lastValue = value; this.updateItem(); }, get: function () { return this.$selectlist.value; } }; SelectMenu.property.enableSearch = { set: function (value) { this._enableSearch = !!value; if (value) { this.$searchTextInput.removeStyle('display'); } else { this.$searchTextInput.addStyle('display', 'none'); } }, get: function () { return !!this._enableSearch; } }; SelectMenu.prototype.updateDropdownPostion = function (updateAnchor) { if (!this.isFocus) { this.$anchorContentCtn .removeStyle('left') .removeStyle('top'); this.$dropdownBox.removeStyle('min-width'); return; } var bound = this.getBoundingClientRect(); if (!updateAnchor) { var outBound = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].traceOutBoundingClientRect */ .ZP.traceOutBoundingClientRect(this); if (!this.isFocus || bound.top > outBound.bottom || bound.bottom < outBound.top) { this.isFocus = false; return; } var anchorOutBound = absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].traceOutBoundingClientRect */ .ZP.traceOutBoundingClientRect(this.$anchor); var searchBound = this.$searchTextInput.getBoundingClientRect(); var availableTop = bound.top - anchorOutBound.top - (this.enableSearch ? searchBound.height + 8 : 0) - 20; var availableBottom = anchorOutBound.bottom - bound.bottom - (this.enableSearch ? searchBound.height + 8 : 0) - 20; if (this.forceDown || availableBottom >= this.selectListBound.height || availableBottom > availableTop) { this.isDropdowUp = false; if (this.$dropdownBox.firstChild != this.$searchTextInput) { this.$searchTextInput.selfRemove(); this.$dropdownBox.addChildBefore(this.$searchTextInput, this.$vscroller); } this.$vscroller.addStyle('max-height', availableBottom + 'px'); } else { this.isDropdowUp = true; if (this.$dropdownBox.lastChild !== this.$searchTextInput) { this.$searchTextInput.selfRemove(); this.$dropdownBox.addChild(this.$searchTextInput); } this.$vscroller.addStyle('max-height', availableTop + 'px'); } this.$dropdownBox.addStyle('min-width', bound.width + 'px'); } var anchorBound = this.$anchor.getBoundingClientRect(); if (this.isDropdowUp) { this.$anchorContentCtn.addStyle({ left: bound.left - anchorBound.left + 'px', top: bound.top - anchorBound.top - this.$dropdownBox.clientHeight - 1 + 'px', }); } else { this.$anchorContentCtn.addStyle({ left: bound.left - anchorBound.left + 'px', top: bound.bottom - anchorBound.top + 'px', }); } }; SelectMenu.prototype.scrollToSelectedItem = function () { var self = this; setTimeout(function () { if (self.$selectlist.$selectedItem) { var fistChildBound = self.$selectlist.childNodes[1].getBoundingClientRect(); var lastChildBound = self.$selectlist.lastChild.getBoundingClientRect(); var listBound = { top: fistChildBound.top, height: lastChildBound.bottom - fistChildBound.top, bottom: lastChildBound.bottom } var itemBound = self.$selectlist.$selectedItem.getBoundingClientRect(); if (self.isDropdowUp) { var scrollBound = self.$vscroller.getBoundingClientRect(); self.$vscroller.scrollTop = Math.max(itemBound.bottom - scrollBound.height - listBound.top, 0); } else { self.$vscroller.scrollTop = itemBound.top - listBound.top; } } }.bind(this), 3); }; SelectMenu.prototype.startTrackScroll = function () { var trackElt = this.parentElement; while (trackElt) { if (trackElt.addEventListener) { trackElt.addEventListener('scroll', this.eventHandler.scrollParent, false); } else { trackElt.attachEvent('onscroll', this.eventHandler.scrollParent, false); } this.$scrollTrackElts.push(trackElt); trackElt = trackElt.parentElement; } if (document.addEventListener) { document.addEventListener('scroll', this.eventHandler.scrollParent, false); document.addEventListener('wheel', this.eventHandler.wheelDocument, true); } else { document.attachEvent('onscroll', this.eventHandler.scrollParent, false); } this.$scrollTrackElts.push(document); }; SelectMenu.prototype.stopTrackScroll = function () { var trackElt; for (var i = 0; i < this.$scrollTrackElts.length; ++i) { trackElt = this.$scrollTrackElts[i]; if (trackElt.removeEventListener) { trackElt.removeEventListener('scroll', this.eventHandler.scrollParent, false); } else { trackElt.dettachEvent('onscroll', this.eventHandler.scrollParent, false); } } this.$scrollTrackElts = []; }; SelectMenu.prototype.startListenRemovable = function () { var removableElt = this.parentElement; while (removableElt) { if (removableElt.isSupportedEvent && removableElt.isSupportedEvent('remove')) { removableElt.on('remove', this.eventHandler.removeParent); } removableElt = removableElt.parentElement; } }; SelectMenu.prototype.stopListenRemovable = function () { var removableElt; while (this.$removableTrackElts.length > 0) { removableElt = this.$removableTrackElts.pop(); removableElt.off('remove', this.eventHandler.removeParent); } }; SelectMenu.prototype._releaseResource = function () { this.$selectlist.items = []; }; SelectMenu.prototype._requestResource = function () { this.$selectlist.items = this._items || []; }; SelectMenu.property.isFocus = { set: function (value) { if (value && (this.disabled || this.readOnly)) return; var self = this; value = !!value; if (value == this.isFocus) return; this._isFocus = value; if (value) { this.startTrackScroll(); this.selectListScrollToken = null;//force scroll var isAttached = false; setTimeout(function () { if (isAttached) return; $('body').on('mousedown', self.eventHandler.bodyClick); isAttached = true; }, 1000); $('body').once('click', function () { setTimeout(function () { if (isAttached) return; $('body').on('mousedown', self.eventHandler.bodyClick); isAttached = true; }, 10); }); if (this.enableSearch) { setTimeout(function () { self.$searchTextInput.focus(); }, 50); } this.updateDropdownPostion(); this.scrollToSelectedItem(); this.$anchor.removeClass('absol-disabled'); } else { this.$anchor.addClass('absol-disabled'); this.stopTrackScroll(); $('body').off('mousedown', this.eventHandler.bodyClick); setTimeout(function () { if (self.$searchTextInput.value != 0) { self.$searchTextInput.value = ''; self.$selectlist.items = self.items; self._resourceReady = true; self.$selectlist.removeClass('as-searching'); } }, 100) this.updateItem(); } }, get: function () { return !!this._isFocus; } }; SelectMenu.property.disabled = { set: function (value) { if (value) { this.addClass('disabled'); } else { this.removeClass('disabled'); } }, get: function () { return this.hasClass('disabled'); } }; SelectMenu.property.hidden = { set: function (value) { if (value) { this.addClass('hidden'); } else { this.removeClass('hidden'); } }, get: function () { return this.addClass('hidden'); } }; SelectMenu.property.selectedIndex = { get: function () { if (!this._itemIdxByValue) { this._itemIdxByValue = {}; for (var i = 0; i < this._items.length; ++i) { this._itemIdxByValue[this._items[i].value] = i; } } var idx = this._itemIdxByValue[this._value]; return idx >= 0 ? idx : -1; } }; /** * @type {SelectMenu} */ SelectMenu.eventHandler = {}; SelectMenu.eventHandler.attached = function () { if (this._updateInterval) return; if (!this.$anchor.parentNode) this.$anchor.addTo(this.$anchorCtn); this.$attachhook.updateSize = this.$attachhook.updateSize || this.updateDropdownPostion.bind(this); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_3__/* ["default"].addToResizeSystem */ .ZP.addToResizeSystem(this.$attachhook); this.stopListenRemovable(); this.startListenRemovable(); if (!this._resourceReady) { this._requestResource(); this._resourceReady = true; } this._updateInterval = setInterval(function () { if (!this.isDescendantOf(document.body)) { clearInterval(this._updateInterval); this._updateInterval = undefined; this.$anchor.selfRemove(); this.stopTrackScroll(); this.stopListenRemovable(); this.eventHandler.removeParent(); } }.bind(this), 10000); }; SelectMenu.eventHandler.scrollParent = function (event) { var self = this; if (this._scrollFrameout > 0) { this._scrollFrameout = 10; return; } this._scrollFrameout = this._scrollFrameout || 10; function update() { self.updateDropdownPostion(false); self.scrollToSelectedItem(); self._scrollFrameout--; if (self._scrollFrameout > 0) requestAnimationFrame(update); } update(); }; SelectMenu.eventHandler.removeParent = function (event) { this._releaseResource(); this._resourceReady = false; }; SelectMenu.eventHandler.click = function (event) { if (absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__/* ["default"].isMouseRight */ .ZP.isMouseRight(event)) return; this.isFocus = !this.isFocus; }; SelectMenu.eventHandler.bodyClick = function (event) { if (!absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__/* ["default"].hitElement */ .ZP.hitElement(this, event) && !absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_2__/* ["default"].hitElement */ .ZP.hitElement(this.$anchor, event)) { setTimeout(function () { this.isFocus = false; }.bind(this), 5) } }; SelectMenu.eventHandler.selectlistPressItem = function (event) { this.updateItem(); if (this._lastValue != this.value) { event.lastValue = this._lastValue; event.value = this.value; setTimeout(function () { this.emit('change', event, this); }.bind(this), 1) this._lastValue = this.value; } }; SelectMenu.eventHandler.searchModify = function (event) { var filterText = this.$searchTextInput.value.replace(/((\ )|(\s))+/g, ' ').trim(); if (filterText.length == 0) { this._resourceReady = true; this.$selectlist.items = this.items; this.scrollToSelectedItem(); this.$selectlist.removeClass('as-searching'); } else { this.$selectlist.addClass('as-searching'); var view = []; if (!this._searchCache[filterText]) { if (this._items.length > 0 && !this._items[0].__nvnText__) { (0,_list_search__WEBPACK_IMPORTED_MODULE_4__/* .prepareSearchForList */ .Lb)(this._items); } view = (0,_list_search__WEBPACK_IMPORTED_MODULE_4__/* .searchListByText */ .o)(filterText, this._items); this._searchCache[filterText] = view; } else { view = this._searchCache[filterText]; } this.$selectlist.items = view; this._resourceReady = true; this.$vscroller.scrollTop = 0; } this.selectListBound = this.$selectlist.getBoundingClientRect(); this.updateDropdownPostion(true); }; SelectMenu.eventHandler.listSizeChangeAsync = function () { this.updateDropdownPostion(); }; SelectMenu.eventHandler.listValueVisibility = function (event) { if (!this.isFocus) return; if (this._selectListScrollSession == event.session) return; this._selectListScrollSession = event.session; this.scrollToSelectedItem(); }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(SelectMenu); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SelectMenu); /***/ }), /***/ 9950: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports NOT_READY, READY, START, RUNNING, PAUSE, STOP, ERROR, STATE_TO_STRING */ /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); var _ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$ */ .Z.$; var NOT_READY = 0; var READY = 1; var START = 2; var RUNNING = 3; var PAUSE = 4; var STOP = 5; var ERROR = 6; var STATE_TO_STRING = ['NOT_READY', 'READY', 'START', 'RUNNING', 'PAUSE', 'STOP', 'ERROR']; /** * @augments AElement * @augments HTMLCanvasElement * @constructor */ function Sprite() { this.loadTextureTimeout = 5000; this._textureLoaded = false; this._state = NOT_READY; this.defineEvent(['ready', 'srcerror', 'play', 'resume', 'pause', 'stop', 'reset', 'end', 'frame']); this._length = 60; this._lastDrawFrame = -1; this._frameIndex = 0; this._timeout = -1; this.ctx = this.getContext('2d'); this._fps = 10; this._lastDrawMilis = 0; this._overTime = 0; this.draw = this.draw.bind(this); this.texture = null; this._frames = { type: 'grid', col: 1, row: 1 }; this._loop = false; } Sprite.cache = {}; Sprite.prototype.draw = function () { //todo var now = new Date().getTime(); var dt = this._overTime + now - this._lastDrawMilis; var di = Math.floor(dt / 1000 * this._fps); var frameIndex = (this._frameIndex + di); if (this._loop) { frameIndex = frameIndex % this._length; } else { frameIndex = Math.min(this._length - 1, frameIndex); } if (!isNaN(this._frameIndex) && frameIndex != this._frameIndex) { this.drawFrame(this._frameIndex); } this._overTime = dt - di * 1000 / this._fps; var nextTime = now + 1000 / this._fps - this._overTime - new Date().getTime(); this._lastDrawMilis = now; this._frameIndex = frameIndex; this._timeout = -1; if (this._loop || frameIndex + 1 < this._length) { if (this._state == RUNNING) this._timeout = setTimeout(this.draw, nextTime); } else this.stop(); }; Sprite.prototype.drawFrame = function (index) { if (this._lastDrawFrame == index) return; this._lastDrawFrame = index; this.ctx.clearRect(0, 0, this.width, this.height); if (this._frames.type == 'grid') { var imgWidth = this.texture.naturalWidth; var imgHeight = this.texture.naturalHeight; var sHeight = imgHeight / this._frames.row; var sWidth = imgWidth / this._frames.col; var sx = (index % this._frames.col) * sWidth; var sy = Math.floor(index / this._frames.col) * sHeight; this.ctx.drawImage(this.texture, sx, sy, sWidth, sHeight, 0, 0, this.width, this.height) } else { } this.emit('frame', { name: 'frame', target: this, frameIndex: index }, this); }; Sprite.prototype.stop = function () { this.pause(); if (this._state != PAUSE) return this; this._state = STOP; this.emit('stop', { name: 'stop', target: this }, this); return this; }; Sprite.prototype.pause = function () { if (this._state != RUNNING) return this; this._state = PAUSE; if (this._timeout > 0) { clearTimeout(this._timeout); this._timeout = -1; } var now = new Date().getTime(); this._overTime += now - this._lastDrawMilis; this.emit('pause', { name: 'pause', target: this }, this); }; Sprite.prototype.resume = function () { if (this._state != START && this._state != PAUSE) return this; if (this._state == RUNNING) return this; this._state = RUNNING; var now = new Date().getTime(); this._lastDrawMilis = now; this.draw(); this.emit('resume', { name: 'pause', target: this }, this); }; Sprite.prototype.reset = function () { this._frameIndex = 0; this._overTime = 0; } Sprite.prototype.play = function () { if (this._state == ERROR) return this; if (this._state == RUNNING) return this; if (this._state == READY || this._state == STOP) { this.reset(); } this._state = START; this.emit('play', { name: 'start', target: this }, this); this.resume(); return this; }; Sprite.prototype.afterReady = function () { var thisSprite = this; if (this._state != NOT_READY && this._state != ERROR) return Promise.resolve(); else return new Promise(function (rs, rj) { thisSprite.once('ready', rs); thisSprite.once('srcerror', rj); }); }; Sprite.tag = 'sprite'; Sprite.render = function () { return _('canvas.as-sprite'); }; Sprite.property = {}; Sprite.property.frames = { set: function (value) { this.stop(); this._lastDrawFrame = -1; if (value && value.type == 'grid') { this._length = value.col * value.row; } this._frames = value; if (this._textureLoaded && this._frames && this._state == NOT_READY) {//todo: verify frame this._state = READY; this.emit('ready', { target: this, name: 'ready' }, this); } }, get: function () { return this._frames; } }; Sprite.property.frameIndex = { set: function (value) { value = value || 0; if (value < 0) value = this._length - 1; if (this._loop) { this._frameIndex = value % this._length; this._overTime = 0; } else { this._frameIndex = Math.max(this._length - 1, value); this._overTime = 0; } this.drawFrame(this._frameIndex); }, get: function () { return this._frameIndex; } }; Sprite.property.src = { set: function (value) { this.stop(); this._lastDrawFrame = -1;//did not draw any thing value = value || []; var lastSrc = this._src; this._src = value || null; if (lastSrc == this._src) return; if (!value) this.texture = null; else { var cImage; if (!Sprite.cache[this._src]) { cImage = new Image(); Sprite.cache[this._src] = cImage; cImage.src = this._src; } else { cImage = Sprite.cache[this._src]; } this.texture = cImage; this._state = NOT_READY; var thisSprite = this; this._textureLoaded = false; absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* ["default"].waitImageLoaded */ .ZP.waitImageLoaded(this.texture, this.loadTextureTimeout).then(function (rs) { if (thisSprite.texture == cImage) { thisSprite._textureLoaded = true; if (thisSprite._frames) { thisSprite._lastDrawFrame = -1; thisSprite._state = READY; thisSprite.emit('ready', { target: thisSprite, name: 'ready' }, thisSprite); } } }, function () { if (thisSprite.texture == cImage) { thisSprite._state = ERROR; thisSprite.emit('srcerror', { target: thisSprite, name: 'srcerror' }, thisSprite); } }); } }, get: function () { return this._src; } } Sprite.property.state = { get: function () { return STATE_TO_STRING[this._state]; } }; Sprite.property.length = { get: function () { return this._length; } }; Sprite.property.fps = { set: function (value) { value = Math.max(value || 0, 0); this._fps = value; if (this._state == RUNNING) { clearTimeout(this._timeout); this._timeout = -1; var now = new Date().getTime(); this._overTime += now - this._lastDrawMilis; this._overTime = Math.min(1000 / this._fps, this._overTime); this.draw(); } }, get: function () { return this._fps; } }; Sprite.property.loop = { set: function (value) { value = !!value; this._loop = value; }, get: function () { return this._loop; } } _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(Sprite); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Sprite); /***/ }), /***/ 7: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ js_TabView) }); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tabview.css var tabview = __webpack_require__(3759); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TabButton.js var _ = ACore/* default._ */.Z._; var $ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function TabButton() { var thisTB = this; this._icon = null; this.$extIconCtn = $('.as-tab-bar-button-ext-icon-ctn', this); this.$close = $('.absol-tabbar-button-close', this) this.$iconCtn = $('.absol-tabbar-button-icon-container', this).on('click', function (event) { event.tabButtonEventName = 'delete'; thisTB.emit('close', event); }); this.$modifiedFlag = $('.absol-tabbar-button-modified-flag', this) .on('click', function (event) { event.tabButtonEventName = 'delete'; thisTB.emit('close', event); }); this.$textView = $('.absol-tabbar-button-text', this); this.on({ click: function (event) { if (event.tabButtonEventName) return; event.tabButtonEventName = 'active'; thisTB.emit('active', event); } }); } TabButton.tag = 'TabButton'.toLowerCase(); TabButton.render = function () { return _({ tag: 'button', class: 'absol-tabbar-button', extendEvent: ['close', 'active'], id: (0,stringGenerate.randomIdent)(20), child: [ { class: 'as-tab-bar-button-ext-icon-ctn' }, { class: 'absol-tabbar-button-text', }, { class: 'absol-tabbar-button-icon-container', child: [ { tag: 'span', class: ['absol-tabbar-button-close', 'mdi-close', 'mdi'], attr: { title: 'Close' } }, { tag: 'span', class: ['absol-tabbar-button-close-circle', 'mdi-close-circle', 'mdi'], attr: { title: 'Close' } }, { tag: 'span', class: ['absol-tabbar-button-modified-flag', 'mdi', 'mdi-checkbox-blank-circle'] } ] } ] }); }; TabButton.property = {}; TabButton.property.active = { set: function (value) { this._active = value; if (value) this.addClass('absol-tabbar-button-active'); else this.removeClass('absol-tabbar-button-active'); }, get: function () { return this._active; } }; TabButton.property.name = { set: function (value) { this._name = value || ''; this.$textView.innerHTML = this._name; }, get: function () { return this._name; } }; TabButton.property.desc = { set: function (value) { this.attr('title', value); }, get: function () { return this.attr('title'); } }; TabButton.property.icon = { set: function (value) { value = value || null; this._icon = value; this.$extIconCtn.clearChild(); if (this._icon) { this.$extIconCtn.addChild(_(value)); } }, get: function () { return this._icon; } } TabButton.property.modified = { set: function (value) { if (value) { this.addClass('absol-tabbar-button-modified'); } else { this.removeClass('absol-tabbar-button-modified'); } }, get: function () { return this.hasClass('absol-tabbar-button-modified'); } }; TabButton.property.preventClosing = { set: function (value) { if (value) { this.addClass('as-prevent-closing'); } else { this.removeClass('as-prevent-closing'); } }, get: function () { return this.hasClass('as-prevent-closing'); } } ACore/* default.install */.Z.install(TabButton); /* harmony default export */ const js_TabButton = ((/* unused pure expression or super */ null && (TabButton))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TabBar.js var TabBar_ = ACore/* default._ */.Z._; var TabBar_$ = ACore/* default.$ */.Z.$; /*** * @extends HScroller * @constructor */ function TabBar() { this.$parent = null; this.$addBtn = TabBar_({ tag: 'button', class: 'as-tab-bar-add-btn', child: 'span.mdi.mdi-plus', on: { click: function () { if (this.$parent) { this.$parent.emit('pressaddtab', { type: 'pressaddtab', target: this.$parent }, this.$parent); } }.bind(this) } }); this.addChild(this.$addBtn); this.defineEvent(['active', 'close']); this.on('wheel', function (event) { var lastLeft = this.$viewport.scrollLeft; if (event.deltaY > 1) { this.$viewport.scrollLeft += 50; } else if (event.deltaY < -1) { this.$viewport.scrollLeft -= 50; } if (lastLeft != this.$viewport.scrollLeft) event.preventDefault(); }); this._tabs = []; } TabBar.tag = 'tabbar'; TabBar.render = function () { return TabBar_('hscroller.absol-tabbar'); }; TabBar.prototype.getAllTabButtons = function () { var buttons = []; TabBar_$('tabbutton', this, function (e) { buttons.push(e); }); return buttons; }; /*** * * @param {string} ident * @return {TabButton} */ TabBar.prototype.getButtonByIdent = function (ident) { return TabBar_$('tabbutton#tabbuton-' + ident, this); }; TabBar.property = {}; TabBar.property.tabs = { set: function (value) { this.clearChild(); this._tabs = []; (value || []).forEach(this.addTab.bind(this)); }, get: function () { //each hold item data return this._tabs || []; } }; /*** * * @param {{text}} * @return {tabbar} */ TabBar.prototype.addTab = function (value) { var self = this; var props = {}; if (typeof value == "string") { props.name = value; } else { if (value.name) { props.name = value.name; } else { throw new Error('Tab must has name attribute'); } if (value.desc) props.desc = value.desc; if (value.tabIcon) { props.icon = value.tabIcon; } if (value.preventClosing) { props.preventClosing = value.preventClosing; } } var tabButton = TabBar_({ tag: 'tabbutton', props: props, on: { active: function (event, sender) { var prevented = false; self.emit('active', { target: this, value: value, preventDefault: function () { prevented = true; } }, self); if (!prevented) { self.getAllTabButtons().forEach(function (e) { e.active = false; }); this.active = true; } }, close: function (event, sender) { var prevented = false; self.emit('close', { target: this, value: value, preventDefault: function () { prevented = true; } }, self); if (!prevented) { //todo:active other this.remove(); } } } }); this.addChildBefore(tabButton, this.$addBtn) if (value.id) tabButton.attr('id', 'tabbuton-' + value.id); this._tabs.push(tabButton); this.requestUpdateSize(); return tabButton; }; TabBar.prototype.removeTab = function (id) { this._tabs = this._tabs.filter(function (value) { return value == id; }); TabBar_$('#tabbuton-' + id, this).remove(); this.requestUpdateSize(); }; TabBar.prototype.activeTab = function (id) { var self = this; var activedbtn = TabBar_$('.absol-tabbar-button-active', this); if (activedbtn && activedbtn.attr('id') != id) { activedbtn.active = false; } var mButton = TabBar_$('#tabbuton-' + id, this); if (mButton) { mButton.active = true; setTimeout(function () { self.scrollInto(mButton); }, 30) } }; TabBar.prototype.setModified = function (ident, flag) { var bt = this.getButtonByIdent(ident); if (bt) { bt.modified = flag; } }; ACore/* default.install */.Z.install(TabBar); /* harmony default export */ const js_TabBar = ((/* unused pure expression or super */ null && (TabBar))); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextMeasure.js + 1 modules var TextMeasure = __webpack_require__(2610); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/NotificationPanel.js var NotificationPanel = __webpack_require__(7570); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TabView.js var TabView_ = ACore/* default._ */.Z._; var TabView_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function TabView() { var thisTV = this; /*** * * @type {TabBar} */ this.$tabbar = TabView_$('tabbar', this); this.$tabbar.$parent = this; this.$tabbar.on({ close: TabView.eventHandler.closeTab.bind(thisTV), active: TabView.eventHandler.activeTab.bind(thisTV) }); this._title = ''; this._frameHolders = []; this._history = []; (0,utils.forwardEvent)(this, 'inactivetab', 'deactivetab'); this.rightCtnPlugin = new TabviewRightCtnPlugin(this); (0,OOP/* drillProperty */.pj)(this, this.rightCtnPlugin, ['tvTitle', 'notificationPanel']); } TabView.tag = 'TabView'.toLowerCase(); TabView.render = function () { return TabView_({ class: 'absol-tabview', extendEvent: ['activetab', 'inactivetab', 'removetab', 'requestremovetab', 'pressaddtab'], child: [ 'tabbar' ] }); }; TabView.eventHandler = {}; TabView.eventHandler.closeTab = function (event) { event.preventDefault(); var id = event.value.id; this.removeTab(id, true); }; TabView.eventHandler.activeTab = function (event) { event.preventDefault(); var id = event.value.id; this.activeTab(id, true); }; TabView.prototype.activeTab = function (id, userActive) { var self = this; var resPromise = []; var needDeactivatedHolder = []; var needActiveHolder = []; this._frameHolders.forEach(function (holder) { if (holder.containerElt.hasClass('absol-tabview-container-hidden')) { if (holder.id + '' === id + '') { needActiveHolder.push(holder); } } else { if (holder.id + '' !== id + '') { needDeactivatedHolder.push(holder); } } }); needDeactivatedHolder.forEach(function (holder) { holder.containerElt.addClass('absol-tabview-container-hidden'); holder.tabFrame.emit('inactive', { type: 'inactive', target: holder.tabFrame, id: holder.id, userActive: !!userActive, tabButton: holder.tabButton, holder: holder }, holder.tabFrame); }); needActiveHolder.forEach(function (holder) { self._history.push(holder.id); holder.containerElt.removeClass('absol-tabview-container-hidden'); self.$tabbar.activeTab(holder.id); holder.tabFrame.emit('active', { type: 'active', target: holder.tabFrame, id: holder.id, userActive: !!userActive, tabButton: holder.tabButton, holder: holder }, holder.tabFrame); self.emit('activetab', { type: 'activetab', target: self, id: holder.id, userActive: !!userActive, tabButton: holder.tabButton, holder: holder, from: (needDeactivatedHolder[0] && needDeactivatedHolder[0].tabFrame || null), to: holder.tabFrame }, self); }); }; TabView.prototype.removeTab = function (id, userActive) { var self = this; var resPromise = []; this._frameHolders.forEach(function (holder) { if (holder.id + '' === id + '') { var eventData = { type: 'requestremove', id: id, userActive: !!userActive, target: holder.tabFrame, tabFrame: holder.tabFrame, tabButton: holder.tabButton, holder: holder, __promise__: Promise.resolve(), waitFor: function (promise) { this.__promise__ = promise; } }; holder.tabFrame.emit('requestremove', eventData, holder.tabFrame); eventData.type = 'requestremovetab'; eventData.target = self; self.emit('requestremovetab', eventData, self); resPromise.push( eventData.__promise__.then(function () { //if ok var eventData2 = { type: 'inactive', target: holder.tabFrame, id: holder.id, userActive: !!userActive, tabButton: holder.tabButton, holder: holder }; if (!holder.containerElt.hasClass('absol-tabview-container-hidden')) holder.tabFrame.emit('inactive', eventData2, holder.tabFrame); eventData2.type = 'inactivetab'; eventData2.target = self; if (!holder.containerElt.hasClass('absol-tabview-container-hidden')) self.emit('inactivetab', eventData2, self); self._frameHolders = self._frameHolders.filter(function (x) { return x.id + '' !== id + ''; }); holder.tabFrame.notifyDetached(); self.$tabbar.removeTab(holder.id); holder.containerElt.remove(); eventData2.type = 'remove'; eventData2.target = holder.tabFrame; holder.tabFrame.emit('remove', eventData2, holder.tabFrame); eventData2.type = 'removetab'; eventData2.target = self; self.emit('removetab', eventData2, self); self.activeLastTab(); }, function () { //if reject }) ); } }); return Promise.all(resPromise); }; TabView.prototype.notifyUpdateDesc = function (elt) { var holder = this.findHolder(elt); if (holder) { holder.tabButton.desc = elt.desc; } }; TabView.prototype.notifyUpdateName = function (elt) { var holder = this.findHolder(elt); if (holder) { holder.tabButton.name = elt.name; } }; TabView.prototype.notifyUpdateModified = function (elt) { var holder = this.findHolder(elt); if (holder) { holder.tabButton.modified = elt.modified; } }; TabView.prototype.notifyUpdatePreventClosing = function (elt) { var holder = this.findHolder(elt); if (holder) { holder.tabButton.preventClosing = elt.preventClosing; } }; TabView.prototype.findHolder = function (elt) { for (var i = 0; i < this._frameHolders.length; ++i) { var holder = this._frameHolders[i]; if (holder.tabFrame === elt) { return holder; } } }; TabView.prototype.addChild = function () { var self = this; Array.prototype.forEach.call(arguments, function (elt) { if (!elt.notifyAttached || !elt.notifyDetached) { throw new Error('element is not a tabframe'); } var containerElt = TabView_('.absol-tabview-container.absol-tabview-container-hidden'); self.appendChild(containerElt);//origin function elt.selfRemove(); var id = elt.attr('id'); var desc = elt.attr('desc') || undefined; var name = elt.attr('name') || 'NoName'; var tabIcon = elt.tabIcon; var modified = elt.modified; var preventClosing = elt.preventClosing; var tabButton = self.$tabbar.addTab({ name: name, id: id, desc: desc, modified: modified, tabIcon: tabIcon, preventClosing: preventClosing }); containerElt.addChild(elt); elt.notifyAttached(self); var holder = {}; OOP/* default.drillProperty */.ZP.drillProperty(holder, elt, 'id'); OOP/* default.drillProperty */.ZP.drillProperty(holder, elt, 'desc'); OOP/* default.drillProperty */.ZP.drillProperty(holder, elt, 'name'); OOP/* default.drillProperty */.ZP.drillProperty(holder, elt, 'preventClosing'); Object.defineProperties(holder, { tabButton: { value: tabButton, writable: false }, tabFrame: { value: elt, writable: false }, containerElt: { value: containerElt, writable: false } }); self._frameHolders.push(holder); self.activeTab(id); }); }; TabView.prototype.activeLastTab = function () { var dict = this._frameHolders.reduce(function (ac, holder) { ac[holder.id] = true; return ac; }, {}); while (this._history.length > 0) { var id = this._history[this._history.length - 1]; if (dict[id]) { this.activeTab(id); break; } else { this._history.pop(); } } }; TabView.prototype.getChildAt = function (index) { return this._frameHolders[index].tabFrame; }; TabView.prototype.getAllChild = function () { return this._frameHolders.map(function (holder) { return holder.tabFrame; }); }; TabView.prototype.getActiveTabHolder = function () { var holder = null; for (var i = 0; i < this._frameHolders.length; ++i) { holder = this._frameHolders[i]; if (!holder.containerElt.hasClass('absol-tabview-container-hidden')) { return holder; } } return null; }; TabView.prototype.getActiveTab = function () { var holder = this.getActiveTabHolder(); return holder && holder.tabFrame; }; TabView.prototype.getActiveTabId = function () { var holder = this.getActiveTabHolder(); return holder && holder.id; }; TabView.prototype.getTabById = function (id) { var holder = this.getTabHolderById(id); return holder && holder.tabFrame; }; TabView.prototype.getTabHolderById = function (id) { var holder = null; for (var i = 0; i < this._frameHolders.length; ++i) { holder = this._frameHolders[i]; if (holder.id === id) { return holder; } } return null; } TabView.prototype.activeFrame = function (elt) { if (typeof elt == "string") { return this.activeTab(elt); } else if (elt && elt.attr) { return this.activeTab(elt.attr('id')); } else { throw new Error("Invalid param, must be id or elt!"); } }; TabView.property = {}; TabView.property.historyOfTab = { get: function () { return this._history.slice(); } }; ACore/* default.install */.Z.install('tabview', TabView); /* harmony default export */ const js_TabView = (TabView); /** * * @param {TabView} elt * @constructor */ function TabviewRightCtnPlugin(elt) { this.elt = elt; this.$rightCtn = null; this.$title = null; this.$notificationPanel = null; this._title = ''; } TabviewRightCtnPlugin.prototype.initCtn = function () { if (this.$rightCtn) return; this.$rightCtn = TabView_({ class: 'as-tabview-right-ctn' }); this.$rightCtn.requestUpdateSize = this.updateSize.bind(this); this.elt.insertBefore(this.$rightCtn, this.elt.$tabbar.nextSibling); }; TabviewRightCtnPlugin.prototype.updateSize = function () { var width = 0; if (this.$title) { width += TextMeasure/* default.measureWidth */.Z.measureWidth(this._title, 'Arial', 14) + 20; } if (this.$notificationPanel) { width += 20; width += this.$notificationPanel.childNodes.length * 40; if (this.$notificationPanel.childNodes.length >0) width += (this.$notificationPanel.childNodes.length - 1) * 10; } this.elt.$tabbar.addStyle('right', width + 'px'); }; Object.defineProperty(TabviewRightCtnPlugin.prototype, 'tvTitle', { set: function (value) { this.initCtn(); this._title = value + ''; if (!this.$title) { this.$title = TabView_({ class: 'as-tabview-title', child: { text: '' } }); this.$rightCtn.addChild(this.$title); } this.$title.firstChild.data = value; this.updateSize(); }, get: function () { return this._title; } }); Object.defineProperty(TabviewRightCtnPlugin.prototype, 'notificationPanel', { get: function () { this.initCtn(); if (!this.$notificationPanel) { this.$notificationPanel = TabView_({ tag: NotificationPanel/* default */.ZP, }); this.$rightCtn.addChildBefore(this.$notificationPanel, this.$title); this.updateSize(); } return this.$notificationPanel; } }); /***/ }), /***/ 5789: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_textarea2_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2764); /* harmony import */ var _css_textarea2_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_textarea2_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _SelectMenu__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5357); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3349); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * * @augments HTMLTextAreaElement * @augments AElement * * @constructor */ function TextArea2() { this.on('keydown', this.eventHandler.keydown); this.on('paste', this.eventHandler.paste); this.on('cut', this.eventHandler.paste); } TextArea2.tag = 'TextArea2'.toLowerCase(); TextArea2.render = function () { return _('textarea.absol-textarea2'); }; TextArea2.getRenderPre = function () { if (!TextArea2.$preSpace) { TextArea2.$preSpace = _('textarea').addStyle({ 'overflow': 'hidden', 'height': '12px', 'resize': 'none' }).addTo(_SelectMenu__WEBPACK_IMPORTED_MODULE_2__/* ["default"].getRenderSpace */ .Z.getRenderSpace()); } return TextArea2.$preSpace; }; TextArea2.prototype.updateSize = function () { var heightStyle = this._measureHeight(this.value); this.addStyle('--content-height', heightStyle); }; TextArea2.eventHandler = {}; TextArea2.eventHandler.keydown = function (event) { if (event.altKey || event.ctrlKey) return; var key = event.key || String.fromCharCode(event.which || event.keyCode); var selectPost = this.getInputSelection(); var leftText = this.value.substring(0, selectPost.start); var rightText = this.value.substring(selectPost.end); var middText = ''; if (key == 'Enter') { middText = '\n'; } else if (key == 'Backspace') { if (leftText.length > 0) { leftText = leftText.substring(0, leftText.length - 1); } } else if (key == 'Delete') { if (selectPost.start < selectPost.end) { middText = ''; } else if (rightText.length > 0) { rightText = rightText.substring(1); } } else if (key.length == 1) {//char middText = key; } else { return; } var newText = leftText + middText + rightText; var heightStyle = this._measureHeight(newText); this.addStyle('--content-height', heightStyle); }; TextArea2.eventHandler.paste = function (event) { // var text = var cl = event.clipboardData || window.clipboardData; var middText = cl.getData('Text') || ''; var selectPost = this.getInputSelection(); var leftText = this.value.substring(0, selectPost.start); var rightText = this.value.substring(selectPost.end); var newText = leftText + middText + rightText; var heightSyle = this._measureHeight(newText); this.addStyle('--content-height', heightSyle); }; TextArea2.eventHandler.cut = function (event) { // var text = var cl = event.clipboardData || window.clipboardData; var selectPost = this.getInputSelection(); var leftText = this.value.substring(0, selectPost.start); var rightText = this.value.substring(selectPost.end); var newText = leftText + rightText; var heightSyle = this._measureHeight(newText); this.addStyle('--content-height', heightSyle); }; TextArea2.prototype._measureHeight = function (text) { var pre = TextArea2.getRenderPre(); pre.addStyle('padding-left', this.getComputedStyleValue('padding-left')) pre.addStyle('padding-right', this.getComputedStyleValue('padding-right')) pre.addStyle('padding-top', this.getComputedStyleValue('padding-top')) pre.addStyle('padding-bottom', this.getComputedStyleValue('padding-bottom')); pre.addStyle('width', this.getComputedStyleValue('width')); pre.addStyle('height', this.getFontSize() + 'px'); pre.addStyle('boder', this.getComputedStyleValue('boder')); pre.addStyle('font-size', this.getComputedStyleValue('font-size')); pre.addStyle('font-family', this.getComputedStyleValue('font-family')); pre.value = text; var result = pre.scrollHeight + 'px'; return result; }; /** * Return an object with the selection range or cursor position (if both have the same value) * @param {DOMElement} el A dom element of a textarea or input text. * @return {Object} reference Object with 2 properties (start and end) with the identifier of the location of the cursor and selected text. **/ TextArea2.prototype.getInputSelection = function () { var start = 0, end = 0, normalizedValue, range, textInputRange, len, endRange; if (typeof this.selectionStart == "number" && typeof this.selectionEnd == "number") { start = this.selectionStart; end = this.selectionEnd; } else { range = document.selection.createRange(); if (range && range.parentElement() == this) { len = this.value.length; normalizedValue = this.value.replace(/\r\n/g, "\n"); // Create a working TextRange that lives only in the input textInputRange = this.createTextRange(); textInputRange.moveToBookmark(range.getBookmark()); // Check if the start and end of the selection are at the very end // of the input, since moveStart/moveEnd doesn't return what we want // in those cases endRange = this.createTextRange(); endRange.collapse(false); if (textInputRange.compareEndPoints("StartToEnd", endRange) > -1) { start = end = len; } else { start = -textInputRange.moveStart("character", -len); start += normalizedValue.slice(0, start).split("\n").length - 1; if (textInputRange.compareEndPoints("EndToEnd", endRange) > -1) { end = len; } else { end = -textInputRange.moveEnd("character", -len); end += normalizedValue.slice(0, end).split("\n").length - 1; } } } } return { start: start, end: end }; } _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(TextArea2); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TextArea2); /***/ }), /***/ 2610: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ js_TextMeasure) }); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TextMeasureData.js /* harmony default export */ const TextMeasureData = ({ chars: (" !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~©´ÀÁÂÊÍÒÔÙÚ" + "ÝàáâãèéêìíðòóôõùúýĂăĐđĩũƠơƯưɐɔɕɗəɛɡɣɲʃʒʝʰˆː˘̪̀̃͡τφχẠạẢảẤấẦầẩẫẬậắằẳặẸẹẻẽếỀềểễỆệỉịọỏỐốồổỗỘộỚớỜờởỡỢợụỦủỨứỪừửữựỳỷỹ" + "–‘“”…♥♪【】🤣️�").split(''), fonts: { "Times New Roman": { "width": { "0": "̪̀̃͡️", "5": " ,.", "10": "0123456789#$*_bdghknopquvxyðòóôõùúýđũɗɡɣɲọỏốồổỗộụủỳỷỹ–♪", "20": "…【】", "6.66015625": "!()-I[]`fr´Íʃˆ˘‘", "8.1640625": "\"", "16.66015625": "%", "15.556640625": "&m", "3.603515625": "'", "11.279296875": "+<=>", "5.556640625": "/:;\\ijltìíĩʝːỉị", "8.876953125": "?acezàáâãèéêăɐɔɕəʒχạảấầẩẫậắằẳặẹẻẽếềểễệ“”", "18.41796875": "@", "14.443359375": "ADGHKNOQUVXYwÀÁÂÒÔÙÚÝĂĐƠẠẢẤẦẬỐỘỚỜỢỦ", "13.33984375": "BCR", "12.216796875": "ELTZÊẸỀỆ", "11.123046875": "FPS", "7.783203125": "Js", "17.783203125": "M", "18.876953125": "W", "9.384765625": "^", "9.599609375": "{}", "4.00390625": "|", "10.8203125": "~", "15.1953125": "©", "10.576171875": "ơớờởỡợ", "15.517578125": "ƯỨỪ", "10.83984375": "ưứừửữự", "8.3984375": "ɛ", "6.42578125": "ʰ", "8.037109375": "τ", "11.54296875": "φ", "11.875": "♥", "19.423828125": "🤣�" }, "spacing": { "-0.7421875": "11W:W;", "-2.216796875": "ATP,P.VaVeVyWAY-YAYqYu", "-2.578125": "AVV,V.VAVoY,Y.", "-1.6015625": "AWF,F.RVTAWaWeWo", "-1.8359375": "AYAwAyLTLVPAT-V-W,W.Y:Y;Yp", "-1.484375": "AvFALWT,T.V:V;‘‘", "-2.001953125": "LYYaYeYoYv", "-1.103515625": "LyRWRYT;W-Yir.", "-1.201171875": "RTViVrVuWy", "-0.80078125": "RyWiWrWur,", "-0.99609375": "T:", "-0.361328125": "TOffrg", "-1.396484375": "TaTcTeToTsTwTy", "-0.703125": "TiTrTu", "-0.400390625": "r-", "-1.298828125": "v,v.w,w.y,y.", "-0.439453125": "χφ", "-4.443359375": "【̀【̃【̪【͡】̀】̃】̪】͡", "-11.38671875": "🤣" }, "fontBoundingBoxAscent": 18, "fontBoundingBoxDescent": 4 }, "Arial": { "width": { "0": "̪̀̃͡️", "10": "Jcksvxyzýɔɕỳỷỹ♪", "20": "…【】", "11.123046875": "0123456789#$?L_abdeghnopquàáâãèéêðòóôõùúăđũɐɗəɡɲạảấầẩẫậắằẳặẹẻẽếềểễệọỏốồổỗộụủ–", "5.556640625": " !,./:;I[\\]ftÍìíĩː", "7.099609375": "\"", "17.783203125": "%", "13.33984375": "&ABEKPSVXYÀÁÂÊÝĂẠẢẤẦẬẸỀỆ", "3.818359375": "'", "6.66015625": "()-`r´ˆ˘“”", "7.783203125": "*", "11.6796875": "+<=>~", "20.302734375": "@", "14.443359375": "CDHNRUwÙÚĐỦ", "12.216796875": "FTZ", "15.556640625": "GOQÒÔỐỘ", "16.66015625": "Mm", "18.876953125": "W", "9.384765625": "^", "4.443359375": "ijlʃỉị‘", "6.6796875": "{}", "5.1953125": "|", "14.736328125": "©", "17.1484375": "ƠỚỜỢ", "13.115234375": "ơớờởỡợ", "17.080078125": "ƯỨỪ", "13.388671875": "ưứừửữự", "9.169921875": "ɛ", "10.01953125": "ɣ", "10.8984375": "ʒ", "7.94921875": "ʝ", "7.666015625": "ʰ", "7.900390625": "τ", "12.96875": "φ", "10.498046875": "χ", "11.875": "♥", "19.423828125": "🤣�" }, "spacing": { "-1.484375": "11ATAVAYLTLVLWLYPATAVAVaYAYaYpv,v.y,y.", "-0.7421875": "AWLyTiTrTuV:V;VrVuVyWAWaYi", "-0.361328125": "AvAwAyRTRVRWRYTOViW-W:W;WeWoWrWuff‘‘", "-2.216796875": "F,F.T,T.T:T;TaTcTeToTs", "-1.103515625": "FAT-TwTyV-VeVoW,W.Y:YuYvr,r.w,w.", "-2.578125": "P,P.Y,Y.", "-1.8359375": "V,V.Y-YeYoYq", "-0.17578125": "Wy", "-1.298828125": "Y;", "1.11328125": "ìĩ", "-0.283203125": "τφφτ", "-0.537109375": "φχχφ", "-5": "【̀【̃【̪【͡】̀】̃】̪】͡", "-11.38671875": "🤣" }, "fontBoundingBoxAscent": 18, "fontBoundingBoxDescent": 4 } } }); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TextMeasure.js /** * best module * @constructor */ function TextMeasure() { this.$canvas = null; this.data = {}; this._loadComputedData(); // if the font is not in data, create it and copy console log to TextMeasureData.js // this._makeFontSize('Times New Roman'); // this._makeFontSize('Arial'); } TextMeasure.prototype.FONT_ARIAL = 'Arial'; TextMeasure.prototype.FONT_TIMES_NEW_ROMAN = 'Times New Roman'; TextMeasure.prototype.exportCode = function () { var obj = 'self.absol.TextMeasure'; var code = [ 'if (!self.absol) self.absol = {};', obj + ' = {};', obj+'.data = '+ JSON.stringify(this.data)+';' ]; Object.keys(this.constructor.prototype).forEach(key=>{ var val = this[key]; if (typeof val === "function") { code.push(obj+'.'+key+' = '+ val+';\n'); } else if (!(0,Dom/* isDomNode */.mV)(val)) { //todo } }) return code.join('\n'); }; TextMeasure.prototype._loadComputedData = function () { var thisO = this; this.data.chars = TextMeasureData.chars; this.data.fonts = Object.keys(TextMeasureData.fonts).reduce(function (ac, fontName) { var font = TextMeasureData.fonts[fontName]; ac[fontName] = { width: thisO._valueDict2KeyDict(font.width), spacing: thisO._valueDict2KeyDict(font.spacing, 2), fontBoundingBoxAscent: font.fontBoundingBoxAscent, fontBoundingBoxDescent: font.fontBoundingBoxDescent } return ac; }, {}); }; TextMeasure.prototype._valueDict2KeyDict = function (dict, keyLength) { var thisO = this; return Object.keys(dict).reduce(function (ac, valueText) { var keys = thisO._splitKey(dict[valueText], keyLength || 1); var value = parseFloat(valueText); keys.reduce(function (ac1, key) { ac1[key] = value; return ac1; }, ac); return ac; }, {}); }; TextMeasure.prototype._keyDic2ValueDict = function (keyDict) { return Object.keys(keyDict).reduce(function (ac, cr) { var vKey = keyDict[cr].toString(); ac[vKey] = ac[vKey] || ''; ac[vKey] += cr; return ac; }, {}); } /*** * * @param s * @param l * @returns {string[]} * @private */ TextMeasure.prototype._splitKey = function (s, l) { var cArr = s.split(''); if (!l || l < 2) return cArr; return cArr.reduce(function (ac, cr) { ac.last += cr; if (ac.last.length >= l) { ac.arr.push(ac.last); ac.last = ''; } return ac; }, { arr: [], last: '' }).arr; }; TextMeasure.prototype._array2keyDict = function (arrKey, arrVal) { return arrKey.reduce(function (ac, cr, i) { ac[cr] = arrVal[i] return ac; }, {}) }; TextMeasure.prototype._makeFontSize = function (fontName) { var thisO = this; var charList = TextMeasureData.chars; var fontMt = this.measureTextByCanvas("demo-abgH", '20px ' + fontName); var cWidthArr = charList.map(function (c) { return thisO.measureTextByCanvas(c).width; }); var width = this._array2keyDict(charList, cWidthArr); var spacing = charList.reduce(function (ac, c1, i1) { return charList.reduce(function (ac1, c2, i2) { var d = thisO.measureTextByCanvas(c1 + c2).width - cWidthArr[i1] - cWidthArr[i2]; if (d !== 0) ac1[c1 + c2] = d; return ac1; }, ac); }, {}); TextMeasureData[fontName] = { width: thisO._keyDic2ValueDict(width), spacing: thisO._keyDic2ValueDict(spacing), fontBoundingBoxAscent: fontMt.fontBoundingBoxAscent, fontBoundingBoxDescent: fontMt.fontBoundingBoxDescent }; this.data.fonts[fontName] = { width: width, spacing: spacing, fontBoundingBoxAscent: fontMt.fontBoundingBoxAscent, fontBoundingBoxDescent: fontMt.fontBoundingBoxDescent }; // copy from console and paste it to TextMeasureData // console.log(fontName+":"+JSON.stringify(this.data.fonts[fontName])); }; /*** * * @param {string} text * @param {string} fontName * @param {number} fontSize * @return {number} */ TextMeasure.prototype.measureWidth = function (text, fontName, fontSize) { var width = this.data.fonts[fontName].width; var spacing = this.data.fonts[fontName].spacing; var res = 0; var prevC = text[0]; var c = text[0]; res += width[c] || 0; for (var i = 1; i < text.length; ++i) { c = text[i]; res += spacing[prevC + c] || 0; res += width[c] || 0; prevC = c; } return res * fontSize / 20; } TextMeasure.prototype.wrapText = function (text, fontName, fontSize, maxWidth) { var width = this.data.fonts[fontName].width; var spacing = this.data.fonts[fontName].spacing; var lines = []; var currentLine = ''; var currentWidth = 0; var prevC = null; var c, charWidth, charSpacing; for (var i = 0; i < text.length; i++) { c = text[i]; charWidth = (width[c] !== undefined?width[c] : width['a']) * fontSize / 20; charSpacing = prevC ? (spacing[prevC + c] || 0) * fontSize / 20 : 0; if (currentWidth + charWidth + charSpacing > maxWidth) { // Find the last space in the current line var lastSpaceIndex = currentLine.lastIndexOf(' '); if (lastSpaceIndex !== -1) { // Break at the last space lines.push(currentLine.slice(0, lastSpaceIndex).trim()); currentLine = currentLine.slice(lastSpaceIndex + 1) + c; currentWidth = this.measureWidth(currentLine, fontName, fontSize); } else { // No spaces, break the word lines.push(currentLine.trim()); currentLine = c; currentWidth = charWidth; } } else { currentLine += c; currentWidth += charWidth + charSpacing; } prevC = c; } if (currentLine.trim()) { lines.push(currentLine.trim()); } return lines; }; /*** * * @param {string}text * @param {string=} font - without font-size, default is 20px * @returns {TextMetrics} */ TextMeasure.prototype.measureTextByCanvas = function (text, font) { if (!document || !document.createElement) throw new Error("Not support renderer!"); var canvas = this.$canvas || (this.$canvas = document.createElement("canvas")); var context = canvas.getContext("2d"); if (font) context.font = font; var metrics = context.measureText(text); return metrics; }; var instance = new TextMeasure(); /* harmony default export */ const js_TextMeasure = (instance); /***/ }), /***/ 1376: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_toast_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5822); /* harmony import */ var _css_toast_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_toast_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /* harmony import */ var _VariantColors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(8494); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(6628); /* harmony import */ var absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(257); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(863); /* harmony import */ var absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7807); /* harmony import */ var _RelativeTimeText__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(9441); var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var toastBg = { success: "#a4f3b6", info: "#67d5e7" } var toastTextColor = { success: '#454040', info: '#48433b' } ;(0,_utils__WEBPACK_IMPORTED_MODULE_4__.buildCss)(_VariantColors__WEBPACK_IMPORTED_MODULE_3__/* ["default"].keys.reduce */ .Z.keys.reduce(function (ac, cr) { var color = absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_6__/* ["default"].parse */ .Z.parse(toastBg[cr] || _VariantColors__WEBPACK_IMPORTED_MODULE_3__/* ["default"].base */ .Z.base[cr]); var textColor = color.getContrastYIQ(); var headerColor = toastTextColor[cr] || _VariantColors__WEBPACK_IMPORTED_MODULE_3__/* ["default"].mediumContract */ .Z.mediumContract[cr] || color.getHightContrastColor(); ac['.as-toast.as-variant-' + cr + ' .as-toast-variant-color'] = { 'background-color': color.toString('hex6') } ac['.as-toast.as-variant-background.as-variant-' + cr] = { 'background-color': color.toString('hex6'), color: textColor.toString('hex6') } ac['.as-toast.as-variant-background.as-variant-' + cr + ' .as-toast-header'] = { color: headerColor.toString('hex6') } return ac; }, {})); /*** * @extends {AElement} * @constructor */ function Toast() { this._state = 0; this.$closeBtn = $('.as-toast-close-btn', this) .on('click', this.disappear.bind(this)); this.$title = $('.as-toast-title', this); this.$timeText = $('.as-toast-time-text', this); this.$body = $('.toast-body', this); this.$attachhook = $('attachhook', this) .on('attached', this.appear.bind(this)); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.$title.firstChild, 'htitle', 'data'); this._message = null; this.$message = null; this.disappearTimeout = 0; this.htitle = 'Toast.htitle'; this.message = null; this.variant = null; this.addEventListener('click', (event) => { if ((0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_7__/* .hitElement */ .EY)(this.$closeBtn, event)) return; this.emit('click', event, this); }); _({ tag: _RelativeTimeText__WEBPACK_IMPORTED_MODULE_9__/* ["default"] */ .Z, elt: this.$timeText }); (0,absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_2__/* .drillProperty */ .pj)(this, this.$timeText, ['timeText', 'time']); } Toast.tag = 'toast'; ['addChild', 'removeChild', 'clearChild', 'addChildBefore', 'addChildAfter'].forEach(function (key) { Toast.prototype[key] = function () { this.$body[key].apply(this.$body, arguments); }; }); Toast.render = function () { return _({ extendEvent: ['appeared', 'disappeared', 'click'], class: ['as-toast', 'as-not-appeared'], child: [ { class: 'as-toast-header', child: [ '.as-toast-variant-color', { tag: 'strong', class: 'as-toast-title', child: { text: "Absol Js" } }, { tag: 'smal', class: 'as-toast-time-text' }, { tag: 'button', class: 'as-toast-close-btn', child: 'span.mdi.mdi-close' // child: { tag: 'span', child: { text: '×' } } } ] }, { class: 'toast-body' }, 'attachhook' ] }); }; Toast.prototype.disappear = function () { if (this._state !== 2) return; this._state = 3; this.addClass('as-disappearing'); setTimeout(function () { this.removeClass('as-disappeared') .removeClass('as-disappearing') .addClass('as-not-appeared'); this.remove(); this.emit('disappeared', { target: this, type: 'disappeared' }, this); }.bind(this), 500); }; Toast.prototype.appear = function () { if (this._state !== 0) return; this._state = 1; this.addClass('as-appearing'); setTimeout(function () { this.removeClass('as-not-appeared') .addClass('as-appeared') .removeClass('as-appearing'); this._state = 2; this.emit('appeared', { target: this, type: 'appeared' }, this); if (this.disappearTimeout > 0 && this.disappearTimeout < Infinity) { setTimeout(this.disappear.bind(this), this.disappearTimeout); } }.bind(this), 100); }; Toast.property = {}; Toast.property.variant = { set: function (value) { if (this._variant && this._variant !== value) { this.removeClass('as-variant-' + this._variant); } if (_VariantColors__WEBPACK_IMPORTED_MODULE_3__/* ["default"].has */ .Z.has(value) || (['sticky-note'].indexOf(value) >= 0)) { this._variant = value; this.addClass('as-variant-' + this._variant); } }, get: function () { return this._variant; } }; Toast.property.message = { set: function (value) { if (typeof value !== "string" || value.length === 0) { value = null; } if (value) { if (!this.$message) { this.$message = _({ class: 'as-toast-message', child: { text: '' } }); } if (!this.$message.parentElement) this.$body.addChild(this.$message); this.$message.firstChild.data = value; } else { if (this.$message && this.$message.parentElement) { this.$message.remove(); } } this._message = value; }, get: function () { return this._message; } }; Toast.$toastList = _('.as-toast-list.as-se.as-bscroller'); Toast.$toastList4Pos = { se: Toast.$toastList, sw: _('.as-toast-list.as-sw.as-bscroller'), nw: _('.as-toast-list.as-nw.as-bscroller'), ne: _('.as-toast-list.as-ne.as-bscroller'), sc: _('.as-toast-list.as-sc.as-bscroller'), }; absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_5__/* ["default"].documentReady.then */ .ZP.documentReady.then(function () { Toast.$toastList.addTo(document.body); Toast.$toastList4Pos.sw.addTo(document.body); Toast.$toastList4Pos.nw.addTo(document.body); Toast.$toastList4Pos.ne.addTo(document.body); Toast.$toastList4Pos.sc.addTo(document.body); }); /*** * * @param {AbsolConstructDescriptor|{}} aObject, * @param {"se"|"sw"|"ne"|"nw"|"sc" } [pos="se"] * @return {AElementNS|AElement|Text} */ Toast.make = function (aObject, pos) { if (!Toast.$toastList4Pos[pos]) pos = "se"; aObject = aObject || {}; if (typeof aObject !== "object") throw new Error("param must be AbsolConstructDescriptor object!"); if ((0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_5__/* .isDomNode */ .mV)(aObject)) { } else { aObject.tag = aObject.tag || 'toast'; } var toastElt = _(aObject); var toastListElt = Toast.$toastList4Pos[pos] || Toast.$toastList; toastListElt.addChild(toastElt); return toastElt; }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(Toast); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Toast); /***/ }), /***/ 5194: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "J": () => (/* binding */ updateTooltipPosition), /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_tooltip_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5071); /* harmony import */ var _css_tooltip_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_tooltip_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(863); var _ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"]._ */ .Z._; var $ = _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].$ */ .Z.$; /*** * @extends AElement * @constructor */ function ToolTip() { this.$content = $('.absol-tooltip-content', this); this.$arrow = $('.absol-tooltip-arrow', this); } ToolTip.tag = 'ToolTip'.toLowerCase(); ToolTip.render = function () { return _({ class: 'absol-tooltip', child: [ { class: 'absol-tooltip-content' }, '.absol-tooltip-arrow' ] }); }; ['addChild', 'addChildBefore', 'addChildAfter', 'clearChild'].forEach(function (key) { ToolTip.prototype[key] = function () { return this.$content[key].apply(this.$content, arguments); } }); _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(ToolTip); function updateTooltipPosition(toolTipClass) { var element = toolTipClass.$element; if (!element) return; var orientation = toolTipClass._orientation; var tBound = toolTipClass.$tooltip.$content.getBoundingClientRect(); var ebound = element.getBoundingClientRect(); var screenSize = (0,absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* .getScreenSize */ .tE)(); var sMargin = Math.round(Math.min(5, screenSize.width/100, screenSize.height)); screenSize.width = Math.min(screenSize.width, document.body.getBoundingClientRect().width); var fontSize = toolTipClass.$tooltip.getFontSize(); var dx = 0; var dy = 0; var arrowPos = null; var aHCenter = (ebound.left + ebound.width / 2 > tBound.width / 2) && (screenSize.width - ebound.left - ebound.width / 2 > tBound.width / 2); var aVCenter = (ebound.top + ebound.height / 2 > tBound.height / 2) && (screenSize.height - ebound.top - ebound.height / 2 > tBound.height / 2); var aTop = (tBound.height < ebound.top - sMargin); var aBottom = tBound.height < screenSize.height - sMargin - ebound.bottom; var aRight = tBound.width < screenSize.width - sMargin - ebound.right; var aLeft = tBound.width < ebound.left - sMargin; var aHLeft = (ebound.left + ebound.width / 2 - tBound.width / 2 < sMargin) && (ebound.left + ebound.width / 2 >= sMargin + fontSize / 2); var aHRight = (ebound.left + ebound.width / 2 + tBound.width / 2 > screenSize.width - sMargin) && (ebound.left + ebound.width / 2 < screenSize.width - sMargin - fontSize / 2); var aVTop = (ebound.top + ebound.width / 2 - tBound.height / 2 < sMargin) && (ebound.top + ebound.height / 2 >= sMargin + fontSize / 2); var aVBottom = (ebound.top + ebound.width / 2 + tBound.height / 2 <= screenSize.height - sMargin) && (ebound.top + ebound.height / 2 > screenSize.height - sMargin - fontSize / 2); if (orientation === 'auto' && aHCenter) { if (aTop) { orientation = 'top'; } else if (aBottom) { orientation = 'bottom'; } } if (orientation === 'auto' && aVCenter) { if (aRight) { orientation = 'right'; } else if (aLeft) { orientation = 'left'; } } if ((orientation === 'auto' || orientation === 'top' || orientation === 'bottom') && aHLeft) { if (aTop || orientation === 'auto') orientation = "top"; else if (aBottom || orientation === 'auto') orientation = 'bottom'; if (aTop || aBottom) { dx += tBound.width / 2 - (ebound.left + ebound.width / 2) + sMargin; arrowPos = tBound.width / 2 - dx + 'px'; } } if ((orientation === 'auto' || orientation === 'top' || orientation === 'bottom') && aHRight) { if (aTop || orientation === 'auto') orientation = "top"; else if (aBottom || orientation === 'auto') orientation = 'bottom'; if (aTop || aBottom) { dx -= tBound.width / 2 - (screenSize.width - (ebound.left + ebound.width / 2)) + sMargin; arrowPos = tBound.width / 2 - dx + 'px'; } } if ((orientation === 'auto'|| orientation === 'left' || orientation === 'right') && aVTop) { if (aLeft || orientation === 'auto') orientation = "left"; else if (aRight || orientation === 'auto') { orientation = 'right'; } if (aLeft || aRight) { dy += tBound.height / 2 - (ebound.top + ebound.height / 2) + sMargin; arrowPos = tBound.height / 2 - dy + 'px'; } } if ((orientation === 'auto'|| orientation === 'left' || orientation === 'right') && aVBottom) { if (aLeft || orientation === 'auto') orientation = "left"; else if (aRight || orientation === 'auto') { orientation = 'right'; } if (aLeft || aRight) { dy -= tBound.height / 2 - (screenSize.height - (ebound.top + ebound.height / 2)) + sMargin; arrowPos = tBound.height / 2 - dx + 'px' } } if (orientation === 'auto') { if (aRight) { if (aTop) { orientation = 'ne'; } else if (aBottom) { orientation = 'se'; } } else if (aLeft) { if (aTop) { orientation = 'nw'; } else if (aBottom) { orientation = 'sw'; } } } if (orientation === 'auto') orientation = "error"; toolTipClass.$tooltip.removeClass('top') .removeClass('left') .removeClass('right') .removeClass('bottom') .removeClass('ne') .removeClass('nw') .removeClass('se') .removeClass('sw') .addClass(orientation); tBound = toolTipClass.$tooltip.getBoundingClientRect(); if (orientation == 'top') { dy += ebound.top - tBound.height; dx += ebound.left + ebound.width / 2 - tBound.width / 2; } else if (orientation == 'left') { dy += ebound.top + ebound.height / 2 - tBound.height / 2; dx += ebound.left - tBound.width; } else if (orientation == 'right') { dy += ebound.top + ebound.height / 2 - tBound.height / 2; dx += ebound.right; } else if (orientation == 'bottom') { dy += ebound.bottom; dx += ebound.left + ebound.width / 2 - tBound.width / 2; } else if (orientation === 'ne') { dy += ebound.top - tBound.height; dx += ebound.right; } else if (orientation === 'nw') { dy += ebound.top - tBound.height; dx += ebound.left - tBound.width; } else if (orientation === 'se') { dy += ebound.bottom; dx += ebound.right; } else if (orientation === 'sw') { dy += ebound.bottom; dx += ebound.left - tBound.width; } else { throw new Error("Invalid orientation, orientation: ['left', 'right', 'top', 'bottom', 'auto', 'nw', 'ne', 'sw', 'se']"); } if (arrowPos) { toolTipClass.$tooltip.addStyle('--tool-tip-arrow-pos', arrowPos); } else { toolTipClass.$tooltip.removeStyle('--tool-tip-arrow-pos') } toolTipClass.$holder.addStyle({ top: dy + 'px', left: dx + 'px' }); } ToolTip.$holder = _('.absol-tooltip-root-holder') ToolTip.$tooltip = _('tooltip.top').addTo(ToolTip.$holder); ToolTip.$element = undefined; ToolTip.$content = undefined; ToolTip._orientation = 'top'; ToolTip._session = Math.random() * 10000000000 >> 0; ToolTip.updatePosition = function () { if (!ToolTip.$element) return; updateTooltipPosition(ToolTip); }; ToolTip.$tooltip.$arrow.updateSize = ToolTip.updatePosition.bind(ToolTip); ToolTip.show = function (element, content, orientation) { orientation = orientation || 'auto'; if (typeof content == 'string') { content = _({ tag: 'span', style: { 'white-space': 'nowrap' }, props: { innerHTML: content } }); } $('', content, function (elt) { if (elt.tagName == "IMG" && elt.src) { absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].waitImageLoaded */ .ZP.waitImageLoaded(elt).then(ToolTip.updatePosition.bind(ToolTip)); } else if (elt.sync) { elt.sync.then(ToolTip.updatePosition.bind(ToolTip)); } }); var currentSession = Math.random() * 10000000000 >> 0; ToolTip.$holder.addTo(document.body); absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].addToResizeSystem */ .ZP.addToResizeSystem(ToolTip.$tooltip.$arrow); ToolTip.$element = element; ToolTip._session = currentSession; ToolTip.$content = content; ToolTip._orientation = orientation; ToolTip.$tooltip.clearChild().addChild(content); ToolTip.$holder.removeStyle('visibility'); ToolTip.$tooltip.removeClass('top') .removeClass('left') .removeClass('right') .removeClass('bottom') .removeClass('ne') .removeClass('nw') .removeClass('auto'); ToolTip.$tooltip.addClass(orientation); ToolTip.updatePosition(); return currentSession; }; ToolTip.close = function (session) { if (session === true || session === this._session) { ToolTip.$holder.addStyle('visibility', 'hidden'); ToolTip.$tooltip.clearChild(); ToolTip.$holder.addStyle({ top: false, left: false }); } }; ToolTip.closeTooltip = ToolTip.close; ToolTip.showWhenClick = function (element, content, orientation) { var mSession = undefined; element.addEventListener('click', function () { if (mSession !== undefined) return; mSession = ToolTip.show(element, content, orientation); var finish = function (event) { if (!absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_3__/* ["default"].hitElement */ .ZP.hitElement(content, event)) { $(document.body).off('click', finish); ToolTip.closeTooltip(mSession); mSession = undefined; } }; setTimeout(function () { $(document.body).on('click', finish); }, 100) }); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ToolTip); /***/ }), /***/ 8494: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_variantcolors_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6483); /* harmony import */ var _css_variantcolors_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_variantcolors_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6628); function VariantColor() { this.keys = ['primary', 'secondary', 'success', 'info', 'warning', 'error', 'danger', 'light', 'dark', 'link', 'note']; this.base = { primary: "#007bff", secondary: "#6c757d", success: "#28a745", info: "#17a2b8", warning: "#ffc107", error: "#ff4052", danger: "#dc3545", light: "#f8f9fa", dark: "#343a40", link: "#007bff", note: '#ffff88' }; this.mediumContract = { primary: '#e2edd5', secondary: '#fca75b', success: '#fce8e8', info: '#fcf5e8', warning: '#5e5a75', error: '#e0dfce', danger: "#e5e8d5", light: '#7a5b3c', dark: "#bf7d3b", link: "#dde8c9", note: '#1e1ec8' } absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* ["default"].documentReady.then */ .ZP.documentReady.then(this.loadFromCss.bind(this)); } VariantColor.prototype.has = function (name) { return this.keys.indexOf(name) >= 0; }; VariantColor.prototype.loadFromCss = function () { this.base = this.keys.reduce(function (ac, name) { var style = window.getComputedStyle(document.body); ac[name] = style.getPropertyValue('--variant-color-' + name); return ac; }, {}); this.mediumContract = this.keys.reduce(function (ac, name) { var style = window.getComputedStyle(document.body); ac[name] = style.getPropertyValue('--variant-medium-contract-color-' + name); return ac; }, {}); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (new VariantColor()); /***/ }), /***/ 774: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3349); /** * @typedef WindowBoxAction * @property icon * @property name * */ /*** * @extends AElement * @constructor */ function WindowBox() { this.$header = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-window-box-header', this); /*** * * @type {WindowBoxAction[]} * @private */ this._windowActions = []; this.$windowActionButtonCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-window-box-header-button-ctn', this); this._windowIcon = null; this.$windowIconCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-window-box-header-icon-ctn', this); /** * * @type {Text} */ this.$windowTitleText = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-window-box-header-title', this).firstChild; this.$body = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-window-box-body', this); /*** * @type {WindowBoxAction[]} * @name windowActions */ } WindowBox.tag = 'WindowBox'.toLowerCase(); WindowBox.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ class: 'as-window-box', extendEvent: ['action'], child: [ { class: 'as-window-box-header', child: [ { class: 'as-window-box-header-icon-ctn' }, { class: 'as-window-box-header-title', child: { text: '' } }, { class: "as-window-box-header-button-ctn" } ] }, { class: 'as-window-box-body' } ] }); }; ['addChild', 'addChildBefore', 'addChildAfter', 'clearChild', 'findChildBefore', 'findChildAfter'].forEach(function (key) { WindowBox.prototype[key] = function () { return this.$body[key].apply(this.$body, arguments); }; }); WindowBox.property = {}; WindowBox.property.windowTitle = { set: function (value) { this.$windowTitleText.data = (value || '') + ''; }, get: function () { return this.$windowTitleText.data; }, enumerable: true }; WindowBox.property.windowIcon = { /*** * @this WindowBox * @param value */ set: function (value) { value = value || null; this.$windowIconCtn.clearChild(); if (value) { this.$windowIconCtn.addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)(value)); } this._windowIcon = value; }, get: function () { return this._windowIcon; }, enumerable: true }; WindowBox.property.windowActions = { set: function (actions) { var self = this; this._windowActions = actions || []; this.$windowActionButtonCtn.clearChild(); var buttons = this._windowActions.map(function (action) { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: 'button', class: action.class || [], child: action.icon, on: { click: function (event) { var eventData = { type: 'action', target: self, action: action, originalEvent: event }; absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_1__/* ["default"].drillProperty */ .ZP.drillProperty(eventData, eventData, 'actionData', 'action'); self.emit('action', eventData, self); } } }); }); this.$windowActionButtonCtn.addChild(buttons); }, get: function () { return this._windowActions; } }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(WindowBox); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (WindowBox); /***/ }), /***/ 5466: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var _css_messagedialog_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3163); /* harmony import */ var _css_messagedialog_css__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_css_messagedialog_css__WEBPACK_IMPORTED_MODULE_1__); /* harmony import */ var _MessageDialog__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3488); /*** * @extends MessageDialog * @constructor */ function YesNoQuestionDialog() { this.dialogActions = [ { class: 'secondary', text: 'No', name: 'no', }, { class: 'primary', text: 'Yes', name: 'yes' } ]; this.$yesBtn = this.$actionBtns[1]; this.$noBtn = this.$actionBtns[0]; this.$message = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)('.as-message-dialog-message', this); /*{ class: 'as-message-dialog-footer', child: [ { tag: FlexiconButton.tag, class: ['as-message-dialog-no-btn', 'secondary'], props: { text: 'No' } }, { tag: FlexiconButton.tag, class: ['as-message-dialog-yes-btn', 'primary'], props: { text: 'Yes' } } ] }*/ } YesNoQuestionDialog.tag = 'YesNoQuestionDialog'.toLowerCase(); YesNoQuestionDialog.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: _MessageDialog__WEBPACK_IMPORTED_MODULE_2__/* ["default"].tag */ .Z.tag, child: [ { tag: 'span', class: 'as-message-dialog-message', child: { text: '' } } ] }); }; YesNoQuestionDialog.eventHandler = {}; YesNoQuestionDialog.property = {}; YesNoQuestionDialog.property.message = { set: function (value) { value = (value || '') + ''; this.$message.firstChild.data = value; }, get: function () { return this.$message.firstChild.data; } }; YesNoQuestionDialog.property.textYes = { set: function (value) { value = (value || 'Yes') + ''; this.$yesBtn.text = value; this.dialogActions[1].text = value; }, get: function () { return this.$yesBtn.text; } }; YesNoQuestionDialog.property.textNo = { set: function (value) { value = (value || 'No') + ''; this.$noBtn.text = value; this.dialogActions[0].text = value; }, get: function () { return this.$noBtn.text; } }; _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"].install */ .Z.install(YesNoQuestionDialog); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (YesNoQuestionDialog); /***/ }), /***/ 5830: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "cF": () => (/* binding */ DEFAULT_CHART_COLOR_SCHEMES), /* harmony export */ "TD": () => (/* binding */ generatorColorScheme), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3349); /* harmony import */ var _Follower__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7094); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3855); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(863); /* harmony import */ var absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(257); /* harmony import */ var absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7988); var DEFAULT_CHART_COLOR_SCHEMES = [ ['#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252'],//gray scale ['#a50026', '#f46d43', '#fee08b', '#d9ef8b', '#66bd63', '#006837'], ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f'], ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02'], ['#a6cee3', '#b2df8a', '#fb9a99', '#fdbf6f', '#cab2d6', '#ffff99'], ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae'], ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33'], ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f'], ['#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02'], ['#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3'], ['#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5'], ['#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45'], ['#7f3b08', '#e08214', '#fee0b6', '#d8daeb', '#8073ac', '#2d004b'], ['#543005', '#bf812d', '#f6e8c3', '#c7eae5', '#35978f', '#003c30'], ['#40004b', '#9970ab', '#e7d4e8', '#d9f0d3', '#5aae61', '#00441b'], ['#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443'], ['#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45'], ['#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0'], ['#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e'], ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a'] ]; var DEFAULT_CHART_COLOR_SCHEMES_OBJS = DEFAULT_CHART_COLOR_SCHEMES.map(scm => scm.map(c => absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_5__/* ["default"].parse */ .Z.parse(c))); absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_5__/* ["default"].DEFAULT_CHART_COLOR_SCHEMES */ .Z.DEFAULT_CHART_COLOR_SCHEMES = DEFAULT_CHART_COLOR_SCHEMES; var ColorSchemeGenerators = {}; var scaleArray = (arr, newN) => Array(newN).fill(0).map((u, i) => { var k = i * (arr.length - 1) / (newN - 1); var l = Math.floor(k); var h = Math.ceil(k); if (l === h) return arr[l]; return (0,absol_src_Math_int__WEBPACK_IMPORTED_MODULE_6__.map)(k, l, h, arr[l], arr[h]); }) var generatorColorScheme = (id, n) => { var hsl6 = DEFAULT_CHART_COLOR_SCHEMES_OBJS[id].map(c => c.toHSLA()); var h6 = hsl6.map(c => c[0]); var s6 = hsl6.map(c => c[1]); var l, h, s; if ((id >= 1 && id <= 7)|| id === 12 || id ===13) { if (n > 6) { s = s6.concat(Array(n - 6).fill(0).map((u, i) => 0.6 + (3 * i * 0.3) % 0.35)); } } if (id === 1) { h6[0] -= 1; } else if (id === 2) { if (n > 6) { s = s6.concat(Array(n - 6).fill(0).map((u, i) => 0.5 + (3 * i * 0.3) % 0.45)); } } else if (id === 18 && n !== 6) { h6[0] = 1; h6[1] = 1; } s = s || scaleArray(s6, n); l = l || scaleArray(hsl6.map(c => c[2]), n); h = h || scaleArray(h6, n).map(h => h < 0 ? h + 1 : h); return Array(n).fill(0).map((u, i) => absol_src_Color_Color__WEBPACK_IMPORTED_MODULE_5__/* ["default"].fromHSL */ .Z.fromHSL(h[i], s[i], l[i])); }; // DEFAULT_CHART_COLOR_SCHEMES = Array(20).fill(0).map((u, id) => colorSchemeGenerator(id, 20).map(c => c.toString('hex6'))) // console.log(DEFAULT_CHART_COLOR_SCHEMES) /** * @extends AElement * @constructor */ function SelectColorSchemeMenu() { this.dropdown = new SCSMDropdown(this); this.comboboxCtrl = new SCSMComboBoxController(this); absol_src_HTML5_OOP__WEBPACK_IMPORTED_MODULE_0__/* ["default"].drillProperty */ .ZP.drillProperty(this, this.dropdown, ['value', 'items', 'selectedItem']); this.dropdown.items = DEFAULT_CHART_COLOR_SCHEMES.map((it, i) => ({ colors: it, value: i })); } SelectColorSchemeMenu.tag = 'SelectColorSchemeMenu'.toLowerCase(); SelectColorSchemeMenu.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ class: ['as-select-color-scheme-menu', 'absol-selectmenu'], extendEvent: ['change'], child: [ '.as-select-color-scheme-menu-selected-item', { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] }, ] }); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SelectColorSchemeMenu); /** * * @param {SelectColorSchemeMenu} elt * @constructor */ function SCSMDropdown(elt) { this.elt = elt; this._items = []; this.itemDict = {}; this.$itemDict = {}; this.$follower = (0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ tag: _Follower__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, class: ['as-select-color-scheme-menu-dropdown', 'as-dropdown-box-common-style'], child: {} }); this.$follower.cancelWaiting(); } SCSMDropdown.prototype.updateItems = function () { var items = this._items; var maxColorLength = items.reduce((ac, cr) => Math.max(ac, cr.colors.length), 0); var itRow = Math.max(1, Math.floor(Math.sqrt(maxColorLength))); while (itRow > 1 && (maxColorLength % itRow)) itRow--; var itCol = maxColorLength / itRow; var gridRow = Math.max(1, Math.ceil(Math.sqrt(items.length))); while (gridRow < items.length && (items.length % gridRow)) gridRow++; var gridCol = Math.ceil(items.length / gridRow); this.$follower.clearChild(); this.$selected = null; this.$itemDict = {}; items.forEach((item, i) => { if (i % gridCol === 0) { this.$follower.addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)('.as-scsm-item-list-row')); } var itemElt = (0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ class: ['as-scsm-item'] }); var wrapper = (0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ class: 'as-scsm-item-wrapper', child: itemElt, on: { click: (event) => { var cValue = this.value; if (cValue !== item.value) { this.value = item.value; this.elt.emit('change', { type: 'change', target: this.elt }, this.elt) } } } }) this.$itemDict[(0,_utils__WEBPACK_IMPORTED_MODULE_3__.keyStringOf)(item.value)] = itemElt; this.$follower.lastChild.addChild(wrapper); item.colors.forEach((color, j) => { if (j % itCol === 0) { itemElt.addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)('.as-scsm-item-row')); } itemElt.lastChild.addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ class: 'as-scsm-item-cell', style: { backgroundColor: color } })); }); }); }; SCSMDropdown.prototype.updateSelected = function () { var value = this.value; if (this.$selected) this.$selected.removeClass('as-selected'); this.$selected = this.$itemDict[(0,_utils__WEBPACK_IMPORTED_MODULE_3__.keyStringOf)(value)]; if (this.$selected) this.$selected.addClass('as-selected'); this.elt.comboboxCtrl.update(); }; Object.defineProperty(SCSMDropdown.prototype, 'items', { set: function (items) { if (!(items instanceof Array)) items = []; this._items = items; this.itemDict = items.reduce((ac, cr) => { ac[(0,_utils__WEBPACK_IMPORTED_MODULE_3__.keyStringOf)(cr.value)] = cr; return ac; }, {}); this.updateItems(); this.updateSelected(); }, get: function () { return this._items; } }); Object.defineProperty(SCSMDropdown.prototype, 'value', { set: function (value) { this._value = value; this.updateSelected(); }, get: function () { if (this.itemDict[(0,_utils__WEBPACK_IMPORTED_MODULE_3__.keyStringOf)(this._value)] || this._items.length === 0) return this._value; return this._items[0].value; } }); Object.defineProperty(SCSMDropdown.prototype, 'selectedItem', { get: function () { return this.itemDict[(0,_utils__WEBPACK_IMPORTED_MODULE_3__.keyStringOf)(this.value)]; } }); /** * * @param {SelectColorSchemeMenu} elt * @constructor */ function SCSMComboBoxController(elt) { this.elt = elt; this.$selected = (0,_ACore__WEBPACK_IMPORTED_MODULE_2__.$)('.as-select-color-scheme-menu-selected-item', this.elt); this.ev_click = this.ev_click.bind(this); this.ev_clickOut = this.ev_clickOut.bind(this); this.elt.on('click', this.ev_click) } SCSMComboBoxController.prototype.ev_click = function (event) { this.isFocus = true; }; SCSMComboBoxController.prototype.ev_clickOut = function (event) { this.isFocus = false; }; SCSMComboBoxController.prototype.update = function () { var selectedItem = this.elt.dropdown.selectedItem; this.$selected.clearChild(); if (!selectedItem) return; this.$selected.addChild(selectedItem.colors.map(color => (0,_ACore__WEBPACK_IMPORTED_MODULE_2__._)({ class: 'as-scsm-item-cell', style: { backgroundColor: color } }))) }; Object.defineProperty(SCSMComboBoxController.prototype, 'isFocus', { set: function (value) { if (!!value === this.elt.hasClass('as-focus')) return; if (value) { this.elt.addClass('as-focus'); } else { this.elt.removeClass('as-focus'); } if (value) { this.elt.off('click', this.ev_click); setTimeout(() => { document.addEventListener('click', this.ev_clickOut); }, 10); this.elt.dropdown.$follower.addTo(document.body); this.elt.dropdown.$follower.followTarget = this.elt; } else { this.elt.on('click', this.ev_click); document.removeEventListener('click', this.ev_clickOut); this.elt.dropdown.$follower.selfRemove(); this.elt.dropdown.$follower.followTarget = null; } }, get: function () { return this.elt.hasClass('as-focus'); } }); /***/ }), /***/ 6369: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ dom_install) }); // UNUSED EXPORTS: publicCreators // EXTERNAL MODULE: ./node_modules/absol-acomp/css/autocompleteinput.css var autocompleteinput = __webpack_require__(2317); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/adapter/SearchStringArrayAdapter.js /** * @typedef {Object} SearchArrayAdapterOption * @property {function} searchFuntion * * * * @param {Array<String>} arr * @param {SearchArrayAdapterOption} options not implement yet */ function SearchStringArrayAdapter(texts, options) { if (!this.queryItems) return new SearchStringArrayAdapter(texts, options); this.texts = texts; } SearchStringArrayAdapter.prototype.queryItems = function (query, mInput) { var query = query.toLocaleLowerCase(); return this.texts.map(function (text) { var start = text.toLocaleLowerCase().indexOf(query); if (start >= 0) { var hightlightedText = text.substr(0, start) + '<strong style="color:red">' + text.substr(start, query.length) + '</strong>' + text.substr(start + query.length); return { text: text, hightlightedText: hightlightedText } } else return null; }).filter(function (it) { return it !== null; }) }; SearchStringArrayAdapter.onAttached = function(parent){ this.parent = parent; }; SearchStringArrayAdapter.prototype.getItemText = function (item, mInput) { return item.text; }; SearchStringArrayAdapter.prototype.getItemView = function (item, index, _, $, query, reuseItem, refParent, mInput) { if (reuseItem) { reuseItem.childNodes[0].innerHTML = item.hightlightedText; return reuseItem; } else return _({ tag: 'div', child: { tag: 'span', class: 'absol-autocomplete-input-item-text', props: { innerHTML: item.hightlightedText } } }) } /* harmony default export */ const adapter_SearchStringArrayAdapter = (SearchStringArrayAdapter); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/adapter/SearchObjectArrayAdapter.js /** * @typedef {Object} SearchObjectArrayAdapter * @property {function} getItemText * * * * @param {Array<Object>} arr * @param {SearchArrayAdapterOption} options */ function SearchObjectArrayAdapter(objects, options) { if (!this.queryItems) return new SearchObjectArrayAdapter(texts, options); this.objects = objects; this.options = options; } SearchObjectArrayAdapter.prototype.queryItems = function (query, mInput) { var query = query.toLocaleLowerCase(); return this.objects.map(function (object) { var text = this.getItemText(object); var start = text.toLocaleLowerCase().indexOf(query); if (start >= 0) { var hightlightedText = text.substr(0, start) + '<strong style="color:red">' + text.substr(start, query.length) + '</strong>' + text.substr(start + query.length); return Object.assign(object, { __hightlightedText__: hightlightedText }); } else return null; }.bind(this)).filter(function (it) { return it !== null; }) }; SearchObjectArrayAdapter.prototype.onAttached = function (parent) { this.parent = parent; parent.getSelectedObject = function () { if (this._selectedIndex >= 0) { return this.$poolItems[this._selectedIndex]._holderItem; } else { return null; } } }; SearchObjectArrayAdapter.prototype.getItemText = function (item, mInput) { if (this.options && this.options.getItemText) return this.options.getItemText.call(this, item, mInput); else if (typeof item.text == 'string') { return item.text; } else return item.toString(); }; SearchObjectArrayAdapter.prototype.getItemView = function (item, index, _, $, query, reuseItem, refParent, mInput) { if (reuseItem) { reuseItem.childNodes[0].innerHTML = item.__hightlightedText__; return reuseItem; } else return _({ tag: 'div', child: { tag: 'span', props: { innerHTML: item.__hightlightedText__ } } }) } /* harmony default export */ const adapter_SearchObjectArrayAdapter = (SearchObjectArrayAdapter); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/EventEmitter.js var EventEmitter = __webpack_require__(863); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/AutoCompleteInput.js var _ = ACore/* default._ */.Z._; var AutoCompleteInput_$ = ACore/* default.$ */.Z.$; /*** * * @extends {AElement} * @constructor */ function AutoCompleteInput() { this.$input = AutoCompleteInput_$('input', this) .on('keyup', this.eventHandler.keyup) .on('keydown', this.eventHandler.keydown) .on('focus', this.eventHandler.focus) .on('blur', this.eventHandler.blur); this.$dropdown = AutoCompleteInput_$('.absol-autocomplete-input-dropdown', this); this.$vscroller = AutoCompleteInput_$('bscroller', this).on('click', this.eventHandler.vscrollerClick); this.$poolItems = []; this._currentData = []; this._sessionIndex = 0; this._updatedSession = -1; this._cache = {}; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, 'value'); } AutoCompleteInput.tag = 'AutoCompleteInput'.toLowerCase(); AutoCompleteInput.render = function () { return _({ extendEvent: 'change', class: 'absol-autocomplete-input', child: [ 'input[type="text"].absol-autocomplete-input-text', { class: 'absol-autocomplete-input-dropdown', style: { display: 'none' }, child: { tag: 'bscroller', style: { 'max-height': '500px' } } } ] }); }; AutoCompleteInput.eventHandler = {}; AutoCompleteInput.eventHandler.keyup = function (event) { if (this._keyTimeout) { clearTimeout(this._keyTimeout); this._keyTimeout = 0; } var cTimeout = setTimeout(function () { clearTimeout(cTimeout); this.find(); }.bind(this), 300); if (this._cacheTimeout) { clearTimeout(this._cacheTimeout); this._cacheTimeout = 0; } var cacheTimeout = setTimeout(function () { clearTimeout(cacheTimeout); this.clearCache(); }.bind(this), 300); this._cacheTimeout = cacheTimeout; this._keyTimeout = cTimeout; }; AutoCompleteInput.eventHandler.blur = function () { if (!this.hasClass('focus')) return; this.removeClass('focus'); AutoCompleteInput_$(document.body).off('mousedown', this.eventHandler.clickOut); }; AutoCompleteInput.eventHandler.focus = function () { if (this.hasClass('focus')) return; this.addClass('focus'); AutoCompleteInput_$(document.body).on('mousedown', this.eventHandler.clickOut); } AutoCompleteInput.eventHandler.clickOut = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this, event)) return; AutoCompleteInput_$(document.body).off('mousedown', this.eventHandler.clickOut); var text = this.$input.value; if (this._lastValue != text) { this._lastValue = text; this.$dropdown.addStyle('display', 'none'); this._lastValue = text; this.emit('change', { target: this, value: text }, this); } } AutoCompleteInput.eventHandler.vscrollerClick = function (event) { var current = event.target; while (current && current.hasClass && !current.hasClass('absol-autocomplete-input-item') && current != this.$vscroller) { current = current.parentElement; } if (current && current._holderItem) { var text = this.getItemText(current._holderItem); this.$input.value = text; this._lastQuery = text; this._selectedIndex = current._holderIndex; this.$dropdown.addStyle('display', 'none'); this._lastValue = text; this.emit('change', { target: this, value: text }, this); } }; AutoCompleteInput.eventHandler.keydown = function (event) { var key = event.key; if (key === 'ArrowDown') { if (this._selectedIndex + 1 < this._currentData.length) { if (this.$poolItems[this._selectedIndex]) { this.$poolItems[this._selectedIndex].removeClass('active'); } this._selectedIndex += 1; if (this.$poolItems[this._selectedIndex]) { this.$poolItems[this._selectedIndex].addClass('active'); this.$vscroller.scrollInto(this.$poolItems[this._selectedIndex]); } } event.preventDefault(); } else if (key === 'ArrowUp') { if (this._selectedIndex - 1 >= 0) { if (this.$poolItems[this._selectedIndex]) { this.$poolItems[this._selectedIndex].removeClass('active'); } this._selectedIndex -= 1; if (this.$poolItems[this._selectedIndex]) { this.$poolItems[this._selectedIndex].addClass('active'); this.$vscroller.scrollInto(this.$poolItems[this._selectedIndex]); } } event.preventDefault(); } else if (key === 'Enter') { var text; if (this._currentData[this._selectedIndex] === undefined) { text = this.$input.value; } else { text = this.getItemText(this._currentData[this._selectedIndex]); this.$input.value = text; } this._lastQuery = text; this.$dropdown.addStyle('display', 'none'); this._lastValue = text; this.emit('change', { target: this, value: text }, this); } }; AutoCompleteInput.prototype.focus = function () { if (this.disabled) return; this.$input.focus.apply(this.$input, arguments); }; AutoCompleteInput.prototype.blur = function () { this.$input.blur.apply(this.$input, arguments); }; AutoCompleteInput.prototype.select = function () { this.$input.select.apply(this.$input, arguments); } AutoCompleteInput.prototype.find = function () { var query = this.$input.value; if (query == this._lastQuery) return; this._lastQuery = query; var currentSession = ++this._sessionIndex; if (!query) { this.pushData([], currentSession, query) return; } if (this.disableCache) { var onReciveData = function (data) { cacheHolder.data = data; this.pushData(data, currentSession, query);//sessionIndex may be change }.bind(this); var result = this.queryItems(query); if (typeof result.then == 'function') result.then(onReciveData); else onReciveData(result) } else { if (this._cache[query]) { this._cache[query].sessionIndex = currentSession; if (!this._cache[query].pending) { var data = this._cache[query].data; this.pushData(data, currentSession); } } else { var cacheHolder = { pending: true, sessionIndex: currentSession }; var onReciveData = function (data) { cacheHolder.data = data; cacheHolder.pending = false; this.pushData(data, cacheHolder.sessionIndex, query);//sessionIndex may be change }.bind(this); var result = this.queryItems(query); if (typeof result.then == 'function') result.then(onReciveData); else onReciveData(result) this._cache[query] = cacheHolder; } } }; AutoCompleteInput.prototype.pushData = function (data, sessionIndex, query) { if (sessionIndex > this._updatedSession) { this._updatedSession = sessionIndex; this.$vscroller.clearChild(); this._currentData = data; if (data && data.length > 0) { this.$dropdown.removeStyle('display'); } else { this.$dropdown.addStyle('display', 'none'); } var maxHeight = this.getComputedStyleValue('max-height'); if (maxHeight == 'none' || !maxHeight) { maxHeight = 10000; } else { maxHeight = parseFloat(maxHeight.replace('px', '')); } var outBound = Dom/* default.traceOutBoundingClientRect */.ZP.traceOutBoundingClientRect(this); var bound = this.$input.getBoundingClientRect(); var aTop = bound.top - outBound.top; var aBotom = outBound.bottom - bound.bottom; this.$dropdown.removeClass('top'); if (aTop > aBotom) { maxHeight = Math.min(maxHeight, aTop - 10); } else { maxHeight = Math.min(maxHeight, aBotom - 10); } this.$vscroller.addStyle('max-height', maxHeight + 'px'); this._selectedIndex = -1; data.reduce(function (sync, item, i, arr) { return sync.then(function () { if (this._updatedSession != sessionIndex) return; return new Promise(function (rs) { if (this._updatedSession != sessionIndex) return; var reuseItem = this.$poolItems.length > i ? this.$poolItems[i] : undefined; if (reuseItem) { reuseItem.removeClass('active'); } var newView = this.getItemView(item, i, _, AutoCompleteInput_$, query, reuseItem, this); newView.addClass('absol-autocomplete-input-item'); newView._holderItem = item; newView._holderIndex = i; if (i == this._selectedIndex) newView.addClass('active'); if (this.$poolItems.length <= i) { this.$poolItems.push(newView); } else { this.$poolItems[i] = newView; } this.$vscroller.addChild(newView); if (i == 0) { var estimateHeight = newView.getBoundingClientRect().height * arr.length; if (aTop > aBotom && estimateHeight > aBotom) { this.$dropdown.addClass('top'); } } if (i >= 50 && i % 50 == 0) setTimeout(rs, 0); else rs(); }.bind(this)); }.bind(this)) }.bind(this), Promise.resolve()); } }; AutoCompleteInput.prototype.getItemText = function (item) { if (this.adapter && this.adapter.getItemText) { return this.adapter.getItemText(item, this); } else if (typeof item == 'string') { return item; } else { throw Error('You need adapter.getItemText(item, mAutoCompleteInput) to handle your item text!'); } } AutoCompleteInput.prototype.getItemView = function (item, index, _, $, query, reuseItem, refParent) { if (this.adapter && this.adapter.getItemView) { return this.adapter.getItemView(item, index, _, $, query, reuseItem, refParent, this); } else { var text = this.getItemText(item); if (reuseItem) { reuseItem.childNodes[0].innerHTML = text; return reuseItem; } return _({ child: { tag: 'span', class: 'absol-autocomplete-input-item-text', child: { text: text } } }); } }; /** * @param {String} query * @returns {Array} */ AutoCompleteInput.prototype.queryItems = function (query) { if (this.adapter && this.adapter.queryItems) { return this.adapter.queryItems(query, this); } else { throw new Error('Invalid adapter: queryItems(query, mAutoCompleteInput) not found!'); } }; AutoCompleteInput.prototype.clearCache = function (old) { if (typeof old != "number") old = 30; for (var key in this._cache) { var cacheHolder = this._cache[key]; if (this._sessionIndex - cacheHolder.sessionIndex > old) { delete this._cache[key]; } } } AutoCompleteInput.property = {}; AutoCompleteInput.property.adapter = { set: function (value) { if (value instanceof Array) { if (value[0] == 'SearchStringArray') { this._adapter = new adapter_SearchStringArrayAdapter(value[1], value[2]); } else if (value[0] == 'SearchObjectArray') { this._adapter = new adapter_SearchObjectArrayAdapter(value[1], value[2]); } else { throw new Error("Unknown adapter type name"); } } else { this._adapter = value; } if (this.adapter && this.adapter.onAttached) { this.adapter.onAttached(this); } }, get: function () { return this._adapter; } }; AutoCompleteInput.property.selectedItem = { get: function (){ return ( this._currentData && this._currentData[this._selectedIndex]) || null; } }; AutoCompleteInput.property.disabled = { set: function (value) { if (value) { this.addClass('absol-disabled'); } else { this.removeClass('absol-disabled'); } }, get: function () { return this.hasClass('absol-disabled'); } }; AutoCompleteInput.attribute = {}; AutoCompleteInput.attribute.disabled = { set: function (value) { if (value === true || value === 'true' || value === null) { this.disabled = true; } else { this.disabled = false; } }, get: function () { return this.disabled ? 'true' : 'false' }, remove: function () { this.disabled = false; } }; ACore/* default.install */.Z.install( AutoCompleteInput); /* harmony default export */ const js_AutoCompleteInput = (AutoCompleteInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/BoardTable.js var BoardTable = __webpack_require__(7548); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Board.js var Board = __webpack_require__(7537); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/bscroller.css var bscroller = __webpack_require__(3283); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Element.js var Element = __webpack_require__(1487); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/BScroller.js var BScroller_ = ACore/* default._ */.Z._; var BScroller_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function BScroller() { this.addClass('as-bscroller'); } BScroller.tag = "bscroller"; BScroller.render = function (data) { if (data && data.elt) { return BScroller_$(data.elt) } else return BScroller_('div'); }; BScroller.prototype.scrollInto = function (element) { if (Element/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(element, this)) { var elementBound = element.getBoundingClientRect(); var viewportBound = this.getBoundingClientRect(); var currentScrollTop = this.scrollTop; var newScrollTop = currentScrollTop; if (elementBound.bottom > viewportBound.bottom) { newScrollTop = currentScrollTop + (elementBound.bottom - viewportBound.bottom); } if (elementBound.top < viewportBound.top) { newScrollTop = currentScrollTop - (viewportBound.top - elementBound.top); } if (newScrollTop != currentScrollTop) { this.scrollTop = newScrollTop; } var currentScrollLeft = this.scrollLeft; var newScrollLeft = currentScrollLeft; if (elementBound.right > viewportBound.right) { newScrollLeft = currentScrollLeft + (elementBound.right - viewportBound.right); } if (elementBound.left < viewportBound.left) { newScrollLeft = currentScrollLeft - (viewportBound.left - elementBound.left); } if (newScrollLeft != currentScrollLeft) { this.scrollLeft = newScrollLeft; } } } ACore/* default.install */.Z.install(BScroller); /* harmony default export */ const js_BScroller = (BScroller); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/buttonarray.css var buttonarray = __webpack_require__(439); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElement.js var AElement = __webpack_require__(7951); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ButtonArray.js var ButtonArray_ = ACore/* default._ */.Z._; var ButtonArray_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function ButtonArray() { this._dict = {}; this._pool = []; this._items = []; this.$lastActiveBtn = null; this._value = undefined; this._lastValue = this._value; } ButtonArray.tag = 'buttonarray'; ButtonArray.render = function () { return ButtonArray_({ extendEvent: ['change'], class: 'as-button-array' }); }; ButtonArray.prototype._newButton = function () { var button = ButtonArray_({ tag: 'button', class: 'as-button-array-item', child: { text: 'null' } }); button.on('click', this.eventHandler.clickItem.bind(this, button)); return button; }; ButtonArray.prototype._requestButton = function (items) { var button; if (this._pool.length > 0) { button = this._pool.pop(); } else { button = this._newButton(); } return button; }; ButtonArray.prototype._assignButton = function (button, data) { button._data = data; button.childNodes[0].data = data.text; }; ButtonArray.prototype._releaseButton = function (button) { this._pool.push(button); }; ButtonArray.prototype._getFullFormat = function (item) { var res = {}; if ((typeof item == 'string') || (typeof item == 'number') || (typeof item == 'boolean') || (item === null) || (item === undefined)) { res.ident = item; res.value = item; res.text = item + ''; } else if (item && (typeof item == 'object')) { res.value = item.value; res.ident = res.value + ''; res.text = item.text; } return res; }; ButtonArray.property = {}; /** * @type {ButtonArray} */ ButtonArray.property.items = { set: function (items) { items = items || []; this._items = items; var child; while (this.childNodes.length > items.length) { child = this.lastChild; this._releaseButton(child); this.removeChild(child); } while (this.childNodes.length < items.length) { this.addChild(this._requestButton()); } var item; for (var i = 0; i < items.length; ++i) { item = this._getFullFormat(items[i]); this._assignButton(this.childNodes[i], item); this._dict[item.ident] = { elt: this.childNodes[i], data: item } } if (items.length > 0) { if (!this._dict[this._value + '']) { this._value = this._getFullFormat(items[0]).value; } } this.value = this._value; }, get: function () { return this._items; } }; ButtonArray.property.value = { set: function (value) { this._value = value; this._lastValue = this._value; if (this.$lastActiveBtn) { this.$lastActiveBtn.removeClass('as-active'); this.$lastActiveBtn = null; } var hodler = this._dict[value + '']; if (hodler) { hodler.elt.addClass('as-active'); this.$lastActiveBtn = hodler.elt; } }, get: function () { return this._value; } }; ButtonArray.eventHandler = {}; ButtonArray.eventHandler.clickItem = function (item, event) { if (this._lastValue != item._data.value) { this.value = item._data.value; this.emit('change', { target: this, value: this.value, type: 'change' }, this); } }; ACore/* default.install */.Z.install(ButtonArray); /* harmony default export */ const js_ButtonArray = (ButtonArray); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/calendarinput.css var calendarinput = __webpack_require__(3623); // EXTERNAL MODULE: ./node_modules/absol/src/Time/datetime.js var datetime = __webpack_require__(7807); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ChromeCalendar.js var ChromeCalendar = __webpack_require__(4845); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CalendarInput.js var CalendarInput_ = ACore/* default._ */.Z._; var CalendarInput_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function CalendarInput() { var thisCI = this; this.$input = CalendarInput_$('input', this); this._value = null; this._quickOption = ChromeCalendar/* default.showWhenClick */.Z.showWhenClick(this, { minLimitDate: this.minLimitDate || this.minDateLimit, maxLimitDate: this.maxLimitDate || this.maxDateLimit, selectedDates: [new Date()] }, 'auto', function (value) { thisCI._value = value; thisCI.$input.value = thisCI.formatDateString(value); thisCI._quickOption.opt.selectedDates = [value];//change new option thisCI.emit('change', { target: thisCI, value: value }, thisCI); }); OOP/* default.drillProperty */.ZP.drillProperty(this, this._quickOption.opt, { minLimitDate: 'minLimitDate', maxLimitDate: 'maxLimitDate', minDateLimit: 'minLimitDate', maxDateLimit: 'maxLimitDate' }); } CalendarInput.tag = 'CalendarInput'.toLowerCase(); CalendarInput.render = function () { return CalendarInput_({ extendEvent: ['change'], class: 'absol-calendar-input', child: 'input[type="text"][readonly="true"][value="dd/mm/yyyy"]' }); }; CalendarInput.property = {}; CalendarInput.property.value = { set: function (value) { if (value === null || value === undefined) { this.$input.value = this.formatDateString(value); this._quickOption.opt.selectedDates = []; this._value = value; this._quickOption.opt.selectedDates = [new Date()] } else { if (typeof value == 'number') value = new Date(value); this._value = value; this.$input.value = this.formatDateString(value); this._quickOption.opt.selectedDates = [value]; } }, get: function () { return this._value; } }; CalendarInput.property.disabled = { set: function (value) { this.$input.disabled = !!value; if (value) { this.addClass('absol-disabled'); } else { this.removeClass('absol-disabled'); } }, get: function () { return this.$input.disabled; } }; CalendarInput.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; CalendarInput.attribute = { disabled: { set: function (value) { this.$input.attr('disabled', value); if (this.$input.disabled) this.addClass('absol-disabled'); }, get: function () { return this.$input.attr('disabled'); }, remove: function () { this.$input.attr('disabled', undefined); this.removeClass('absol-disabled'); } } }; CalendarInput.property.dateToString = { set: function (value) { this._dateToString = value; this.$input.value = this.formatDateString(this.value); }, get: function () { return this._dateToString; } }; CalendarInput.prototype.formatDateString = function (date) { if (!date) { return { 'undefined': 'dd/mm/yyyy', 'function': '--/--/--', 'object': 'dd/mm/yyyy', 'string': typeof this.dateToString }[typeof this.dateToString] || '--/--/--'; } if (!this.dateToString) { return (0,datetime.formatDateString)(date); } else if (typeof this.dateToString == 'string') { return (0,datetime.formatDateString)(date, this.dateToString); } else if (typeof this.dateToString == 'function') { return this.dateToString(date); } }; ACore/* default.install */.Z.install(CalendarInput); function OldCalendarInput() { } OldCalendarInput.tag = 'calendar-input'; OldCalendarInput.render = function (data) { return CalendarInput_({ tag: 'calendarinput', extendEvent: 'changed', props: data, on: { change: function (ev) { this.emit('changed', ev.value); } } }); }; ACore/* default.install */.Z.install(OldCalendarInput); /* harmony default export */ const js_CalendarInput = (CalendarInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/CheckBoxInput.js var CheckBoxInput = __webpack_require__(1728); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/checkbox.css var css_checkbox = __webpack_require__(1239); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckBox.js var CheckBox_ = ACore/* default._ */.Z._; var CheckBox_$ = ACore/* default.$ */.Z.$; var $$ = ACore/* default.$$ */.Z.$$; /*** * @extends AElement * @constructor */ function CheckBox() { this.defineEvent('change'); /*** * * @type {CheckboxInput} */ this.$input = CheckBox_$('checkboxinput', this).on('change', this.notifyChange.bind(this) ); this.$labels = $$('span', this); this.on('click', this.eventHandler.click); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, ['checked']); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, ['minus']); /*** * @type {boolean} * @name checked * @memberOf CheckBox# */ /*** * @type {boolean} * @name minus * @memberOf CheckBox# */ } CheckBox.tag = 'checkbox'; CheckBox.render = function () { return CheckBox_({ class: ['absol-checkbox', 'as-no-label'], child: [ { tag: 'span', class: ['absol-checkbox-label', 'as-left'], child: { text: '' } }, 'checkboxinput', { tag: 'span', class: ['absol-checkbox-label', 'as-right'], child: { text: '' } } ] }); }; CheckBox.prototype.notifyChange = function () { this.emit('change', { type: 'change', checked: this.checked, target: this }, this); }; //v, labelText, checked CheckBox.attribute = { checked: { set: function (value) { if (value === 'false' || value == null) { this.checked = false; } else { this.checked = true; } }, get: function () { return this.checked ? 'true' : 'false' }, remove: function () { this.checked = false; } }, disabled: { set: function (value) { this.disabled = !(value === 'false' || value === null); }, get: function () { return this.disabled ? 'true' : 'false'; }, remove: function () { this.disabled = false; } }, readonly: { set: function (value) { this.readOnly = !(value === 'false' || value === null); }, get: function () { return this.readOnly ? 'true' : 'false' } } }; CheckBox.property = {}; CheckBox.property.text = { get: function () { return this._text; }, set: function (value) { value = value || ''; if (value.length === 0) { this.addClass('as-no-label'); } else { this.removeClass('as-no-label'); } this._text = value; this.$labels[0].firstChild.data = value; this.$labels[1].firstChild.data = value; } }; CheckBox.property.disabled = { get: function () { return this.$input.disabled; }, set: function (value) { value = !!value; this.$input.disabled = value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } } }; CheckBox.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); this.$input.readOnly = true; } else { this.addClass('as-read-only'); this.$input.readOnly = false; } }, get: function () { return this.$input.readOnly; } } /*** * * @type {{}|CheckBox} */ CheckBox.eventHandler = {}; CheckBox.eventHandler.click = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$input, event) && !this.readOnly) { this.$input.click(); } }; ACore/* default.install */.Z.install(CheckBox); /* harmony default export */ const js_CheckBox = (CheckBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/circlesectionlabel.css var circlesectionlabel = __webpack_require__(9022); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Svg.js var Svg = __webpack_require__(6821); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CircleSectionLabel.js var CircleSectionLabel_ = ACore/* default._ */.Z._; var CircleSectionLabel_$ = ACore/* default.$ */.Z.$; var _g = Svg/* default.ShareInstance._ */.ZP.ShareInstance._; var $g = Svg/* default.ShareInstance.$ */.ZP.ShareInstance.$; var Design = { circleHeight: 218 - 36, borderWidth: 36, textBoxHeight: 146, textHeight: 48, indexHeight: 54, textBoxPaddingLeft: 80, indexArrowRadius: (172 - 18) / 2, indexArrowStrokeWidth: 18, indexArrowStartAngle: -Math.PI / 6, indexArrowEndAngle: -7 * Math.PI / 12 }; var StyleSheet = { '.as-circle-section-label-text': { height: Design.textBoxHeight / Design.textHeight + 'em', 'padding-left': Design.textBoxPaddingLeft / Design.textHeight + 'em', 'line-height': Design.textBoxHeight / Design.textHeight + 'em' }, '.as-circle-section-label-index': { 'font-size': Design.indexHeight / Design.textHeight + 'em', height: (Design.circleHeight + Design.borderWidth) / Design.indexHeight + 'em', 'line-height': (Design.circleHeight + Design.borderWidth) / Design.indexHeight + 'em', width: (Design.circleHeight + Design.borderWidth) / Design.indexHeight + 'em' }, }; CircleSectionLabel_({ tag: 'style', id: 'circle-section-label-style', props: { innerHTML: Object.keys(StyleSheet).map(function (key) { var style = StyleSheet[key]; return key + ' {\n' + Object.keys(style).map(function (propName) { return propName + ': ' + style[propName] + ';'; }).join('\n') + '}'; }).join('\n') } }).addTo(document.head); /** * @extends AElement * @constructor */ function CircleSectionLabel() { this._ident = (Math.random() + '').replace(/[^0-9]/g, '_'); this.$background = CircleSectionLabel_$('.as-circle-section-label-background', this); this.$index = CircleSectionLabel_$('.as-circle-section-label-index', this); this.$text = CircleSectionLabel_$('.as-circle-section-label-text', this); this.$attachhook = CircleSectionLabel_('attachhook').addTo(this).on('error', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.requestUpdateSize(); }); this.$attachhook.requestUpdateSize = this.redrawBackground.bind(this); this.$svg = _g({ tag: 'svg', attr: { width: '0', height: '0' }, child: [ { tag: 'defs', child: [ { tag: 'marker', id: 'marker_' + this._ident, attr: { markerWidth: "4", markerHeight: "4", refX: "0", refY: "1", orient: "auto", markerUnits: "strokeWidth", viewBox: "0 0 4 4" }, child: { tag: 'path', class: 'as-circle-section-label-arrow-marker-path', attr: { d: 'M0,0 L0,2 L2,1 z' } } } ] }, 'rect.as-circle-section-label-text-box', 'circle.as-circle-section-label-index-box', 'path.as-circle-section-label-arrow' ] }).addTo(this.$background); this.$indexBox = $g('circle.as-circle-section-label-index-box', this.$svg); this.$textBox = $g('rect.as-circle-section-label-text-box', this.$svg); // this.$marker = $g('defs marker', this.$svg); // this.$markerPath = $g(' path', this.$marker); this.$arrow = $g('path.as-circle-section-label-arrow', this.$svg) .attr({ 'marker-end': "url(" + '#marker_' + this._ident + ")" }); }; CircleSectionLabel.prototype.redrawBackground = function () { var indexBound = this.$index.getBoundingClientRect(); var textBound = this.$text.getBoundingClientRect(); var cHeight = indexBound.height; var cWidth = textBound.right - indexBound.left; this.$svg.attr({ height: cHeight + '', width: cWidth + '', viewBox: [0, 0, cWidth, cHeight].join(' ') }); var borderWidth = cHeight * Design.borderWidth / (Design.circleHeight + Design.borderWidth); var radius = cHeight * Design.circleHeight / (Design.circleHeight + Design.borderWidth) / 2; var x0 = indexBound.width / 2; var y0 = cHeight / 2; this.$indexBox.attr({ r: radius + '', cx: x0, cy: y0 }) .addStyle({ strokeWidth: borderWidth + '' }); var textBoxHeight = textBound.height; this.$textBox.attr( { x: x0 / 2, y: (cHeight - textBoxHeight) / 2, width: cWidth - x0 - 1, height: textBoxHeight, rx: textBoxHeight / 2, ry: textBoxHeight / 2 } ); var arrowRadius = cHeight * Design.indexArrowRadius / (Design.circleHeight + Design.borderWidth); this.$arrow.attr({ d: [ 'M', x0 + arrowRadius * Math.cos(Design.indexArrowStartAngle), y0 + arrowRadius * Math.sin(Design.indexArrowStartAngle), 'A', arrowRadius, arrowRadius, 0, 1, 1, x0 + arrowRadius * Math.cos(Design.indexArrowEndAngle), y0 + arrowRadius * Math.sin(Design.indexArrowEndAngle) ].join(' ') }).addStyle('stroke-width', cHeight * Design.indexArrowStrokeWidth / (Design.circleHeight + Design.borderWidth)) }; CircleSectionLabel.tag = 'CircleSectionLabel'.toLowerCase(); CircleSectionLabel.render = function () { return CircleSectionLabel_({ class: 'as-circle-section-label', child: [ { class: 'as-circle-section-label-background' }, '.as-circle-section-label-index', '.as-circle-section-label-text' ] }); }; CircleSectionLabel.property = {}; CircleSectionLabel.property.index = { set: function (value) { this._index = value; this.$index.clearChild().addChild(CircleSectionLabel_({ text: value + '' })) }, get: function () { return this._index; } }; CircleSectionLabel.property.text = { set: function (value) { this._text = value; this.$text.clearChild().addChild(CircleSectionLabel_({ text: value + '' })) }, get: function () { return this._text; } } ACore/* default.install */.Z.install(CircleSectionLabel); /* harmony default export */ const js_CircleSectionLabel = (CircleSectionLabel); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Scroller.js var Scroller = __webpack_require__(9246); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ContextMenu.js var ContextMenu = __webpack_require__(7054); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Menu.js var Menu = __webpack_require__(407); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dateinput.css var dateinput = __webpack_require__(8094); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/datetimeinput.css var datetimeinput = __webpack_require__(8000); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DomSignal.js var DomSignal = __webpack_require__(5150); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/chrometimepicker.css var chrometimepicker = __webpack_require__(6171); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ChromeTimePicker.js /*** * @extends AElement * @constructor */ function ChromeTimePicker() { this._hour = null; this._minute = null; OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'dayOffset', 'value'); this.$lists = (0,ACore.$$)('.as-chrome-time-picker-list', this); this.$hourList = this.$lists[0]; this.$hourList.on('scroll', this.eventHandler.hourScroll) .on('click', this.eventHandler.clickHourList); this.$hour24List = this.$lists[1]; this.$hour24List.on('scroll', this.eventHandler.hour24Scroll) .on('click', this.eventHandler.clickHour24List); this.$minList = this.$lists[2]; this.$minList.on('scroll', this.eventHandler.minScroll) .on('click', this.eventHandler.clickMinList); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$attachhook) .on('request_scroll_into_selected', this._scrollIntoSelected.bind(this)); this.$amBtn = (0,ACore.$)('.as-chrome-time-picker-btn[data-value="AM"]', this) .on('click', this.eventHandler.clickAM); this.$pmBtn = (0,ACore.$)('.as-chrome-time-picker-btn[data-value="PM"]', this) .on('click', this.eventHandler.clickPM); this.scrollIntoSelected(); this.hour = null; this.minute = null; this.s24 = false; (0,ACore.$$)('.as-chrome-time-picker-scroller', this).forEach(this._makeScroller.bind(this)); /*** * @memberOf ChromeTimePicker# * @type {number} * @name min */ } ChromeTimePicker.tag = 'ChromeTimePicker'.toLowerCase(); ChromeTimePicker.render = function () { return (0,ACore._)({ class: 'as-chrome-time-picker', extendEvent: ['change'], child: [ { class: ['as-chrome-time-picker-scroller', 'as-chrome-time-picker-scroller-h12'], child: [ {tag: 'button', class: 'as-chrome-time-picker-scroller-up', child: 'span.mdi.mdi-chevron-up'}, {tag: 'button', class: 'as-chrome-time-picker-scroller-down', child: 'span.mdi.mdi-chevron-down'}, { class: ['as-chrome-time-picker-viewport', 'as-chrome-time-picker-h12'], child: { class: 'as-chrome-time-picker-list', child: Array(36).fill(0).map(function (u, i) { return { tag: 'button', class: 'as-chrome-time-picker-btn', child: { tag: 'span', child: {text: (i % 12) + 1 + ''} }, props: { __hour__: (i % 12) + 1 } } }) } }] }, { class: ['as-chrome-time-picker-scroller', 'as-chrome-time-picker-scroller-h24'], child: [ {tag: 'button', class: 'as-chrome-time-picker-scroller-up', child: 'span.mdi.mdi-chevron-up'}, {tag: 'button', class: 'as-chrome-time-picker-scroller-down', child: 'span.mdi.mdi-chevron-down'}, { class: ['as-chrome-time-picker-viewport', 'as-chrome-time-picker-h24'], child: { class: 'as-chrome-time-picker-list', child: Array(24 * 3).fill(0).map(function (u, i) { return { tag: 'button', class: 'as-chrome-time-picker-btn', child: { tag: 'span', child: {text: (i % 24) + ''} }, props: { __hour__: (i % 24) } } }) } }] }, { class: 'as-chrome-time-picker-scroller', child: [ {tag: 'button', class: 'as-chrome-time-picker-scroller-up', child: 'span.mdi.mdi-chevron-up'}, {tag: 'button', class: 'as-chrome-time-picker-scroller-down', child: 'span.mdi.mdi-chevron-down'}, { class: 'as-chrome-time-picker-viewport', child: { class: 'as-chrome-time-picker-list', child: Array(180).fill(0).map(function (u, i) { return { tag: 'button', class: 'as-chrome-time-picker-btn', child: { tag: 'span', child: {text: (i % 60) + ''} }, props: { __min__: (i % 60) } } }) } }] }, { class: ['as-chrome-time-picker-viewport', 'as-chrome-time-picker-period'], child: ['AM', 'PM'].map(function (u,) { return { tag: 'button', class: 'as-chrome-time-picker-btn', attr: { 'data-value': u }, child: { tag: 'span', child: {text: u} }, props: { __APM__: u } } }) } ] }); }; ChromeTimePicker.prototype._makeScroller = function (rootElt) { var upBtn = (0,ACore.$)('.as-chrome-time-picker-scroller-up', rootElt); var downBtn = (0,ACore.$)('.as-chrome-time-picker-scroller-down', rootElt); var listElt = (0,ACore.$)('.as-chrome-time-picker-list', rootElt); var delta = 0; function tick() { if (delta === 0) return; listElt.scrollTop -= delta; requestAnimationFrame(tick); } function cancel() { delta = 0; document.body.removeEventListener('mouseup', cancel); document.body.removeEventListener('mouseleave', cancel); } upBtn.on('mousedown', function () { delta = 5; document.body.addEventListener('mouseup', cancel); document.body.addEventListener('mouseleave', cancel); tick(); }); downBtn.on('mousedown', function () { delta = -5; document.body.addEventListener('mouseup', cancel); document.body.addEventListener('mouseleave', cancel); tick(); }); }; ChromeTimePicker.prototype.scrollIntoSelected = function () { this.domSignal.emit('request_scroll_into_selected'); }; ChromeTimePicker.prototype._scrollIntoSelected = function () { var hour = this._hour; this.$hour24List.scrollTop = (hour + 24) * 28; hour = this._hour % 12; if (hour === 0) hour = 12; this.$hourList.scrollTop = (hour + 11) * 28; this.$minList.scrollTop = (this._minute + 60) * 28; }; ChromeTimePicker.prototype.notifyChange = function (event) { this.emit('change', { type: 'change', originEvent: event, dayOffset: this.dayOffset, hour: this.hour, minute: this.minute, target: this }, this); } ChromeTimePicker.property = {}; ChromeTimePicker.property.hour = { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.min(23, Math.max(0, Math.floor(value) % 24)); } else { value = null; } var prevVal = this._hour; if (prevVal !== null) { this.$hour24List.childNodes[prevVal].removeClass('as-selected'); this.$hour24List.childNodes[prevVal + 24].removeClass('as-selected'); this.$hour24List.childNodes[prevVal + 48].removeClass('as-selected'); prevVal = this._hour % 12; if (prevVal === 0) prevVal = 12; this.$hourList.childNodes[prevVal - 1].removeClass('as-selected'); this.$hourList.childNodes[prevVal - 1 + 12].removeClass('as-selected'); this.$hourList.childNodes[prevVal - 1 + 24].removeClass('as-selected'); } this._hour = value; prevVal = this._hour; if (prevVal !== null) { this.$hour24List.childNodes[prevVal].addClass('as-selected'); this.$hour24List.childNodes[prevVal + 24].addClass('as-selected'); this.$hour24List.childNodes[prevVal + 48].addClass('as-selected'); prevVal = this._hour % 12; if (prevVal === 0) prevVal = 12; this.$hourList.childNodes[prevVal - 1].addClass('as-selected'); this.$hourList.childNodes[prevVal - 1 + 12].addClass('as-selected'); this.$hourList.childNodes[prevVal - 1 + 24].addClass('as-selected'); if (this._hour >= 12) { this.$pmBtn.addClass('as-selected'); this.$amBtn.removeClass('as-selected'); } else { this.$amBtn.addClass('as-selected'); this.$pmBtn.removeClass('as-selected'); } } else { this.$pmBtn.removeClass('as-selected'); this.$amBtn.removeClass('as-selected'); } }, get: function () { return this._hour; } }; ChromeTimePicker.property.minute = { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.min(59, Math.max(0, Math.floor(value) % 60)); } else { value = null; } var prevVal = this._minute; if (prevVal !== null) { this.$minList.childNodes[prevVal].removeClass('as-selected'); this.$minList.childNodes[prevVal + 60].removeClass('as-selected'); this.$minList.childNodes[prevVal + 120].removeClass('as-selected'); } this._minute = value; prevVal = this._minute; if (prevVal !== null) { this.$minList.childNodes[prevVal].addClass('as-selected'); this.$minList.childNodes[prevVal + 60].addClass('as-selected'); this.$minList.childNodes[prevVal + 120].addClass('as-selected'); } }, get: function () { return this._minute; } }; ChromeTimePicker.property.value = { set: function (value) { if (!(0,utils.isRealNumber)(value) && !(value instanceof Date)) { value = null; } if (value && value.getTime) { value = value.getTime() - (0,datetime.beginOfDay)(value).getTime(); if (!(0,utils.isRealNumber)(value)) value = null; } else if ((0,utils.isRealNumber)(value)) { value = Math.min(datetime.MILLIS_PER_DAY - 1, Math.max(0, value % datetime.MILLIS_PER_DAY)); } if ((0,utils.isRealNumber)(value)) { this.hour = Math.floor(value / datetime.MILLIS_PER_HOUR); this.minute = Math.floor((value % datetime.MILLIS_PER_HOUR) / datetime.MILLIS_PER_MINUTE); } else { this.hour = null; this.minute = null; } this.domSignal.emit('request_scroll_into_selected'); }, get: function () { var res = this._hour * datetime.MILLIS_PER_HOUR + this._minute * datetime.MILLIS_PER_MINUTE; return (0,utils.isRealNumber)(res) ? res : null; } }; ChromeTimePicker.property.min = { set: function (value){ }, get: function (){ } }; ChromeTimePicker.property.s24 = { set: function (value) { if (value) { this.addClass('as-24h-clock'); } else { this.removeClass('as-24h-clock'); } }, get: function () { return this.hasClass('as-24h-clock'); } } ChromeTimePicker.eventHandler = {}; ChromeTimePicker.eventHandler.hourScroll = function () { var y = this.$hourList.scrollTop; var dy = 0; if (y < 28 * 12) dy = 28 * 12; else if (y > 28 * 24) { dy = -28 * 12; } if (dy !== 0) { this.$hourList.scrollTop += dy; } }; ChromeTimePicker.eventHandler.hour24Scroll = function () { var y = this.$hour24List.scrollTop; var dy = 0; if (y < 28 * 24) dy = 28 * 24; else if (y > 28 * 48) { dy = -28 * 24; } if (dy !== 0) { this.$hour24List.scrollTop += dy; } }; ChromeTimePicker.eventHandler.minScroll = function () { var y = this.$minList.scrollTop; var dy = 0; if (y < 28 * 60) dy = 28 * 60; else if (y > 28 * 120) { dy = -28 * 60; } if (dy !== 0) { this.$minList.scrollTop += dy; } }; ChromeTimePicker.eventHandler.clickHourList = function (event) { var hour; if ('__hour__' in event.target) hour = event.target.__hour__; if ('__hour__' in event.target.parentElement) hour = event.target.parentElement.__hour__; if (hour !== undefined) { if (this.hour >= 12) { this.hour = hour === 12 ? hour : hour + 12; } else { this.hour = hour === 12 ? 0 : hour; } if ((hour - 1 + 12) * 28 < this.$hourList.scrollTop) { this.$hourList.scrollTop = (hour - 1 + 12) * 28; } else if (((hour - 1 + 13) * 28) > this.$hourList.scrollTop + this.$hourList.clientHeight) { this.$hourList.scrollTop = (hour - 1 + 13) * 28 - this.$hourList.clientHeight; } this.notifyChange(event); } }; ChromeTimePicker.eventHandler.clickHour24List = function (event) { var hour; if ('__hour__' in event.target) hour = event.target.__hour__; if ('__hour__' in event.target.parentElement) hour = event.target.parentElement.__hour__; if (hour !== undefined) { this.hour = hour; if ((hour + 24) * 28 < this.$hourList.scrollTop) { this.$hourList.scrollTop = (hour + 24) * 28; } else if (((hour + 24) * 28) > this.$hourList.scrollTop + this.$hourList.clientHeight) { this.$hourList.scrollTop = (hour + 24) * 28 - this.$hourList.clientHeight; } this.notifyChange(event); } }; ChromeTimePicker.eventHandler.clickMinList = function (event) { var min; if ('__min__' in event.target) min = event.target.__min__; if ('__min__' in event.target.parentElement) min = event.target.parentElement.__min__; if (min !== undefined) { this.minute = min; if ((min + 60) * 28 < this.$minList.scrollTop) { this.$minList.scrollTop = (min + 60) * 28; } else if (((min + 61) * 28) > this.$minList.scrollTop + this.$minList.clientHeight) { this.$minList.scrollTop = (min + 61) * 28 - this.$minList.clientHeight; } this.notifyChange(event); } }; ChromeTimePicker.eventHandler.clickPM = function (event) { if ((0,utils.isRealNumber)(this.hour)) { if (this.hour < 12) this.hour += 12; } else { this.hour = 12; } this.notifyChange(event); }; ChromeTimePicker.eventHandler.clickAM = function (event) { if ((0,utils.isRealNumber)(this.hour)) { if (this.hour >= 12) this.hour -= 12; } else { this.hour = 0; } this.notifyChange(event); }; ACore/* default.install */.Z.install(ChromeTimePicker); /* harmony default export */ const js_ChromeTimePicker = (ChromeTimePicker); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Follower.js var Follower = __webpack_require__(7094); // EXTERNAL MODULE: ./node_modules/absol/src/Input/keyboard.js var keyboard = __webpack_require__(27); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DateTimeInput.js var STATE_NEW = 1; var STATE_EDITED = 2; var STATE_NONE = 0; /*** * @extends AElement * @constructor */ function DateTimeInput() { this._editingData = {}; this._value = null; this._min = new Date(1890, 0, 1); this._max = new Date(new Date(2090, 0, 1).getTime() - 1); this._format = 'dd/MM/yyyy HH:mm'; this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$attachhook); this.domSignal.on('request_auto_select', this._autoSelect.bind(this)); /*** * * @type {HTMLInputElement | AElement} */ this.$text = (0,ACore.$)('.as-date-time-input-text', this) .on('mousedown', this.eventHandler.mouseDownInput) .on('mouseup', this.eventHandler.mouseUpInput) .on('dblclick', this.eventHandler.dblclickInput) .on('keydown', this.eventHandler.keydown) .on('blur', this.eventHandler.inputBlur) .on('contextmenu', function (event) { event.preventDefault(); }); this.$pickerBtn = (0,ACore.$)('.as-date-time-input-icon-btn', this) .on('click', this.eventHandler.clickPickerBtn); this.$clearBtn = (0,ACore.$)('button.as-time-input-clear-btn', this) .on('click', this.clear.bind(this)); this.notNull = false; this.min = this._min; this.max = this._max; } DateTimeInput.tag = 'DateTimeInput'.toLowerCase(); //calendar-clock DateTimeInput.render = function () { return (0,ACore._)({ extendEvent: ['change'], class: 'as-date-time-input', child: [ { tag: 'input', class: 'as-date-time-input-text', attr: { ondrop: "return false;" }, props: { value: 'dd/MM/yyyy HH:mm' } }, { tag: 'button', class: 'as-time-input-clear-btn', child: 'span.mdi.mdi-close-circle' }, { tag: 'button', class: 'as-date-time-input-icon-btn', child: 'span.mdi.mdi-calendar-clock' } ] }); }; DateTimeInput.prototype.tokenRegex = /([^.\/:\-,\\\s]+)|([.\/:\-,\\]+)/i; /*** * * @param start * @returns {null|{ident: string, length: number, sourceText: string, replace: function(s: string, selecting:boolean):void, text: string, idx: number, elt: (HTMLInputElement|absol.AElement)}} */ DateTimeInput.prototype._tokenAt = function (start) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var rgxFormat = new RegExp(this.tokenRegex.source, 'g'); var s = this.$text.value; var format = this._format; var tokenMatched = rgx.exec(s); var formatToken = rgxFormat.exec(format); var tokenMatchedList = []; var formatTokenList = []; var text, ident; var idx; while (tokenMatched && formatToken) { text = tokenMatched[1]; ident = formatToken[1]; if (text && (0,utils.isDateTimeFormatToken)(ident)) { tokenMatchedList.push(tokenMatched); formatTokenList.push(formatToken); } tokenMatched = rgx.exec(s); formatToken = rgxFormat.exec(format); } var bestI = -1; var bestD = Infinity; var d; for (var i = 0; i < tokenMatchedList.length; ++i) { tokenMatched = tokenMatchedList[i]; formatToken = formatTokenList[i]; text = tokenMatched[1]; idx = tokenMatched.index; d = Math.min(Math.abs(start - idx), Math.abs(start - (idx + text.length))); if (d < bestD) { bestD = d; bestI = i; } } if (bestI >= 0) { tokenMatched = tokenMatchedList[bestI]; formatToken = formatTokenList[bestI]; text = tokenMatched[1]; ident = formatToken[1]; idx = tokenMatched.index; return { idx: idx, text: text, length: text.length, ident: ident, elt: this.$text, sourceText: s, replace: function (newText, selecting) { var left = this.sourceText.substr(0, this.idx); var right = this.sourceText.substr(this.idx + this.length); this.text = newText; this.length = newText.length; this.sourceText = left + this.text + right; this.elt.value = this.sourceText; if (selecting) { this.elt.setSelectionRange(this.idx, this.idx + this.length); } } } } return null; }; DateTimeInput.prototype._autoSelect = function () { var token = this._tokenAt(this.$text.selectionStart); var tokenEnd = this._tokenAt(this.$text.selectionEnd); if (token) { if (tokenEnd.idx === token.idx) { this.$text.setSelectionRange(token.idx, token.idx + token.length); this._editingData.state = STATE_NEW; } else { this.$text.select(); this._editingData.state = STATE_NONE; } } }; DateTimeInput.prototype._editNextToken = function () { var token = this._tokenAt(this.$text.selectionStart); if (!token) return false; var cIdx = token.idx; var l = this.$text.value.length; for (var i = token.idx + token.length; i < l; ++i) { token = this._tokenAt(i); if (token && token.idx !== cIdx) { this.$text.setSelectionRange(token.idx, token.idx + token.length); this._editingData.state = STATE_NEW; break; } } }; DateTimeInput.prototype._editPrevToken = function () { var token = this._tokenAt(this.$text.selectionStart); if (!token) return false; var cIdx = token.idx; var l = this.$text.value.length; for (var i = token.idx - 1; i >= 0; --i) { token = this._tokenAt(i); if (token && token.idx !== cIdx) { this.$text.setSelectionRange(token.idx, token.idx + token.length); this._editingData.state = STATE_NEW; break; } } }; DateTimeInput.prototype.tokenMap = { d: 'd', dd: 'd', M: 'M', MM: 'M', y: 'y', yyyy: 'y', hh: 'h', h: 'h', mm: 'm', m: 'm', a: 'a', HH: 'H', H: 'H' }; /*** * * @param {string} s * @returns {{}} * @private */ DateTimeInput.prototype._makeTokenDict = function (s) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var rgxFormat = new RegExp(this.tokenRegex.source, 'g'); var format = this._format; var tokenMap = this.tokenMap; var tokenMatched = rgx.exec(s); var formatToken = rgxFormat.exec(format); var text, ident; var idx; var res = {}; while (tokenMatched && formatToken) { text = tokenMatched[1]; ident = formatToken[1]; if (text) { if (tokenMap[ident]) { idx = tokenMatched.index; res[tokenMap[ident]] = { text: text, idx: idx, length: text.length, sourceText: s, value: ident === 'a' ? text : parseInt(text) } } } tokenMatched = rgx.exec(s); formatToken = rgxFormat.exec(format); } return res; }; /*** * * @param {Date} date * @private */ DateTimeInput.prototype._makeValueDict = function (date) { var res = {}; res.d = { value: date.getDate() }; res.y = { value: date.getFullYear() }; res.M = { value: date.getMonth() + 1 }; res.m = { value: date.getMinutes() }; res.h = { value: date.getHours() }; res.H = { value: date.getHours() }; if (res.h.value < 12) { if (res.h.value === 0) res.h.value = 12; res.a = { value: "AM" }; } else { if (res.h.value > 12) res.h.value -= 12; res.a = { value: "PM" }; } return res; }; DateTimeInput.prototype._applyTokenDict = function (format, dict, debug) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var tokenMap = this.tokenMap; return format.replace(rgx, function (full, g1, g2, sourceText) { if (g1 && tokenMap[g1]) { var ident = tokenMap[g1]; if (ident === 'a') { return (dict.a && dict.a.value) || 'a'; } else { if (dict[ident] && !isNaN(dict[ident].value)) { var numberText = dict[ident].value + ''; while (numberText.length < g1.length) numberText = '0' + numberText; return numberText; } else { return full; } } } else return full; }); }; DateTimeInput.prototype._loadValueFromInput = function () { var tkDict = this._makeTokenDict(this.$text.value); var H = NaN; var m = NaN; if (tkDict.H && (0,utils.isRealNumber)(tkDict.H.value)) { H = tkDict.H.value; } else if (tkDict.h && tkDict.a && tkDict.a.value === 'AM') { H = tkDict.h.value % 12; } else if (tkDict.h && tkDict.a && tkDict.a.value === 'PM') { H = tkDict.h.value + (tkDict.h.value === 12 ? 0 : 12); } if (!tkDict.h && !tkDict.H) H = 0; if (tkDict.m) { m = tkDict.m.value; } else { m = 0; } var date = new Date(tkDict.y.value, tkDict.M.value - 1, tkDict.d.value, H, m); if (isNaN(date.getTime())) { this._value = null; } else { this._value = date; } }; DateTimeInput.prototype.clear = function () { var lev = this._lastEmitValue; if (this.notNull) { this.value = (0,datetime.formatDateTime)( new Date(Math.max(this.min.getTime(), Math.min(this.max.getTime(), new Date().getTime()))), this.format); } else { this.value = null; } this._lastEmitValue = lev; this._notifyIfChange(); }; DateTimeInput.prototype._notifyIfChange = function (event) { if (!this._lastEmitValue && !this._value) return; if (this._lastEmitValue && this._value && this._lastEmitValue.getTime() === this._value.getTime()) return; this.emit('change', { type: 'change', target: this, value: this._value, originEvent: event }, this); this._lastEmitValue = this._value; }; DateTimeInput.prototype._correctingInput = function () { var tkDict = this._makeTokenDict(this.$text.value); var equalMin = true; var equalMax = true; if (!isNaN(tkDict.y.value)) { tkDict.y.value = Math.max(this._min.getFullYear(), Math.min(this._max.getFullYear(), tkDict.y.value)); equalMin = tkDict.y.value === this._min.getFullYear(); equalMax = tkDict.y.value === this._max.getFullYear(); } else { equalMin = false; equalMax = false; } if (!isNaN(tkDict.M.value)) { tkDict.M.value = Math.max(1, Math.min(12, tkDict.M.value)); if (equalMin) { tkDict.M.value = Math.max(this._min.getMonth() + 1, tkDict.M.value); equalMin = tkDict.M.value === this._min.getMonth() + 1; } if (equalMax) { tkDict.M.value = Math.min(this._max.getMonth() + 1, tkDict.M.value); equalMax = this._max.getMonth() + 1; } } else { equalMin = false; equalMax = false; } if (!isNaN(tkDict.d.value)) { tkDict.d.value = Math.max(1, Math.min(31, tkDict.d.value)); if (!isNaN(tkDict.M.value)) { tkDict.d.value = Math.min(tkDict.d.value, (0,datetime.daysInMonth)(isNaN(tkDict.y.value) ? 2020 : tkDict.y.value, tkDict.M.value - 1)); } if (equalMin) { tkDict.d.value = Math.max(this._min.getDate(), tkDict.d.value); equalMin = tkDict.d.value === this._min.getDate(); } if (equalMax) { tkDict.d.value = Math.min(this._max.getDate(), tkDict.d.value); equalMax = tkDict.d.value === this._max.getDate(); } } else { equalMin = false; equalMax = false; } //todo: min max if (tkDict.a && (tkDict.a.value === 'AM' || tkDict.a.value === 'PM')) { if (equalMin) { } } else { equalMin = false; equalMax = false; } this.$text.value = this._applyTokenDict(this._format, tkDict); this.attr('data-text', this.$text.value); }; DateTimeInput.prototype._correctingCurrentToken = function () { var token = this._tokenAt(this.$text.selectionStart); if (!token) return; var value; if (token.ident === 'a') { if (token.text !== 'a' && token.text !== 'AM' && token.text !== 'PM') { token.replace('a', false); } } else { value = parseInt(token.text); var rqMin = { d: 1, dd: 1, M: 1, MM: 1, y: 1890, yyyy: 1890, h: 1, hh: 1, HH: 0, H: 0, m: 0, mm: 0 }[token.ident]; var rqMax = { d: 31, dd: 31, M: 12, MM: 12, y: 2089, yyyy: 2089, h: 12, hh: 12, HH: 23, H: 23, m: 59, mm: 59 }[token.ident]; if (rqMin !== undefined) { if (!isNaN(value)) { if ((value < rqMin || value > rqMin)) { value = Math.max(rqMin, Math.min(rqMax, value)); token.replace((0,utils.zeroPadding)(value, token.ident.length), false); this._editingData.d = value; } } else if (token.text !== token.ident) { token.replace(token.ident, false); } } } }; DateTimeInput.prototype._dateFrom = function (value) { var typeV = typeof value; if (typeV === 'string' || typeV === 'number') { value = new Date(value); } if (!value || !value.getTime) value = null; if (value) { value = new Date(value.getTime()); value.setSeconds(0, 0); } return value || null; } DateTimeInput.property = {}; DateTimeInput.property.disabled = { set: function (value) { this.$text.disabled = !!value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; DateTimeInput.property.notNull = { set: function (value) { if (value) { this.addClass('as-must-not-null'); if (!this.value) this.value = new Date(); } else { this.removeClass('as-must-not-null'); } this.value = this.value;//update }, get: function () { return this.hasClass('as-must-not-null'); } }; DateTimeInput.property.format = { set: function (value) { value = value || 'dd/MM/yyyy HH:mm'; var dict; if (this._value) { dict = this._makeValueDict(this._value); } else { dict = this._makeTokenDict(this.$text.value); } this._format = value; this.$text.value = this._applyTokenDict(value, dict); this.attr('data-text', this.$text.value); }, get: function () { return this._format; } }; DateTimeInput.property.value = { set: function (value) { this._value = this._dateFrom(value); var dict; if (this._value) { dict = this._makeValueDict(this._value); } else { dict = this._makeTokenDict(this.$text.value); } if (value) { this.$text.value = this._applyTokenDict(this._format, dict, true); this.attr('data-text', this.$text.value); } else { this.$text.value = this.format; this.attr('data-text', this.$text.value); } this._lastEmitValue = this._value; }, get: function () { return this._value; } }; DateTimeInput.property.min = { set: function (value) { this._min = this._dateFrom(value) || new Date(1890, 0, 1); }, get: function () { return this._min; } }; DateTimeInput.property.max = { set: function (value) { this._max = this._dateFrom(value) || new Date(new Date(2090, 0, 1).getTime() - 1); }, get: function () { return this._max; } }; DateTimeInput.property.readOnly = { set: function (value) { if (value) { this.addClass(('as-read-only')); } else { this.removeClass(('as-read-only')); } }, get: function () { return this.hasClass('as-read-only'); } }; DateTimeInput.property.text = { get: function () { return this.$text.value; } }; DateTimeInput.eventHandler = {}; DateTimeInput.eventHandler.mouseUpInput = function () { if (!this.readOnly) { this.domSignal.emit('request_auto_select'); } }; DateTimeInput.eventHandler.mouseDownInput = function () { if (!this.readOnly && document.activeElement === this.$text) { this._correctingCurrentToken(); } } DateTimeInput.eventHandler.dblclickInput = function (event) { event.preventDefault(); }; /*** * * @param {KeyboardEvent} event */ DateTimeInput.eventHandler.keydown = function (event) { var kbId = (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event); if (this.readOnly) { if (!kbId.match(/^arrow/) && !kbId.match(/^ctrl-[ca]/)) { event.preventDefault(); } return; } var token = this._tokenAt(this.$text.selectionStart); var endToken = this._tokenAt(this.$text.selectionEnd); if (!token) { if (event.key === 'Enter') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } return; } var newTokenText; var value; if (event.key.startsWith('Arrow') || [' ', ':', '/', '-'].indexOf(event.key) >= 0) { event.preventDefault(); switch (event.key) { case 'ArrowLeft': this._editPrevToken(); break; case 'ArrowRight': case ' ': case ':': case '/': case '-': this._editNextToken(); break; case 'ArrowUp': case 'ArrowDown': switch (token.ident) { case 'dd': case 'd': value = parseInt(token.text); if (isNaN(value)) { this._editingData.d = event.key === 'ArrowUp' ? 1 : 31; } else { this._editingData.d = 1 + (value + (event.key === 'ArrowUp' ? 0 : 29)) % 31; } newTokenText = '' + this._editingData.d; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'MM': case 'M': value = parseInt(token.text) - 1; if (isNaN(value)) { this._editingData.M = event.key === 'ArrowUp' ? 0 : 11; } else { this._editingData.M = (value + (event.key === 'ArrowUp' ? 1 : 11)) % 12; } newTokenText = '' + (this._editingData.M + 1); while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'yyyy': value = parseInt(token.text); if (isNaN(value)) { this._editingData.y = new Date().getFullYear(); } else { this._editingData.y = Math.max(1890, Math.min(2089, value + (event.key === 'ArrowUp' ? 1 : -1))); } newTokenText = this._editingData.y + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case "hh": case 'h': value = parseInt(token.text); if (isNaN(value)) { this._editingData.h = event.key === 'ArrowUp' ? 1 : 12; } else { this._editingData.h = 1 + (value + (event.key === 'ArrowUp' ? 0 : 10)) % 12; } newTokenText = this._editingData.h + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case "HH": case 'H': value = parseInt(token.text); if (isNaN(value)) { this._editingData.H = event.key === 'ArrowUp' ? 1 : 12; } else { this._editingData.H = (value + (event.key === 'ArrowUp' ? 1 : 23)) % 24; } newTokenText = this._editingData.H + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case "mm": case 'm': value = parseInt(token.text); if (isNaN(value)) { this._editingData.m = event.key === 'ArrowUp' ? 0 : 59; } else { this._editingData.m = (value + (event.key === 'ArrowUp' ? 1 : 59)) % 60; } newTokenText = this._editingData.m + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'a': value = token.text; this._editingData.a = value === 'PM' ? "AM" : "PM"; newTokenText = this._editingData.a; token.replace(newTokenText, true); break; } break; } } else if (event.key === "Delete" || event.key === 'Backspace') { event.preventDefault(); if (endToken.idx !== token.idx) { if (this.notNull) { this.$text.value = (0,datetime.formatDateTime)( new Date(Math.max(this.min.getTime(), Math.min(this.max.getTime(), new Date().getTime()))), this.format); } else { this.$text.value = this._format; } this.attr('data-text', this.$text.value); this.$text.select(); } else { if (this.notNull) { switch (token.ident) { case 'HH': case 'mm': case 'H': case 'm': token.replace((0,utils.zeroPadding)(0, token.ident.length), true); break; case 'h': case 'hh': token.replace('12', true); break; case 'M': case 'MM': case 'dd': case 'd': token.replace((0,utils.zeroPadding)(1, token.ident.length), true); break; case 'y': case 'yyyy': token.replace( (0,utils.zeroPadding)(Math.max(this.min.getFullYear(), Math.min(this.max.getFullYear(), new Date().getFullYear())), token.ident.length), true); break; case 'a': token.replace('AM', true); break; } } else { token.replace(token.ident, true); } if (event.key === "Delete") this._editNextToken(); else this._editPrevToken(); } } else if (event.key === "Enter" || event.key === 'Tab') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } else if (event.ctrlKey) { switch (event.key) { case 'a': case 'A': break; case 'c': case 'C': break; case 'x': case 'X': this.domSignal.once('clear_value', function () { this.$text.value = this._format; this.attr('data-text', this.$text.value); this.$text.select(); }.bind(this)); this.domSignal.emit('clear_value'); break; default: event.preventDefault(); } } else if (event.key.match(/^[0-9]$/g)) { event.preventDefault(); var dVal = parseInt(event.key); if (this._editingData.state === STATE_NEW) { switch (token.ident) { case 'dd': case 'd': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; this._editingData.d = dVal; if (dVal > 3) { this._editNextToken(); } break; case 'MM': case 'M': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; this._editingData.M = dVal; if (dVal > 1) { this._editNextToken(); } break; case 'yyyy': case 'y': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; this._editingData.state_num = 1; break; case 'm': case 'mm': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; if (dVal > 5) { this._editNextToken(); } break; case 'h': case 'hh': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; if (dVal > 1) { this._editNextToken(); } break; case 'HH': case 'H': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = STATE_EDITED; if (dVal > 2) { this._editNextToken(); } break; } } else { switch (token.ident) { case 'dd': case 'd': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(31, dVal)); this._editingData.d = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'MM': case 'M': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(12, dVal)); this._editingData.M = dVal - 1; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'yyyy': case 'y': dVal = (parseInt(token.text.replace(/^./, '')) || 0) * 10 + dVal; this._editingData.state_num++; if (this._editingData.state_num >= 4) { // dVal = Math.max(1890, Math.min(2089, dVal)); token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); } else { token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); } break; case 'm': case 'mm': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(59, dVal)); this._editingData.m = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'h': case 'hh': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(12, dVal)); this._editingData.h = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'H': case 'HH': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(23, dVal)); this._editingData.h = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; } } } else if (event.key.match(/^[aApPSCsc]$/) && token.ident === 'a') { event.preventDefault(); if (event.key.match(/^[aAsS]$/)) { token.replace('AM', true); this._editingData.a = "AM"; } else { token.replace('PM', true); this._editingData.a = "PM"; } this._editNextToken(); } else { event.preventDefault(); } } DateTimeInput.eventHandler.inputBlur = function () { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(); }; DateTimeInput.eventHandler.clickPickerBtn = function () { this._attachPicker(); }; DateTimeInput.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$follower, event)) return; this._releasePicker(); }; DateTimeInput.eventHandler.clickCancelBtn = function () { this._releasePicker(); }; DateTimeInput.eventHandler.calendarPick = function (event) { var value = event.value; var tkDict = this._makeTokenDict(this.share.pickedValeText); if (tkDict.y) { tkDict.y.value = value.getFullYear(); } if (tkDict.M) { tkDict.M.value = value.getMonth() + 1; } if (tkDict.d) { tkDict.d.value = value.getDate(); } this.share.pickedValeText = this._applyTokenDict(this._format, tkDict); if (this.share.dateOnly) this.eventHandler.clickOKBtn({}); }; DateTimeInput.eventHandler.clickOKBtn = function (event) { this.$text.value = this.share.pickedValeText; this.attr('data-text', this.$text.value); this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); this._releasePicker(); }; DateTimeInput.eventHandler.timePick = function (event) { var hour = event.hour; var minute = event.minute; var tkDict = this._makeTokenDict(this.share.pickedValeText); if (tkDict.h) { tkDict.h.value = 1 + ((hour + 11) % 12); if (tkDict.a) { tkDict.a.value = hour >= 12 ? "PM" : 'AM'; } } if (tkDict.H) { tkDict.H.value = hour; } if (tkDict.m) { tkDict.m.value = minute; } this.share.pickedValeText = this._applyTokenDict(this._format, tkDict); }; DateTimeInput.prototype.share = { $follower: null, $calendar: null, $timePicker: null, $holdingInput: null }; DateTimeInput.prototype._preparePicker = function () { if (!this.share.$follower) { this.share.$timePicker = (0,ACore._)({ tag: js_ChromeTimePicker.tag, class: 'as-date-time-input-time-picker' }); this.share.$calendar = (0,ACore._)({ tag: ChromeCalendar/* default.tag */.Z.tag, class: 'as-date-time-input-date-picker' }); if (this.share.$calendar.$attachHook) { this.share.$calendar.$attachHook.cancelWaiting(); } this.share.$cancelBtn = (0,ACore._)({ tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { "data-ml-key": 'txt_cancel' }, }); this.share.$okBtn = (0,ACore._)({ tag: 'a', class: 'as-select-list-box-ok-btn', attr: { "data-ml-key": 'txt_ok' }, }); this.share.$follower = (0,ACore._)({ tag: Follower/* default.tag */.Z.tag, class: ['as-date-time-input-follower', 'as-dropdown-box-common-style'], child: [ { class: 'as-date-time-input-picker-ctn', child: [ this.share.$calendar, this.share.$timePicker ] }, { class: 'as-dropdown-box-footer', child: [{ class: 'as-dropdown-box-footer-right', child: [ this.share.$okBtn, this.share.$cancelBtn ] } ] } ] }); this.share.$footer = (0,ACore.$)('.as-dropdown-box-footer', this.share.$follower); this.share.$follower.cancelWaiting(); } }; DateTimeInput.prototype._attachPicker = function () { this._preparePicker(); if (this.share.$holdingInput) this.share.$holdingInput._releasePicker(); this.share.pickedValeText = this.$text.value; this.share.$holdingInput = this; this.share.$follower.addStyle('visibility', 'hidden'); this.share.$follower.addTo(document.body); this.share.$follower.followTarget = this; this.share.$follower.sponsorElement = this; this.$pickerBtn.off('click', this.eventHandler.clickPickerBtn); this.share.$calendar.on('pick', this.eventHandler.calendarPick); this.share.$timePicker.on('change', this.eventHandler.timePick); this.share.$okBtn.on('click', this.eventHandler.clickOKBtn); this.share.$cancelBtn.on('click', this.eventHandler.clickCancelBtn); if (this.share.$calendar.$attachHook) { this.share.$calendar.$attachHook.emit('attached'); } var tkDict = this._makeTokenDict(this.$text.value); this.share.dateOnly = !tkDict.m && !tkDict.H && !tkDict.h; if (tkDict.h && !isNaN(tkDict.h.value)) { if (tkDict.a && tkDict.a.value === 'PM') { this.share.$timePicker.hour = 12 + tkDict.h.value % 12; } else { this.share.$timePicker.hour = tkDict.h.value % 12; } } else if (tkDict.H && (0,utils.isRealNumber)(tkDict.H.value)) { this.share.$timePicker.hour = tkDict.H.value; } else if (!tkDict.H && !tkDict.h) { this.share.$timePicker.hour = 0; } else { this.share.$timePicker.hour = null; } this.share.$timePicker.s24 = !!tkDict.H || !tkDict.a; if (tkDict.m && !isNaN(tkDict.m.value)) { this.share.$timePicker.minute = tkDict.m.value; } else if (!tkDict.m) { this.share.$timePicker.minute = 0; } else { this.share.$timePicker.minute = null; } if (this.share.dateOnly) { this.share.$timePicker.addStyle('display', 'none'); this.share.$footer.addStyle('display', 'none'); } else { this.share.$timePicker.removeStyle('display'); this.share.$footer.removeStyle('display'); this.share.$timePicker.scrollIntoSelected(); } var date = null; if (tkDict.d && !isNaN(tkDict.d.value) && tkDict.M && !isNaN(tkDict.M.value) && tkDict.y && !isNaN(tkDict.y.value)) { date = new Date(tkDict.y.value, tkDict.M.value - 1, tkDict.d.value); if (isNaN(date.getTime())) date = null; } if (date) { this.share.$calendar.selectedDates = [date]; this.share.$calendar.viewDate = date; } else { this.share.$calendar.selectedDates = []; var viewDate = null; if (tkDict.y && !isNaN(tkDict.y.value)) { if (tkDict.M && !isNaN(tkDict.M.value)) { if (tkDict.d && !isNaN(tkDict.d.value)) { viewDate = new Date(tkDict.y.value, tkDict.M.value - 1, tkDict.d.value); } else { viewDate = new Date(tkDict.y.value, tkDict.M.value - 1, 1); } } else { viewDate = new Date(tkDict.y.value, 0, 1); } } else { viewDate = new Date(); } if (viewDate && !isNaN(viewDate.getTime())) { this.share.$calendar.viewDate = viewDate; } else { this.share.$calendar.viewDate = new Date(); } } setTimeout(function () { this.share.$follower.removeStyle('visibility'); document.addEventListener('click', this.eventHandler.clickOut); }.bind(this), 5); }; DateTimeInput.prototype._releasePicker = function () { if (this.share.$holdingInput !== this) return; this.share.$follower.remove(); this.share.$holdingInput = null; this.share.$calendar.off('pick', this.eventHandler.calendarPick); this.share.$timePicker.off('change', this.eventHandler.timePick); this.share.$okBtn.off('click', this.eventHandler.clickOKBtn); this.share.$cancelBtn.off('click', this.eventHandler.clickCancelBtn); document.removeEventListener('click', this.eventHandler.clickOut); setTimeout(function () { this.$pickerBtn.on('click', this.eventHandler.clickPickerBtn); }.bind(this)); }; ACore/* default.install */.Z.install(DateTimeInput); /* harmony default export */ const js_DateTimeInput = (DateTimeInput); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DelaySignal.js var DelaySignal = __webpack_require__(8098); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DateInput2.js var DateInput2_STATE_NEW = 1; var DateInput2_STATE_EDITED = 2; var DateInput2_STATE_NONE = 0; /*** * * @param {Date} date * @param level * @returns {Date|null} */ var dateByLevel = (date, level) => { if (!date) return null; switch (level) { case 'week': return (0,datetime.beginOfWeek)(date); case 'month': return (0,datetime.beginOfMonth)(date); case 'quarter': return (0,datetime.beginOfQuarter)(date); case 'year': return (0,datetime.beginOfYear)(date); case 'date': default: return (0,datetime.beginOfDay)(date); } } var DateInput2_ = ACore/* default._ */.Z._; var DateInput2_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function DateInput2() { this._lastValue = null; this._value = null; this._format = 'dd/MM/yyyy'; this.$input = DateInput2_$('input', this); this._editingData = {}; this.startDayOfWeek = (0,datetime.getDefaultFirstDayOfWeek)(); this.$text = this.$input; this.$text.on('mousedown', this.eventHandler.mouseDownInput) .on('mouseup', this.eventHandler.mouseUpInput) .on('dblclick', this.eventHandler.dblclickInput) .on('keydown', this.eventHandler.keydown) .on('blur', this.eventHandler.inputBlur) .on('contextmenu', function (event) { event.preventDefault(); }); this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('request_auto_select', this._autoSelect.bind(this)); this._min = new Date(1890, 0, 1, 0, 0, 0, 0); this._max = new Date(2090, 0, 1, 0, 0, 0, 0); this.$calendarBtn = DateInput2_$('.as-date-input-icon-ctn', this) .on('click', this.eventHandler.clickCalendarBtn); this.$clearBtn = DateInput2_$('button.as-date-input-clear-btn', this) .on('click', this.clear.bind(this)); this.value = this._value; this.format = this._format; this.notNull = false; OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'minLimitDate', 'min'); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'minDateLimit', 'min'); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'maxLimitDate', 'max'); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'maxDateLimit', 'max'); /** * @type {Date} * @name min * @memberOf DateInput# */ /** * @type {Date} * @name max * @memberOf DateInput# */ /** * @type {Date} * @name value * @memberOf DateInput# */ /** * @type {string} * @name format * @memberOf DateInput# */ /** * @deprecated * @type {Date} * @name minLimitDate * @memberOf DateInput# */ /** * @deprecated * @type {Date} * @name maxLimitDate * @memberOf DateInput# */ } DateInput2.tag = 'dateinput'; DateInput2.render = function () { //only support dd/mm/yyyy return DateInput2_({ class: 'as-date-input', extendEvent: ['change'], child: [{ tag: 'input', class: 'as-date-input-text', props: { value: '__/__/____' } }, { tag: 'button', class: 'as-date-input-clear-btn', child: 'span.mdi.mdi-close-circle' }, { tag: 'button', class: 'as-date-input-icon-ctn', child: 'span.mdi.mdi-calendar' }] }); }; /** * @param {String} text */ DateInput2.prototype._verifyFormat = function (text) { var regex = new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g'); var tokens = text.match(regex); var map = { d: ['dd', 'd'], M: ['M', 'MM'], y: ['yy', 'yyyy'], Q: ['Q', 'QQ'], w: ['w', 'ww'], }; var rules = ['dMy', 'My', 'y', 'wy', 'Qy'].map(r => { r = r.split(''); r.sort(); return r.join(''); }); var matched = tokens.reduce((ac, cr) => { Object.keys(map).some(key => { if (map[key].indexOf(cr) >= 0) { ac.push(key); return true; } return false; }); return ac; }, []); matched.sort(); matched = matched.join(''); return rules.indexOf(matched) >= 0; }; DateInput2.prototype._notifyIfChange = function (event) { var oldV = this._explicit(this._lastValue); var newV = this._explicit(this._value); if (!oldV !== !newV || (oldV && newV && (0,datetime.compareDate)(oldV, newV) !== 0)) { this._lastValue = this._value; this.emit('change', { type: 'change', target: this, value: this._value, originEvent: event }, this); } }; DateInput2.prototype.notifyChange = function () { this._lastValue = this._value; this.emit('change', { type: 'change', target: this, value: this._value }, this); }; DateInput2.prototype.focus = function () { this.$input.focus(); }; DateInput2.prototype.blur = function () { this.$input.blur(); }; DateInput2.prototype.clear = function () { this._applyValue(null); this._notifyIfChange(); }; /*** * * @param {Date|null} value */ DateInput2.prototype._applyValue = function (value) { this._value = value; this._loadTextFromValue(); }; DateInput2.prototype._loadTextFromValue = function () { var value = this.value; if (!value) { this.$input.value = this.format; } else { this.$input.value = (0,datetime.formatDateTime)(this._value, this._format); } this._updateNullClass(); }; DateInput2.prototype._updateNullClass = function () { var value = this._value; if (!value) { this.addClass('as-value-null'); } else { this.removeClass('as-value-null'); } }; DateInput2.prototype.tokenRegex = js_DateTimeInput.prototype.tokenRegex; DateInput2.prototype._autoSelect = js_DateTimeInput.prototype._autoSelect; DateInput2.prototype._tokenAt = js_DateTimeInput.prototype._tokenAt; DateInput2.prototype._editNextToken = js_DateTimeInput.prototype._editNextToken; DateInput2.prototype._editPrevToken = js_DateTimeInput.prototype._editPrevToken; DateInput2.prototype._makeTokenDict = js_DateTimeInput.prototype._makeTokenDict; DateInput2.prototype._correctingInput = function () { var tkDict = this._makeTokenDict(this.$text.value); var min = this._min; var max = this._max; var equalMin; var equalMax; if (tkDict.y && !isNaN(tkDict.y.value)) { tkDict.y.value = Math.max(min.getFullYear(), Math.min(max.getFullYear(), tkDict.y.value)); equalMin = tkDict.y.value === min.getFullYear(); equalMax = tkDict.y.value === max.getFullYear(); } else { equalMin = false; equalMax = false; } if (tkDict.M && !isNaN(tkDict.M.value)) { tkDict.M.value = Math.max(1, Math.min(12, tkDict.M.value)); if (equalMin) { tkDict.M.value = Math.max(min.getMonth() + 1, tkDict.M.value); equalMin = tkDict.M.value === min.getMonth() + 1; } if (equalMax) { tkDict.M.value = Math.min(max.getMonth() + 1, tkDict.M.value); equalMax = max.getMonth() + 1; } } else { equalMin = false; equalMax = false; } if (tkDict.d && !isNaN(tkDict.d.value)) { tkDict.d.value = Math.max(1, Math.min(31, tkDict.d.value)); if (tkDict.M && !isNaN(tkDict.M.value)) { tkDict.d.value = Math.min(tkDict.d.value, (0,datetime.daysInMonth)((!tkDict.y ||isNaN(tkDict.y.value) )? 2020 : tkDict.y.value, tkDict.M.value - 1)); } if (equalMin) { tkDict.d.value = Math.max(min.getDate(), tkDict.d.value); } if (equalMax) { tkDict.d.value = Math.min(max.getDate(), tkDict.d.value); } } if (tkDict.w && !isNaN(tkDict.w.value)) { if (tkDict.y && !isNaN(tkDict.y.value)) { tkDict.w.value = Math.max(1, Math.min(tkDict.w.value, 1 + (0,datetime.weekIndexOf)((0,datetime.prevDate)(new Date(tkDict.y.value + 1, 0, 1)), false, this._startDayOfWeek))); } } this.$text.value = this._applyTokenDict(this._format, tkDict); }; DateInput2.prototype._correctingCurrentToken = function () { var token = this._tokenAt(this.$text.selectionStart); if (!token) return; var value; value = parseInt(token.text); var rqMin = { d: 1, dd: 1, M: 1, MM: 1, y: 1890, yyyy: 1890, w: 1, ww: 1, Q: 1, QQ: 1 }[token.ident]; var rqMax = { d: 31, dd: 31, M: 12, MM: 12, y: 2089, yyyy: 2089, w: 54, ww: 54, Q: 4, QQ: 4 }[token.ident]; if (rqMin !== undefined) { if (!isNaN(value)) { if ((value < rqMin || value > rqMin)) { value = Math.max(rqMin, Math.min(rqMax, value)); token.replace((0,utils.zeroPadding)(value, token.ident.length), false); } } else if (this.notNull) { if (token.ident.startsWith('y')) { value = new Date().getFullYear(); } else { value = rqMin; } token.replace((0,utils.zeroPadding)(value, token.ident.length), false); } else if (token.text !== token.ident) { token.replace(token.ident, false); } } }; /*** * * @param {Date|string|null}date * @return {Date|null} */ DateInput2.prototype._normalizeValue = function (date) { var temp; if (date === null || date === undefined || date === false) { return null; } if (typeof date === 'string') { temp = new Date(date); if (isNaN(temp.getTime())) { temp = (0,datetime.parseDateTime)(date, this._format); } date = temp; } else if (typeof date === 'number') { date = new Date(date); } if (date.getTime && date.getHours) { if (isNaN(date.getTime())) { return null; } else { return (0,datetime.beginOfDay)(date); } } else { return null; } }; DateInput2.prototype._loadValueFromInput = function () { var tkDict = this._makeTokenDict(this.$text.value); var y = tkDict.y ? tkDict.y.value : new Date().getFullYear(); var m = tkDict.M ? tkDict.M.value - 1 : 0; var d = tkDict.d ? tkDict.d.value : 1; var date; if (tkDict.w && tkDict.y) { if ((0,utils.isRealNumber)(tkDict.w.value) && (0,utils.isRealNumber)(tkDict.y.value)) date = (0,datetime.weekInYear)(y, tkDict.w.value - 1); } else if (tkDict.Q && tkDict.y) { if ((0,utils.isRealNumber)(tkDict.Q.value) && (0,utils.isRealNumber)(tkDict.y.value)) date = new Date(y, (tkDict.Q.value - 1) * 3, 1); } else { date = new Date(y, m, d); } if (!date || isNaN(date.getTime())) { this._value = null; } else { this._value = date; } this._updateNullClass(); }; DateInput2.prototype._explicit = function (value) { value = value || null; if (this.notNull) { value = value || new Date(); } else if (!value) return null; var time = value.getTime(); time = Math.max(this._min.getTime(), time); time = Math.min(this._max.getTime(), time); return dateByLevel((0,datetime.beginOfDay)(new Date(time)), this.calendarLevel); }; DateInput2.prototype._applyTokenDict = function (format, dict, debug) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var tokenMap = this.tokenMap; var res = format.replace(rgx, function (full, g1, g2, sourceText) { if (g1 && tokenMap[g1]) { var ident = tokenMap[g1]; if (dict[ident] && !isNaN(dict[ident].value)) { return (0,utils.zeroPadding)(dict[ident].value, g1.length); } else { return full; } } else return full; }); return res; }; DateInput2.prototype.focus = function () { this.$text.focus(); this.$text.select(); }; DateInput2.prototype.tokenMap = { d: 'd', dd: 'd', M: 'M', MM: 'M', y: 'y', yyyy: 'y', ww: 'w', Q: 'Q', QQ: 'Q' } /** * @type {DateInput2} */ DateInput2.eventHandler = {}; DateInput2.eventHandler.keydown = function (event) { if (this.readOnly) { if (!event.ctrlKey || event.key !== 'c') { event.preventDefault(); } return; } var token = this._tokenAt(this.$text.selectionStart); var endToken = this._tokenAt(this.$text.selectionEnd); if (!token) { if (event.key === 'Enter') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } return; } var newTokenText; var value; if (event.key.startsWith('Arrow') || event.key.match(/^[\-/,\s]$/)) { event.preventDefault(); switch (event.key) { case 'ArrowLeft': this._editPrevToken(); break; case 'ArrowRight': case '-': case ',': case '/': case ' ': this._editNextToken(); break; case 'ArrowUp': case 'ArrowDown': switch (token.ident) { case 'dd': case 'd': value = parseInt(token.text); if (isNaN(value)) { this._editingData.d = event.key === 'ArrowUp' ? 1 : 31; } else { this._editingData.d = 1 + (value + (event.key === 'ArrowUp' ? 0 : 29)) % 31; } newTokenText = '' + this._editingData.d; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'w': case 'ww': value = parseInt(token.text); if (isNaN(value)) { this._editingData.w = event.key === 'ArrowUp' ? 1 : 54; } else { this._editingData.w = 1 + (value + (event.key === 'ArrowUp' ? 0 : 52)) % 54; } newTokenText = (0,utils.zeroPadding)(this._editingData.w, token.ident.length); token.replace(newTokenText, true); break; case 'Q': case 'QQ': value = parseInt(token.text); if (isNaN(value)) { this._editingData.Q = event.key === 'ArrowUp' ? 1 : 4; } else { this._editingData.Q = 1 + (value + (event.key === 'ArrowUp' ? 0 : 2)) % 4; } newTokenText = (0,utils.zeroPadding)(this._editingData.Q, token.ident.length); token.replace(newTokenText, true); break; case 'MM': case 'M': value = parseInt(token.text) - 1; if (isNaN(value)) { this._editingData.M = event.key === 'ArrowUp' ? 0 : 11; } else { this._editingData.M = (value + (event.key === 'ArrowUp' ? 1 : 11)) % 12; } newTokenText = '' + (this._editingData.M + 1); while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'yyyy': value = parseInt(token.text); if (isNaN(value)) { this._editingData.y = new Date().getFullYear(); } else { this._editingData.y = Math.max(1890, Math.min(2089, value + (event.key === 'ArrowUp' ? 1 : -1))); } newTokenText = this._editingData.y + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; } } } else if (event.key === "Delete" || event.key === 'Backspace') { event.preventDefault(); if (endToken.idx !== token.idx) { if (this.notNull) { this.$text.value = (0,datetime.formatDateTime)(new Date(Math.min(this.max.getTime(), Math.max(this.min.getTime(), new Date().getTime()))), this._format); } else { this.$text.value = this._format; } this.$text.select(); } else { if (this.notNull) { switch (token.ident) { case 'y': case 'yyyy': token.replace((0,utils.zeroPadding)(new Date().getFullYear(), token.ident.length), true); break; case 'w': case 'ww': case 'Q': case 'QQ': token.replace((0,utils.zeroPadding)(1, token.ident.length), true); break; case 'M': case 'MM': case 'd': case 'dd': token.replace((0,utils.zeroPadding)(1, token.ident.length), true); break; default: token.replace(token.ident, true); } } else { token.replace(token.ident, true); } if (event.key === "Delete") this._editNextToken(); else this._editPrevToken(); } } else if (event.key === "Enter" || event.key === 'Tab') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } else if (event.ctrlKey) { switch (event.key) { case 'a': case 'A': break; case 'c': case 'C': break; case 'x': case 'X': this.domSignal.once('clear_value', function () { this.$text.value = this._format; this.$text.select(); }.bind(this)); this.domSignal.emit('clear_value'); break; default: event.preventDefault(); } } else if (event.key.match(/^[0-9]$/g)) { event.preventDefault(); var dVal = parseInt(event.key); if (this._editingData.state === DateInput2_STATE_NEW) { switch (token.ident) { case 'dd': case 'd': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = DateInput2_STATE_EDITED; this._editingData.d = dVal; if (dVal > 3) { this._editNextToken(); } break; case 'w': case 'ww': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = DateInput2_STATE_EDITED; this._editingData.d = dVal; if (dVal > 6) { this._editNextToken(); } break; case 'Q': case 'QQ': dVal = Math.max(1, Math.min(dVal, 4)); token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = DateInput2_STATE_EDITED; this._editingData.Q = dVal; this._editNextToken(); break; case 'MM': case 'M': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = DateInput2_STATE_EDITED; this._editingData.M = dVal; if (dVal > 1) { this._editNextToken(); } break; case 'yyyy': case 'y': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = DateInput2_STATE_EDITED; this._editingData.state_num = 1; break; } } else { switch (token.ident) { case 'dd': case 'd': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(31, dVal)); this._editingData.d = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'ww': case 'w': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(54, dVal)); this._editingData.d = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'Q': case 'QQ': dVal = Math.max(1, Math.min(dVal, 4)); token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.Q = dVal; this._editNextToken(); break; case 'MM': case 'M': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(12, dVal)); this._editingData.M = dVal - 1; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'yyyy': case 'y': dVal = (parseInt(token.text.replace(/^./, '')) || 0) * 10 + dVal; this._editingData.state_num++; if (this._editingData.state_num >= 4) { // dVal = Math.max(1890, Math.min(2089, dVal)); token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); } else { token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); } break; } } } else { event.preventDefault(); } }; DateInput2.eventHandler.mouseUpInput = js_DateTimeInput.eventHandler.mouseUpInput; DateInput2.eventHandler.mouseDownInput = js_DateTimeInput.eventHandler.mouseDownInput; DateInput2.eventHandler.dblclickInput = js_DateTimeInput.eventHandler.dblclickInput; DateInput2.eventHandler.inputBlur = js_DateTimeInput.eventHandler.inputBlur; DateInput2.eventHandler.calendarSelect = function (value) { var oldV = this._explicit(this._lastValue); this.value = value; var newV = this._explicit(this._value); if (!oldV !== !newV || (oldV && newV && (0,datetime.compareDate)(oldV, newV) !== 0)) { this.emit('change', { type: 'change', target: this, value: this._value }, this); } }; DateInput2.eventHandler.clickCalendarBtn = function () { if (this.readOnly) return; this._attachCalendar(); }; DateInput2.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$calendar, event)) return; this._releaseCalendar(); }; DateInput2.eventHandler.calendarPick = function (event) { this._applyValue(event.value); this._notifyIfChange(event.originEvent || event); this._releaseCalendar(); }; DateInput2.property = {}; DateInput2.property.value = { set: function (value) { value = this._normalizeValue(value); if (!value && this.notNull) value = (0,datetime.beginOfDay)(new Date()); this._value = value; this._lastValue = this._explicit(this._value); this._loadTextFromValue(); }, get: function () { return this._explicit(this._value); } }; /** * not support MMM, MMMM, support number only * @type {DateInput2} */ DateInput2.property.format = { set: function (value) { value = value || 'dd/MM/yyyy'; value = value.replace(new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g'), function (full) { if (full === 'mm' || full === 'MMM' || full === 'MMMM' || full === 'mmm' || full === 'mmmm') return 'MM'; if (full === 'm') return 'M'; return full; }); if (!this._verifyFormat(value)) { value = 'dd/MM/yyyy'; console.error("Invalid date format: " + value); } this._format = value; this._formatTokens = this._format.match(new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g')) || []; this.value = this.value;//update var testData = new Date(2000, 9, 22, 12, 12, 22, 335); testData = (0,datetime.formatDateTime)(testData, value); this.addStyle('--format-width', Math.ceil((0,utils.measureText)(testData.replace(/[a-z0-9]/g, 'M'), '14px arial').width / 14 * 2) / 2 + 'em'); this.attr('data-format', value); }, get: function () { return this._format; } }; DateInput2.property.disabled = { set: function (value) { value = !!value; this.$input.disabled = value; if (value) this.addClass('as-disabled'); else this.removeClass('as-disabled'); this.$text.disabled = value; }, get: function () { return this.$input.disabled; } }; DateInput2.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); this.$input.readOnly = true; } else { this.removeClass('as-read-only'); this.$input.readOnly = false; } }, get: function () { return this.hasClass('as-read-only'); } }; DateInput2.property.text = { get: function () { return this.$input.value; } }; DateInput2.property.calendarLevel = { /*** * @memberOf DateInput2 * @name calendarLevel * @type {number} */ get: function () { if (this._formatTokens.indexOf('d') >= 0 || this._formatTokens.indexOf('dd') >= 0) return 'day'; if (this._formatTokens.indexOf('w') >= 0 || this._formatTokens.indexOf('ww') >= 0) return 'week'; if (this._formatTokens.indexOf('M') >= 0 || this._formatTokens.indexOf('MM') >= 0) return 'month'; if (this._formatTokens.indexOf('Q') >= 0 || this._formatTokens.indexOf('QQ') >= 0) return 'quarter'; return 'year'; } }; DateInput2.property.min = { set: function (value) { this._min = this._normalizeValue(value) || new Date(1890, 0, 1); this._lastValue = this._explicit(this._value); this._applyValue(this._lastValue); }, get: function () { return this._min; } }; DateInput2.property.max = { set: function (value) { this._max = this._normalizeValue(value) || new Date(2090, 0, 1); this._lastValue = this._explicit(this._value); this._applyValue(this._lastValue); }, get: function () { var max = this._max; var min = this.min; if ((0,datetime.compareDate)(min, max) > 0) return min; return max; } }; DateInput2.property.notNull = { set: function (value) { if (value) { this.addClass('as-must-not-null'); if (!this.value) this.value = new Date(); } else { this.removeClass('as-must-not-null'); } this.value = this.value;//update }, get: function () { return this.hasClass('as-must-not-null'); } }; DateInput2.prototype.share = { /*** * @type {ChromeCalendar} */ $calendar: null, /*** * @type {Follower} */ $follower: null, /*** * @type {DateInput2} */ $holdingInput: null }; DateInput2.prototype._prepareCalendar = function () { if (this.share.$calendar) return; this.share.$calendar = DateInput2_({ tag: 'chromecalendar', class: ['as-date-input-calendar', 'as-dropdown-box-common-style'] }); if (this.share.$calendar.$attachHook) this.share.$calendar.$attachHook.cancelWaiting(); this.share.$follower = DateInput2_({ tag: 'follower', class: 'as-date-input-follower', child: this.share.$calendar }); this.share.$follower.cancelWaiting(); }; DateInput2.prototype._attachCalendar = function () { this._prepareCalendar(); if (this.share.$holdingInput) this.share.$holdingInput._releaseCalendar(); this.share.$follower.addTo(document.body); this.share.$follower.addStyle('visibility', 'hidden'); this.share.$holdingInput = this; this.share.$follower.followTarget = this; this.share.$follower.sponsorElement = this; this.share.$calendar.level = this.calendarLevel; this.share.$calendar.startDayOfWeek = this.startDayOfWeek || 0; this.share.$calendar.min = this._min; this.share.$calendar.max = this._max; this.share.$calendar.on('pick', this.eventHandler.calendarPick); this.share.$calendar.selectedDates = this.value ? [this.value] : []; if (this.share.$calendar.$attachHook) this.share.$calendar.$attachHook.emit('attached'); this.share.$calendar.sync = this.share.$calendar.sync.then(() => { this.share.$calendar.viewDate = this.value ? this.value : new Date(Math.max(this._min.getTime(), Math.min(this._max.getTime(), new Date().getTime()))); }); setTimeout(function () { document.body.addEventListener('click', this.eventHandler.clickOut); this.share.$follower.removeStyle('visibility'); }.bind(this), 5); this.$calendarBtn.off('click', this.eventHandler.clickCalendarBtn); }; DateInput2.prototype._releaseCalendar = function () { if (this.share.$holdingInput !== this) return; this.share.$calendar.off('pick', this.eventHandler.calendarPick); this.share.$follower.remove(); document.body.removeEventListener('click', this.eventHandler.clickOut); setTimeout(function () { this.$calendarBtn.on('click', this.eventHandler.clickCalendarBtn); }.bind(this), 5) this.share.$holdingInput = null; }; ACore/* default.install */.Z.install(DateInput2); /* harmony default export */ const js_DateInput2 = (DateInput2); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/draggablestack.css var draggablestack = __webpack_require__(5166); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Hanger.js var Hanger = __webpack_require__(655); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Vec2.js var Vec2 = __webpack_require__(557); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PositionTracker.js /*** * @extends {AElement} * @constructor */ function PositionTracker() { this.defineEvent('positionchange'); this.$trackScrollParents = []; this._scrollTrackEventHandler = this.notifyPositionChange.bind(this); } PositionTracker.tag = 'PositionTracker'.toLowerCase(); /*** * * @return {AElement} */ PositionTracker.render = function () { return (0,ACore._)('div'); }; PositionTracker.prototype.notifyPositionChange = function (event) { this.emit('positionchange', { type: 'positionchange', originEvent: event }); }; PositionTracker.prototype.startTrackPosition = function () { if (this.$trackScrollParents.length > 0) this.stopTrackPosition(); var trackElt = this; while (trackElt) { if (trackElt.addEventListener) trackElt.addEventListener('scroll', this._scrollTrackEventHandler, false); else trackElt.attachEvent('onscroll', this._scrollTrackEventHandler, false); this.$trackScrollParents.push(trackElt); trackElt = trackElt.parentElement; } if (document.addEventListener) { document.addEventListener('scroll', this._scrollTrackEventHandler, false); } else { document.attachEvent('onscroll', this._scrollTrackEventHandler, false); } this.$trackScrollParents.push(document); }; PositionTracker.prototype.stopTrackPosition = function () { var trackElt; for (var i = 0; i < this.$trackScrollParents.length; ++i) { trackElt = this.$trackScrollParents[i]; if (trackElt.removeEventListener) trackElt.removeEventListener('scroll', this._scrollTrackEventHandler, false); else trackElt.dettachEvent('onscroll', this._scrollTrackEventHandler, false); } this.$trackScrollParents = []; }; ACore/* default.install */.Z.install(PositionTracker); /* harmony default export */ const js_PositionTracker = (PositionTracker); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Rectangle.js var Rectangle = __webpack_require__(2759); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DraggableVStack.js var DraggableVStack_ = ACore/* default._ */.Z._; var DraggableVStack_$ = ACore/* default.$ */.Z.$; /*** * @augments Hanger * @augments PositionTracker * @constructor */ function DraggableVStack() { DraggableVStack_({ tag: 'PositionTracker'.toLowerCase(), elt: this }); this.$cloneContainer = DraggableVStack_('.absol-draggable-stack-clone-container'); this.on('predrag', this.eventHandler.predrag) .on('dragstart', this.eventHandler.dragstart) .on('drag', this.eventHandler.drag) .on('dragend', this.eventHandler.dragend); this._state = 0; this.friends = []; this.$friends = []; this._privateDraggableVStackIdent = (0,stringGenerate.randomIdent)(35); this._dragData = null; this.on('positionchange', this.eventHandler.scroll); } DraggableVStack.tag = 'DraggableVStack'.toLowerCase(); DraggableVStack.render = function () { return DraggableVStack_({ tag: 'hanger', extendEvent: ['change', 'orderchange', 'itemleave', 'itementer'], class: ['absol-draggable-stack', 'absol-draggable-vstack'] }); }; DraggableVStack.prototype._updateFriends = function () { var dict = {}; dict[this._privateDraggableVStackIdent] = this; this.$friends = this.friends.reduce(function (ac, cr) { if (Dom/* default.isDomNode */.ZP.isDomNode(cr)) { if (cr._privateDraggableVStackIdent) { ac.result.push(cr); ac.dict[cr._privateDraggableVStackIdent] = cr; } } else if (typeof cr === 'string') { DraggableVStack_$(cr, false, function (elt) { if (elt._privateDraggableVStackIdent) { if (!ac.dict[elt._privateDraggableVStackIdent]) { ac.result.push(elt); ac.dict[elt._privateDraggableVStackIdent] = elt; } } }) } return ac; }, { dict: dict, result: [] }).result; }; DraggableVStack.prototype._findIndex = function (clientY) { var childBounds = Array.prototype.map.call(this.childNodes, function (elt) { return elt.getBoundingClientRect() }); var childTops = childBounds.map(function (b) { return b.top; }); childTops.push((childBounds[childBounds.length - 1] || this.getBoundingClientRect()).bottom); var nearestIdx = 0; var nearestVal = 10000000; var val; for (var i = 0; i < childTops.length; ++i) { val = Math.abs(clientY - childTops[i]); if (val < nearestVal) { nearestVal = val; nearestIdx = i; } } return nearestIdx; }; /*** * * @type {DraggableVStack|{}} */ DraggableVStack.eventHandler = {}; DraggableVStack.eventHandler.predrag = function (event) { var dragzone = this._findDragzone(event.target); if (!dragzone) { event.cancel(); } }; DraggableVStack.eventHandler.dragstart = function (event) { this.startTrackPosition(); event.preventDefault(); this._updateFriends(); this._state = 1; this.addClass('as-state-drag'); this._dragData = { mouseStartPos: new Vec2/* default */.Z(event.clientX, event.clientY), elt: this._findDirectChild(event.target), rootBound: this.getBoundingClientRect(), dest: this }; this._dragData.mouseCurrentPos = this._dragData.mouseStartPos; this._updateDestChildrenBound(); this._dragData.idx = Array.prototype.indexOf.call(this.childNodes, this._dragData.elt); this._dragData.eltBound = this._dragData.destChildBounds[this._dragData.idx]; this._dragData.offsetPos = this._dragData.mouseStartPos.sub(new Vec2/* default */.Z(this._dragData.eltBound.left, this._dragData.eltBound.top)); this._dragData.eltRelative = new Vec2/* default */.Z(this._dragData.eltBound.left, this._dragData.eltBound.top).sub(new Vec2/* default */.Z(this._dragData.rootBound.left, this._dragData.rootBound.top)); this.$cloneContainer.addTo(document.body); this.$cloneContainer.clearChild().addChild(DraggableVStack_$(this._dragData.elt.cloneNode(true)).addStyle({ boxSizing: 'border-box', width: this._dragData.eltBound.width + 'px', height: this._dragData.eltBound.height + 'px' })); this.$cloneContainer.addStyle({ left: this._dragData.eltBound.left + 'px', top: this._dragData.eltBound.top + 'px', }); this._dragData.elt.addClass('dragging'); }; DraggableVStack.eventHandler.drag = function (event) { event.preventDefault(); this._dragData.mouseCurrentPos = new Vec2/* default */.Z(event.clientX, event.clientY); this._updateHoverDest(); this._updateDraggingPosition(); this.eventHandler.dragOverflow(event); }; DraggableVStack.prototype.getClientY = function () { var top = 1000000; var bottom = -10000000; var child; var childBound; for (var i = 0; i < this.childNodes.length; ++i) { child = this.childNodes[i]; if (child === this.$cloneContainer) continue; if (child.getBoundingClientRect) { childBound = child.getBoundingClientRect(); top = Math.min(top, childBound.top); bottom = Math.max(bottom, childBound.bottom); } } return { top: top, bottom: bottom }; }; DraggableVStack.eventHandler.dragOverflow = function (event) { var scroller = this; while (scroller) { var overflowStyle = window.getComputedStyle(scroller)['overflow']; if ((overflowStyle === 'auto' || overflowStyle === 'scroll' || scroller.tagName === 'HTML') && (scroller.clientHeight < scroller.scrollHeight)) break; scroller = scroller.parentElement; } if (!scroller) return; var outBound = scroller.getBoundingClientRect(); var bBound = this.$cloneContainer.getBoundingClientRect(); var screenSize = Dom/* default.getScreenSize */.ZP.getScreenSize(); if (scroller.tagName !== "HTML") { outBound = { top: Math.max(outBound.top, 0), bottom: Math.min(outBound.bottom, screenSize.height) } } else { outBound = { top: 0, bottom: screenSize.height } } var vy = 0; if (bBound.top < outBound.top) { vy = bBound.top - outBound.top; } else if (bBound.bottom > outBound.bottom) { vy = bBound.bottom - outBound.bottom; } var dt = 1 / 30; if (vy !== 0) { var copyEvent = { type: event.type, preventDefault: function () {/* noop */ }, target: event.target }; copyEvent.clientX = event.clientX; copyEvent.clientY = event.clientY var thisBT = this; setTimeout(function () { if (scroller.scrollHeight > scroller.clientHeight) { scroller.scrollTop += (0,utils.absCeil)(vy * dt); } if (thisBT._state === 1) { thisBT.eventHandler.dragOverflow(copyEvent); } }, dt * 1000); } }; DraggableVStack.eventHandler.scroll = function (event) { this._updateDraggingPosition(); }; DraggableVStack.eventHandler.dragend = function (event) { this.stopTrackPosition(); event.preventDefault(); this._dragData.dest.removeClass('as-state-drag'); this.$cloneContainer.remove(); this._dragData.elt.removeClass('dragging'); this.removeClass('as-state-no-change'); this._state = 0; var beforeElt; if (this._dragData.dest === this) { if (this._dragData.idx === this._dragData.destIdx || (this._dragData.idx + 1 === this._dragData.destIdx)) { //todo } else { if (this._dragData.destIdx === this.childNodes.length) { this._dragData.elt.remove(); this.addChild(this._dragData.elt); this.emit('change', { type: 'change', fromStack: this, toStack: this, elt: this._dragData.elt, sourceIndex: this._dragData.idx, destIndex: this.childNodes.length, oldIdx: this._dragData.idx, newIdx: this.childNodes.length - 1, desc: "Move element to end of stack." }, this); this.emit('orderchange', { type: 'orderchange', fromStack: this, toStack: this, elt: this._dragData.elt, oldIdx: this._dragData.idx, newIdx: this.childNodes.length - 1, desc: "Move element to end of stack." }, this); } else { beforeElt = this.childNodes[this._dragData.destIdx]; this._dragData.elt.remove(); this.addChildBefore(this._dragData.elt, beforeElt); this.emit('change', { type: 'change', fromStack: this, toStack: this, elt: this._dragData.elt, sourceIndex: this._dragData.idx, destIndex: this._dragData.destIdx, oldIdx: this._dragData.idx, newIdx: this._dragData.destIdx > this._dragData.idx ? this._dragData.destIdx - 1 : this._dragData.destIdx, desc: "Move element to before this.childNodes[" + this._dragData.destIdx + "]" }, this); this.emit('orderchange', { type: 'orderchange', fromStack: this, toStack: this, elt: this._dragData.elt, oldIdx: this._dragData.idx, newIdx: this._dragData.destIdx > this._dragData.idx ? this._dragData.destIdx - 1 : this._dragData.destIdx, desc: "Move element to before this.childNodes[" + this._dragData.destIdx + "]" }, this); } } } else { if (this._dragData.destIdx === this._dragData.dest.childNodes.length) { this.emit('orderchange', { type: 'itemleave', fromStack: this, toStack: this._dragData.dest, oldIdx: this._dragData.idx, newIdx: this.childNodes.length - 1, desc: "Move element to end of friend stack." }, this); this._dragData.elt.remove(); this._dragData.dest.addChild(this._dragData.elt); this._dragData.dest.emit('orderchange', { type: 'itementer', fromStack: this, toStack: this._dragData.dest, oldIdx: this._dragData.idx, newIdx: this.childNodes.length - 1, desc: "Move element to end of friend stack." }, this._dragData.dest); this.emit('change', { type: 'change', fromStack: this, toStack: this._dragData.dest, elt: this._dragData.elt, sourceIndex: this._dragData.idx, destIndex: this.childNodes.length, oldIdx: this._dragData.idx, newIdx: this.childNodes.length - 1, desc: "Move element to end of friend stack." }); } else { beforeElt = this._dragData.dest.childNodes[this._dragData.destIdx]; this._dragData.elt.remove(); this.emit('itemleave', { type: 'itemleave', fromStack: this, toStack: this._dragData.dest, elt: this._dragData.elt, oldIdx: this._dragData.idx, newIdx: this._dragData.destIdx, desc: "Move element to before friend.childNodes[" + this._dragData.destIdx + "]" }, this); this._dragData.dest.addChildBefore(this._dragData.elt, beforeElt); this._dragData.dest.emit('itementer', { type: 'itementer', fromStack: this, toStack: this._dragData.dest, elt: this._dragData.elt, oldIdx: this._dragData.idx, newIdx: this._dragData.destIdx, desc: "Move element to before friend.childNodes[" + this._dragData.destIdx + "]" }, this._dragData.dest); this.emit('change', { type: 'change', fromStack: this, toStack: this._dragData.dest, elt: this._dragData.elt, sourceIndex: this._dragData.idx, destIndex: this._dragData.destIdx, oldIdx: this._dragData.idx, newIdx: this._dragData.destIdx, desc: "Move element to before friend.childNodes[" + this._dragData.destIdx + "]" }, this); } } }; DraggableVStack.prototype._updateDestChildrenBound = function () { var top0 = this._dragData.dest.getBoundingClientRect().top; this._dragData.destChildBounds = Array.prototype.map.call(this._dragData.dest.childNodes, function (elt) { return elt.getBoundingClientRect() }); this._dragData.destChildTops = this._dragData.destChildBounds.map(function (bound) { return bound.top - top0; }).concat([(this._dragData.destChildBounds[this._dragData.destChildBounds.length - 1] || this.getBoundingClientRect()).bottom - top0]); } DraggableVStack.prototype._updateHoverDest = function () { var bound; var newDest; var friendElt; var friendList = this.$friends.concat([this]); var top0; for (var i = 0; i < friendList.length; ++i) { friendElt = friendList[i]; bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(friendElt.getBoundingClientRect()); if (bound.containsPoint(this._dragData.mouseCurrentPos)) { top0 = bound.y; newDest = friendElt; break; } } if (newDest && this._dragData.dest !== newDest) { this._dragData.dest.removeClass('as-state-drag'); this._dragData.dest = newDest; this._dragData.dest.addClass('as-state-drag'); this._dragData.dest.addStyle('--dest-y', 'unset'); this._updateDestChildrenBound(); } }; DraggableVStack.prototype._updateDraggingPosition = function () { var bound = this.getBoundingClientRect(); var clonePos = this._dragData.mouseCurrentPos.sub(this._dragData.offsetPos); this.$cloneContainer.addStyle({ top: clonePos.y + 'px', left: bound.left + 'px' }); this._dragData.destIdx = this._dragData.dest._findIndex(clonePos.y + this._dragData.eltBound.height / 2); this._dragData.dest.addStyle('--dest-y', this._dragData.destChildTops[this._dragData.destIdx] + 'px'); if (this._dragData.dest === this) { if (this._dragData.idx === this._dragData.destIdx || (this._dragData.idx + 1 === this._dragData.destIdx)) { this.addClass('as-state-no-change'); } else { this.removeClass('as-state-no-change'); } } }; DraggableVStack.prototype._autoScrollParentIfNeed = function (delta) { //todo: choose which element should be scroll if (!(delta > 0)) delta = 10000; var bound = this.getBoundingClientRect(); var cloneBound = this.$cloneContainer.getBoundingClientRect(); var outBound = Dom/* default.traceOutBoundingClientRect */.ZP.traceOutBoundingClientRect(this.$cloneContainer); if (outBound.bottom >= cloneBound.bottom && outBound.top <= cloneBound.top) return; var scrollables = []; var current = this; while (current) { var oy = window.getComputedStyle(current); oy = oy['overflow-y'] || oy['overflowY']; if (oy == 'auto' || oy == 'scroll') { scrollables.push(current); } current = current.parentElement; } scrollables.push(document.body.parentElement); }; DraggableVStack.prototype._findDragzone = function (elt) { var result = null; while (elt && elt != this) { if (elt.classList && elt.classList.contains('drag-zone')) { result = elt; break; } elt = elt.parentNode; } if (result) { elt = result; while (elt && elt != this) { if (elt.classList && (elt.classList.contains('absol-draggable-stack'))) { result = null; break; } elt = elt.parentNode; } } return result; }; DraggableVStack.prototype._findDirectChild = function (elt) { while (elt && elt != this) { if (elt.parentNode == this) return elt; elt = elt.parentNode; } return undefined; }; DraggableVStack.property = {}; DraggableVStack.property.friends = { set: function (value) { if (!(value instanceof Array)) value = [value]; this._friends = value; }, get: function () { return this._friends; } }; ACore/* default.install */.Z.install(DraggableVStack); /* harmony default export */ const js_DraggableVStack = (DraggableVStack); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DraggableHStack.js var DraggableHStack_ = ACore/* default._ */.Z._; var DraggableHStack_$ = ACore/* default.$ */.Z.$; /*** * @augments DraggableVStack * @augments PositionTracker * @constructor */ function DraggableHStack() { this._dragData = null; this.$cloneContainer = DraggableHStack_('.absol-draggable-stack-clone-container'); this.on('predrag', this.eventHandler.predrag) .on('dragstart', this.eventHandler.dragstart) .on('drag', this.eventHandler.drag) .on('dragend', this.eventHandler.dragend); DraggableHStack_({ elt: this, tag: js_PositionTracker }) .on('positionchange', this._updateDraggingPosition.bind(this)); } DraggableHStack.tag = "DraggableHStack".toLowerCase(); DraggableHStack.render = function () { return DraggableHStack_({ tag: 'hanger', extendEvent: 'change', class: ['absol-draggable-stack', 'absol-draggable-hstack'] }); }; /*** * * @param {Rectangle} rect * @returns {number} * @private */ DraggableHStack.prototype._findDropIdx = function (rect) { if (!this._dragData) return -1; var centerX = rect.x + rect.width / 2; var currentBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.getBoundingClientRect()); var nearestDistance = Math.abs(centerX - currentBound.width);//end of stack var cDist; var nearestIndex = this._dragData.childBounds.length; var childX; for (var i = 0; i < this._dragData.childBounds.length; ++i) { childX = this._dragData.childBounds[i].x + currentBound.x - this._dragData.bound.x; cDist = Math.abs(centerX - childX); if (cDist < nearestDistance) { nearestDistance = cDist; nearestIndex = i; } } return nearestIndex; }; /*** * * @type {DraggableHStack|{}} */ DraggableHStack.eventHandler = {}; DraggableHStack.eventHandler.predrag = js_DraggableVStack.eventHandler.predrag; DraggableHStack.eventHandler.dragstart = function (event) { this.addClass('as-has-dragging'); this.startTrackPosition(); var mousePos = new Vec2/* default */.Z(event.clientX, event.clientY); var elt = this._findDirectChild(event.target); var childBounds = Array.prototype.map.call(this.childNodes, function (e) { return Rectangle/* default.fromClientRect */.Z.fromClientRect(e.getBoundingClientRect()); }); var eltIdx = Array.prototype.indexOf.call(this.childNodes, elt); var eltBound = childBounds[eltIdx]; var eltMouseOffset = mousePos.sub(new Vec2/* default */.Z(eltBound.x, eltBound.y)); this._dragData = { mouseStartPos: mousePos, mousePos: mousePos, bound: Rectangle/* default.fromClientRect */.Z.fromClientRect(this.getBoundingClientRect()), childBounds: childBounds, elt: elt, eltIdx: eltIdx, eltBound: eltBound, eltMouseOffset: eltMouseOffset }; this.$cloneContainer.addStyle({ left: eltBound.x + 'px', top: eltBound.y + 'px', width: eltBound.width + 'px', height: eltBound.height + 'px', }).clearChild() .addChild(DraggableHStack_$(elt.cloneNode(true))) .addTo(document.body); elt.addClass('as-dragging'); this._updateDraggingPosition(); }; DraggableHStack.eventHandler.drag = function (event) { event.preventDefault(); this._dragData.mousePos = new Vec2/* default */.Z(event.clientX, event.clientY); this._updateDraggingPosition(); }; DraggableHStack.eventHandler.dragend = function (event) { var thisS = this; this.stopTrackPosition(); this.removeClass('as-has-dragging'); this._dragData.elt.removeClass('as-dragging'); if (this._dragData.destIdx == this._dragData.eltIdx || this._dragData.destIdx == this._dragData.eltIdx + 1) { this.$cloneContainer.addClass('as-home-going'); this._updateDraggingPosition(); setTimeout(function () { thisS.$cloneContainer.selfRemove() .removeClass('as-home-going'); }, 100); } else { if (this._dragData.destIdx === this._dragData.childBounds.length) { this._dragData.elt.remove(); this.addChild(this._dragData.elt); this.emit('change', { type: 'change', elt: this._dragData.elt, sourceIndex: this._dragData.eltIdx, destIndex: this._dragData.childBounds.length, oldIdx: this._dragData.eltIdx, newIdx: this._dragData.childBounds.length - 1, desc: "Move element to end of stack." }, this); } else { var beforeElt = this.childNodes[this._dragData.destIdx]; this._dragData.elt.remove(); this.addChildBefore(this._dragData.elt, beforeElt); this.emit('change', { type: 'change', elt: this._dragData.elt, sourceIndex: this._dragData.eltIdx, destIndex: this._dragData.destIdx, oldIdx: this._dragData.eltIdx, newIdx: this._dragData.destIdx > this._dragData.eltIdx ? this._dragData.destIdx - 1 : this._dragData.destIdx, desc: "Move element to before this.childNodes[" + this._dragData.destIdx + "]" }, this); } this.$cloneContainer.selfRemove() .removeClass('as-home-going'); } this.removeClass('as-no-change'); }; DraggableHStack.prototype._findDragzone = js_DraggableVStack.prototype._findDragzone; DraggableHStack.prototype._findDirectChild = js_DraggableVStack.prototype._findDirectChild; DraggableHStack.prototype._updateDraggingPosition = function () { var bound = this.getBoundingClientRect(); var x, y; if (this.$cloneContainer.hasClass('as-home-going')) { x = this._dragData.eltBound.x - this._dragData.bound.x + bound.left; y = this._dragData.eltBound.y - this._dragData.bound.y + bound.top; } else { y = bound.top + (this._dragData.eltBound.y - this._dragData.bound.y); var newPos = this._dragData.mousePos.sub(this._dragData.eltMouseOffset); x = newPos.x; } this.$cloneContainer.addStyle({ left: x + 'px', top: y + 'px' }); var cBound = this._dragData.eltBound.clone(); cBound.x = x; cBound.y = y; var destIdx = this._findDropIdx(cBound); this._dragData.destIdx = destIdx; var destX; if (destIdx >= this._dragData.childBounds.length) { var lastRect = this._dragData.childBounds[this._dragData.childBounds.length - 1]; destX = lastRect.x + lastRect.width - this._dragData.bound.x; } else { destX = this._dragData.childBounds[destIdx].x - this._dragData.bound.x; } this.addStyle('--dest-x', destX + 'px'); if (destIdx == this._dragData.eltIdx || destIdx == this._dragData.eltIdx + 1) { this.addClass('as-no-change'); } else { this.removeClass('as-no-change'); } }; ACore/* default.install */.Z.install(DraggableHStack); /* harmony default export */ const js_DraggableHStack = (DraggableHStack); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/droppanel.css var droppanel = __webpack_require__(8133); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ExpTree.js var ExpTree = __webpack_require__(2917); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DropPanel.js var DropPanel_ = ACore/* default._ */.Z._; var DropPanel_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function DropPanel() { var thisDP = this; /*** * * @type {ExpGroup} */ this.$body = DropPanel_$('.absol-drop-panel-body', this); this.$head = DropPanel_$('.absol-drop-panel-head', this) .on('click', thisDP.eventHandler.clickHead); this.$name = DropPanel_$('.absol-drop-panel-name', thisDP); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$name, 'name', 'innerHTML'); return thisDP; } DropPanel.tag = 'DropPanel'.toLowerCase(); DropPanel.render = function () { return DropPanel_({ class: 'absol-drop-panel', extendEvent: ['toggle'], child: [ { class: 'absol-drop-panel-head', child: [ 'toggler-ico', { tag: 'span', class: "absol-drop-panel-name" } ] }, { tag:'expgroup', class: ['absol-drop-panel-body', 'absol-bscroller'] } ] }); }; DropPanel.eventHandler = {}; DropPanel.eventHandler.clickHead = function (event) { if (!this._childOfButton(event.target)) { var event = { target: this, isShowed: this.show, preventDefault: function () { this.prevented = true; } }; this.emit('toggle', event, this); if (!event.prevented) { this.toggle(); } } }; ['findChildBefore', 'findChildAfter', 'removeChild', 'clearChild', 'addChild'] .forEach(function (key) { DropPanel.prototype[key] = function () { this.$body[key].apply(this.$body, arguments); } }); DropPanel.prototype._childOfButton = function (elt) { while (elt && elt != this) { if (elt.tagName == "BUTTON") { return true; } elt = elt.parentElement } return false; }; DropPanel.prototype.toggle = function () { this.show = !this.show; }; DropPanel.property = {}; DropPanel.property.show = { set: function (value) { if (value) { var maxHeight = parseFloat(this.getComputedStyleValue('max-height').replace('px', '')); var headBound = this.$head.getBoundingClientRect(); if (maxHeight != 'none' && maxHeight != 'auto') { this.$body.addStyle('max-height', maxHeight - headBound.height + 'px'); } this.$body.addStyle('height', this.$body.scrollHeight + 'px'); setTimeout(function () { this.$body.removeStyle('height'); window.dispatchEvent(new Event('resize')); }.bind(this), 200); this.addClass('show'); } else { this.$body.addStyle('height', this.$body.scrollHeight + 'px'); setTimeout(function () { this.$body.addStyle('height', '0'); }.bind(this), 0); setTimeout(function () { this.$body.removeStyle('height'); window.dispatchEvent(new Event('resize')); }.bind(this), 200); this.removeClass('show'); } }, get: function () { return this.hasClass('show'); } }; ACore/* default.install */.Z.install(DropPanel); /* harmony default export */ const js_DropPanel = (DropPanel); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DropPanelStack.js var DropPanelStack_ = ACore/* default._ */.Z._; var DropPanelStack_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function DropPanelStack() { var res = this; this.$attachHook = DropPanelStack_('attachhook').on('error', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.updateSize = res.updateSize.bind(res); }); this.sync = new Promise(function (rs) { res.$attachHook.once('error', rs); }); } DropPanelStack.tag = 'DropPanelStack'.toLowerCase(); DropPanelStack.render = function () { return DropPanelStack_({ class: 'absol-drop-panel-stack', child: ['attachhook'] }); }; DropPanelStack.prototype.updateSize = function () { }; DropPanelStack.prototype.getFreeHeight = function () { var childNodes = this.childNodes; var sumHeight = 0; var bound = this.getBoundingClientRect(); var childBound; for (var i = 0; i < childNodes.length; ++i) { var child = childNodes[i]; if (child.hasClass && child.hasClass('absol-drop-panel')) { childBound = child.getBoundingClientRect(); sumHeight += childBound.height; } } return bound.height - sumHeight; }; DropPanelStack.prototype.addChild = function (child) { var self = this; if (child.hasClass('absol-drop-panel')) { //remove last event listener off other parent if (child.__drop_panel_toggle_listener__) { child.off('toggle', child.__drop_panel_toggle_listener__); } child.__drop_panel_toggle_listener__ = function (event) { event.preventDefault(); self.sync = self.sync.then(function () { if (event.isShowed) { setTimeout(function () { child.removeStyle('max-height'); }, 200); child.toggle(); } else { var headBound = child.$head.getBoundingClientRect(); var vailableHeight = self.getFreeHeight(); if (vailableHeight > 3) { child.addStyle('max-height', self.getFreeHeight() + headBound.height + 'px'); child.toggle(); } } return new Promise(function (rs) { setTimeout(rs, 200); }); }) }; child.on('toggle', child.__drop_panel_toggle_listener__); this.super(child); } else { throw new Error('Child element must be a DropPanel'); } }; ACore/* default.install */.Z.install('droppanelstack', DropPanelStack); /* harmony default export */ const js_DropPanelStack = (DropPanelStack); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/editabletext.css var editabletext = __webpack_require__(4854); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EditableText.js var EditableText_ = ACore/* default._ */.Z._; var EditableText_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function EditableText() { var thisET = this; this.$span = EditableText_$('span', this); this.$text = document.createTextNode(''); this.$span.addChild(this.$text); this.$higne = EditableText_$('.absol-editabe-text-higne', this); this.$input = EditableText_$('input', this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, ['selectionStart', 'selectionEnd']); this.sync = new Promise(function (rs) { EditableText_('attachhook').addTo(thisET).once('error', rs); }); this.$input.on('keydown', this.eventHandler.inputKeyDown, true); this.$input.on('change', this.eventHandler.inputChange); this.$input.on('blur', this.eventHandler.inputBlur); }; EditableText.tag = 'EditableText'.toLowerCase(); EditableText.render = function () { return EditableText_({ class: 'absol-editabe-text', extendEvent: ['blur', 'focus', 'change', 'modify'], child: [ { class: 'absol-editabe-text-higne', child: '<input type="text">' }, 'span' ] }); }; EditableText.prototype.focus = function () { this.$input.focus(); }; EditableText.prototype.blur = function () { this.$input.blur(); }; EditableText.prototype.select = function () { this.$input.select(); }; EditableText.prototype.edit = function (flag, select) { this.editing = !!flag; this.sync = this.sync.then(function () { if (flag) { this.focus(); if (select) this.select(); } else this.blur(); }.bind(this)); return this.sync; } EditableText.prototype._update = function () { this.sync = this.sync.then(function () { return new Promise(function (rs) { // setTimeout(function () { var bound = this.getBoundingClientRect(); var higneBound = this.$higne.getBoundingClientRect(); var fsize = this.getFontSize(); this.$input.addStyle('width', bound.width + 4 + fsize * 0 + 'px'); this.$input.addStyle('height', bound.height + 4 + 'px'); this.$input.addStyle('left', bound.left - higneBound.left - 2 + 'px'); this.$input.addStyle('top', bound.top - higneBound.top + 'px'); rs(); }.bind(this)); }.bind(this)); } EditableText.property = {}; EditableText.property.text = { set: function (value) { this.$text.textContent = value; this.$input.value = value; }, get: function () { return this.$text.textContent; } } EditableText.property.editing = { set: function (value) { if (this._editting === value) return; this._editting = !!value; if (value) { this.$input.value = this.text; this._update(); this.sync = this.sync.then(function () { this.addClass('editing'); this.$input.value = this.text; this.$input.addStyle('font', this.$span.getComputedStyleValue('font')); this.$input.addStyle('font-style', this.$span.getComputedStyleValue('font-style')); this.$input.addStyle('color', this.$span.getComputedStyleValue('color')); }.bind(this)); } else { this.removeClass('editing'); } }, get: function () { return !!this._editting; } }; EditableText.eventHandler = {}; EditableText.eventHandler.inputKeyDown = function (event) { requestAnimationFrame(function () { this.text = this.$input.value; this._update(); event.text = this.text; this.emit('modify', event); }.bind(this)); }; EditableText.eventHandler.inputChange = function (event) { this.editing = false; this.emit('change', event); }; EditableText.eventHandler.inputBlur = function (event) { this.editing = false; this.emit('blur', event); }; ACore/* default.install */.Z.install(EditableText); /* harmony default export */ const js_EditableText = (EditableText); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiPicker.js var EmojiPicker = __webpack_require__(2948); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Sprite.js var Sprite = __webpack_require__(9950); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/FlexiconButton.js var FlexiconButton = __webpack_require__(3929); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/flexiconinput.css var flexiconinput = __webpack_require__(9365); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FlexiconInput.js var FlexiconInput_ = ACore/* default._ */.Z._; var FlexiconInput_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function FlexiconInput() { this.$input = FlexiconInput_$('.as-flexicon-input-text-input', this); this.$iconCtn = FlexiconInput_$('.as-flexicon-input-icon-ctn', this); this.$unitCtn = FlexiconInput_$('.as-flexicon-input-unit-ctn', this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, ['value', 'readonly']); this.on('click', function (event) { if (event.target != this.$input) this.$input.focus(); }.bind(this)); } FlexiconInput.prototype.on = function () { return this.$input.on.apply(this.$input, arguments); }; FlexiconInput.prototype.once = function () { return this.$input.once.apply(this.$input, arguments); }; FlexiconInput.prototype.off = function () { return this.$input.off.apply(this.$input, arguments); }; FlexiconInput.tag = 'FlexiconInput'.toLowerCase(); FlexiconInput.render = function () { return FlexiconInput_({ class: 'as-flexicon-input', child: [ { class: 'as-flexicon-input-icon-ctn' }, { tag: 'input', class: 'as-flexicon-input-text-input', attr: { type: 'text' }, }, { class: 'as-flexicon-input-unit-ctn' } ] }); }; FlexiconInput.property = {}; FlexiconInput.property.icon = { set: function (value) { value = value || null; this._icon = value; this.$iconCtn.clearChild(); if (value == null) { this.removeClass('as-flexicon-input-has-icon'); } else { this.addClass('as-flexicon-input-has-icon'); this.$iconCtn.addChild(FlexiconInput_(value)); } }, get: function () { return this._icon; } }; FlexiconInput.property.unit = { set: function (value) { this._unit = value; if (this._unit) { this.addClass('as-flexicon-input-has-unit'); this.$unitCtn.clearChild().addChild(FlexiconInput_({ text: value + '' })); } else { this.removeClass('as-flexicon-input-has-unit'); this.$unitCtn.clearChild(); } }, get: function () { return this._unit; } }; FlexiconInput.property.disabled = { set: function (value) { value = !!value; this.$input.disabled = value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.$input.disabled; } }; FlexiconInput.property.readOnly = { set: function (value) { value = !!value; this.$input.readOnly = value; if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; ACore/* default.install */.Z.install(FlexiconInput); /* harmony default export */ const js_FlexiconInput = (FlexiconInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/frame.css var css_frame = __webpack_require__(1427); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/Frame.js var Frame_ = ACore/* default._ */.Z._; var Frame_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function Frame() { this.$parent = null;// FrameView or TabView //adapter (0,utils.forwardEvent)(this, 'inactive', 'deactive'); } Frame.tag = 'frame'; Frame.render = function () { return Frame_({ class: 'absol-frame', attr: { id: (0,stringGenerate.randomIdent)(12), }, extendEvent: ['attached', 'detached', 'active', 'inactive']// inactive and active event will be send by parent }); }; Frame.prototype.notifyAttached = function (parentElt) { this.$parent = parentElt; this.emit('attached', { type: 'attached', target: this, parentElt: parentElt }, this); }; Frame.prototype.notifyDetached = function () { this.emit('detached', { type: 'detached', target: this, parentElt: this.$parent }, this); this.$parent = undefined; }; Frame.prototype.selfRemove = function () { if (this.$parent) this.$parent.removeChild(this); else this.super();// normal remove }; Frame.prototype.getParent = function () { return this.$parent; }; Frame.prototype.requestActive = function () { if (this.$parent) { this.$parent.activeFrame(this); } }; ACore/* default.install */.Z.install(Frame); /* harmony default export */ const js_Frame = (Frame); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/frameview.css var frameview = __webpack_require__(7027); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FrameView.js var FrameView_ = ACore/* default._ */.Z._; var FrameView_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function FrameView() { this.$containers = []; //adapt (0,utils.forwardEvent)(this, 'inactiveframe', 'deactiveframe'); (0,utils.forwardMethod)(this, 'notifyDeactiveFrame', 'notifyInactiveFrame'); } FrameView.tag = 'frameview'; FrameView.render = function () { return FrameView_({ class: 'absol-frame-view', extendEvent: ['activeframe', 'inactiveframe'] }); }; FrameView.prototype.addChild = function (elt) { if (elt.hasClass && elt.hasClass('absol-frame')) { elt.selfRemove(); var containerElt = FrameView_({ class: 'absol-frame-view-frame-container', child: elt, props: { __elt__: elt } }); this.$containers.push(containerElt); this.appendChild(containerElt); elt.notifyAttached(this); } else { throw new Error('Children must be a frame'); } }; FrameView.prototype.addLast = function (elt) { this.addChild(elt); this.activeFrame(elt); }; FrameView.prototype.removeLast = function () { if (this.$containers.length > 0) { this.removeChild(this.$containers[this.$containers.length - 1].__elt__); } if (this.$containers.length > 0) { this.activeFrame(this.$containers[this.$containers.length - 1].__elt__); } }; FrameView.prototype.getLength = function () { return this.$containers.length; }; FrameView.prototype.getAllChild = function () { return this.$containers.map(function (ctn) { return ctn.__elt__; }); }; FrameView.prototype.getLast = function () { if (this.$containers.length > 0) { return (this.$containers[this.$containers.length - 1].__elt__); } return null; }; FrameView.prototype.addChildBefore = function (elt, at) { if (elt.hasClass && elt.hasClass('absol-frame')) { elt.selfRemove(); var index = this.childIndexOf(at); if (index < 0) { throw new Error('Second param is not a child'); } var index = this.childIndexOf(at); var atCtnElt = this.$containers[index]; var containerElt = FrameView_({ class: 'absol-frame-view-frame-container', child: elt, props: { __elt__: elt } }); this.$containers.splice(index, 0, containerElt); this.super(containerElt, atCtnElt); elt.notifyAttached(this); } else { throw new Error('Children must be a frame'); } }; FrameView.prototype.addChildAfter = function (elt, at) { if (elt.hasClass && elt.hasClass('absol-frame')) { elt.selfRemove(); var index = this.childIndexOf(at); if (index < 0) { throw new Error('Second param is not a child'); } var index = this.childIndexOf(at); var atCtnElt = this.$containers[index]; var containerElt = FrameView_({ class: 'absol-frame-view-frame-container', child: elt, props: { __elt__: elt } }); this.$containers.splice(index + 1, 0, containerElt); this.super(containerElt, atCtnElt); elt.notifyAttached(this); } else { throw new Error('Children must be a frame'); } }; FrameView.prototype.removeChild = function (elt) { var ctnEltIndex = this.childIndexOf(elt) if (ctnEltIndex >= 0) { var ctnElt = this.$containers[ctnEltIndex]; this.$containers.splice(ctnEltIndex, 1); this.super(ctnElt); } else { throw new Error('Removed element is not a child!'); } }; FrameView.prototype.childIndexOf = function (elt) { for (var i = 0; i < this.$containers.length; ++i) { if (this.$containers[i].__elt__ == elt) return i; } return -1; }; FrameView.prototype.findChildBefore = function (elt) { var eltIndex = this.childIndexOf(elt); if (eltIndex < 0) return -1; return this.$containers[eltIndex - 1]; }; FrameView.prototype.findChildAfter = function (elt) { var eltIndex = this.childIndexOf(elt); if (eltIndex < 0) return -1; return this.$containers[eltIndex + 1]; }; FrameView.prototype.clearChild = function () { while (this.$containers.length > 0) { this.removeChild(this.$containers[0].__elt__); } return this; }; FrameView.prototype.findChildById = function (id) { var elt; for (var i = 0; i < this.$containers.length; ++i) { elt = this.$containers[i].__elt__; if (elt.getAttribute('id') == id) return elt; } return undefined; }; FrameView.prototype.getAllChild = function () { return this.$containers.map(function (ctnElt) { return ctnElt.__elt__; }); }; FrameView.prototype.activeFrame = function (frameElt) { var ctnElt, elt; for (var i = 0; i < this.$containers.length; ++i) { ctnElt = this.$containers[i]; elt = ctnElt.__elt__; if (frameElt === elt) { if (!ctnElt.hasClass('absol-active')) { ctnElt.addClass('absol-active'); this.notifyActiveFrame(elt); } // else do nothing } else { if (ctnElt.hasClass('absol-active')) { ctnElt.removeClass('absol-active'); this.notifyInactiveFrame(elt); } // else do nonthing } } return this; }; FrameView.prototype.notifyActiveFrame = function (frameElt, originEvent) { frameElt.emit('active', { target: frameElt, type: 'active', originEvent: originEvent }); this.emit('activeframe', { type: 'activeframe', target: this, frameElt: frameElt, originEvent: originEvent }, this); }; FrameView.prototype.notifyInactiveFrame = function (frameElt, originEvent) { this.emit('inactiveframe', { type: 'inactiveframe', target: this, frameElt: frameElt, originEvent: originEvent }, this); }; FrameView.prototype.activeFrameById = function (id) { var frameElt = this.findChildById(id); if (frameElt) this.activeFrame(frameElt); return this; }; ACore/* default.install */.Z.install( FrameView); /* harmony default export */ const js_FrameView = (FrameView); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TabFrame.js var TabFrame_$ = ACore/* default.$ */.Z.$; var TabFrame_ = ACore/* default._ */.Z._; /** * @extends {AElement} * @constructor */ function TabFrame() { this.on('remove', this._onRemove); } TabFrame.tag = 'tabframe'; TabFrame.render = function () { return TabFrame_({ tag: 'frame', class: 'absol-tab-frame', extendEvent: ['requestremove', 'remove'] }, true); } TabFrame.property = {}; TabFrame.property.name = { set: function (value) { if (typeof name == "undefined") { this._name = undefined; } else { this._name = value + ''; } if (this.$parent) { if (this.$parent.notifyUpdateName) this.$parent.notifyUpdateName(this); } }, get: function () { return this._name; } }; TabFrame.property.modified = { set: function (value) { this._modified = !!value; if (this.$parent) { if (this.$parent.notifyUpdateModified) this.$parent.notifyUpdateModified(this); } }, get: function () { return !!this._modified; } }; TabFrame.property.desc = { set: function (value) { if (typeof value == "undefined") { this._desc = undefined; } else { this._desc = value + ''; } if (this.$parent) { if (this.$parent.notifyUpdateDesc) this.$parent.notifyUpdateDesc(this); } }, get: function () { return this._desc; } }; TabFrame.property.preventClosing = { set: function (value) { if (value) { this.addClass('as-prevent-closing'); } else { this.removeClass('as-prevent-closing'); } if (this.$parent && this.$parent.notifyUpdatePreventClosing) { this.$parent.notifyUpdatePreventClosing(this); } }, get: function () { return this.hasClass('as-prevent-closing'); } }; TabFrame.attribute = {}; TabFrame.attribute.name = { set: function (value) { this.name = value; }, get: function () { return this.name; }, remove: function () { this.name = undefined; } }; TabFrame.attribute.desc = { set: function (value) { this.desc = value; }, get: function () { return this.desc; }, remove: function () { this.desc = undefined; } }; TabFrame.attribute.modified = { set: function (value) { this.modified = value == 'true' || value == '1' || value === true; }, get: function () { return this.modified ? 'true' : undefined; }, remove: function () { this.desc = false; } }; TabFrame.prototype.requestRemove = function () { if (this.$parent && this.$parent.removeTab) { this.$parent.removeTab(this.id, false); } else { this.selfRemove(); } }; TabFrame.prototype._onRemove = function () { /* bug auto revoke setTimeout(() => { if (!this.isDescendantOf(document.body)) { this.revokeResource(); } }, 100); */ }; TabFrame.prototype.revokeResource = function () { this.off('remove', this._onRemove); while (this.lastChild && false) { if (location.href.indexOf('localhost') >= 0 || location.href.indexOf('lab.') >= 0)//for testing (0,utils.revokeResource)(this.lastChild); this.lastChild.remove(); } }; ACore/* default.install */.Z.install(TabFrame); /* harmony default export */ const js_TabFrame = (TabFrame); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TabView.js + 2 modules var TabView = __webpack_require__(7); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/singlepage.css var singlepage = __webpack_require__(6813); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ResizeSystem.js var ResizeSystem = __webpack_require__(6700); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SinglePage.js var SinglePage_ = ACore/* default._ */.Z._; var SinglePage_$ = ACore/* default.$ */.Z.$; var warned = false; /*** * @extends TabFrame * @constructor */ function SinglePage() { var thisSP = this; this._updateIntv = -1; this._tick = function () { if (this.isDescendantOf(document.body)) { if (this.$header) { var headerHeight = this.$header.getBoundingClientRect().height; if (this._prevHeaderHeight !== headerHeight) { ResizeSystem/* default.update */.Z.update(); } } } else { clearInterval(this._updateIntv); this._updateIntv = -1; } }.bind(this); this.$attachhook = SinglePage_$('attachhook', this) .on('attached', function () { this.updateSize(); setTimeout(this.updateSize, 20); Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); if (thisSP._updateIntv < 0) { thisSP._updateIntv = setInterval(thisSP._tick, 200); } }); this.$attachhook.updateSize = this.updateSize.bind(this); this.$header = null; this.$footer = null; this.$viewport = SinglePage_$('.absol-single-page-scroller-viewport', this); this.$scroller = SinglePage_$('.absol-single-page-scroller', this); } SinglePage.tag = 'SinglePage'.toLowerCase(); SinglePage.render = function () { return SinglePage_({ tag: 'tabframe', extendEvent: ['sizechange'], class: 'absol-single-page', child: [{ class: 'absol-single-page-scroller', child: { class: 'absol-single-page-scroller-viewport' } }, 'attachhook'] }); }; SinglePage.prototype.updateSize = function () { if (!this.isDescendantOf(document.body)) return; var paddingTop = parseFloat(this.getComputedStyleValue('padding-top').replace('px', '')) || 0; if (this.$header) { var headerBound = this.$header.getBoundingClientRect(); this._prevHeaderHeight = headerBound.height; } if (this.$footer) { var footerBound = this.$footer.getBoundingClientRect(); this.$viewport.addStyle('padding-bottom', footerBound.height + 'px'); } this.addStyle('--single-page-scroller-height', this.$scroller.clientHeight + 'px'); if (this.isSupportedEvent('sizechange')) this.emit('sizechange', { type: 'sizechange', target: this }, this); }; SinglePage.prototype.isHeader = function (elt) { return elt && elt.classList && elt.classList.contains('absol-single-page-header'); }; SinglePage.prototype.updateLayoutStyle = function () { if (this.$header) { this.addClass('as-has-header'); } else { this.removeClass('as-has-header'); } }; SinglePage.prototype.addChild = function (elt) { if (this.isHeader(elt)) { if (this.$header) { this.$header.remove(); } if (this.firstChild) { this.addChildBefore(elt, this.firstChild); } else { this.appendChild(elt); } this.$header = SinglePage_$(elt); this.updateLayoutStyle(); this.updateSize(); } else if (elt.classList.contains('absol-single-page-footer')) { this.$viewport.addChild(elt); this.$footer = SinglePage_$(elt); this.updateLayoutStyle(); this.updateSize(); } else { this.$viewport.addChild(elt); } }; SinglePage.prototype.removeChild = function (elt) { if (elt == this.$footer) { this.$viewport.removeChild(elt); this.$footer = undefined; this.updateSize(); } else if (elt == this.$header) { this.super(elt); this.$header = undefined; this.updateSize(); } else { this.$viewport.removeChild(elt); } }; ACore/* default.install */.Z.install(SinglePage); /* harmony default export */ const js_SinglePage = (SinglePage); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/hexasectionlabel.css var hexasectionlabel = __webpack_require__(3964); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/HexaSectionLabel.js var HexaSectionLabel_ = ACore/* default._ */.Z._; var HexaSectionLabel_$ = ACore/* default.$ */.Z.$; var HexaSectionLabel_g = Svg/* default.ShareInstance._ */.ZP.ShareInstance._; var HexaSectionLabel_$g = Svg/* default.ShareInstance.$ */.ZP.ShareInstance.$; var HexaSectionLabel_Design = { hexaHeight: 425, textBoxHeight: 286, textHeight: 96, indexHeight: 110, textBoxPaddingLeft: 127, borderWidth: 38 }; var HexaSectionLabel_StyleSheet = { '.as-hexa-section-label-text': { height: HexaSectionLabel_Design.textBoxHeight / HexaSectionLabel_Design.textHeight + 'em', 'padding-left': HexaSectionLabel_Design.textBoxPaddingLeft / HexaSectionLabel_Design.textHeight + 'em', 'line-height': HexaSectionLabel_Design.textBoxHeight / HexaSectionLabel_Design.textHeight + 'em' }, '.as-hexa-section-label-index': { 'font-size': HexaSectionLabel_Design.indexHeight / HexaSectionLabel_Design.textHeight + 'em', height: HexaSectionLabel_Design.hexaHeight / HexaSectionLabel_Design.indexHeight + 'em', 'line-height': HexaSectionLabel_Design.hexaHeight / HexaSectionLabel_Design.indexHeight + 'em', width: ((HexaSectionLabel_Design.hexaHeight + HexaSectionLabel_Design.borderWidth) / Math.cos(Math.PI / 6)) / HexaSectionLabel_Design.indexHeight + 'em' }, }; HexaSectionLabel_({ tag: 'style', id: 'hexa-section-label-style', props: { innerHTML: Object.keys(HexaSectionLabel_StyleSheet).map(function (key) { var style = HexaSectionLabel_StyleSheet[key]; return key + ' {\n' + Object.keys(style).map(function (propName) { return propName + ': ' + style[propName] + ';'; }).join('\n') + '}'; }).join('\n') } }).addTo(document.head); /*** * @extends AElement * @constructor */ function HexaSectionLabel() { this.$background = HexaSectionLabel_$('.as-hexa-section-label-background', this); this.$index = HexaSectionLabel_$('.as-hexa-section-label-index', this); this.$text = HexaSectionLabel_$('.as-hexa-section-label-text', this); this.$attachhook = HexaSectionLabel_('attachhook').addTo(this).on('error', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.requestUpdateSize(); }); this.$attachhook.requestUpdateSize = this.redrawBackground.bind(this); this.$svg = HexaSectionLabel_g({ tag: 'svg', attr: { width: '0', height: '0' }, child: [ 'path.as-hexa-section-label-text-box', 'path.as-hexa-section-label-index-box' ] }).addTo(this.$background); this.$indexBox = HexaSectionLabel_$g('path.as-hexa-section-label-index-box', this.$svg); this.$textBox = HexaSectionLabel_$g('path.as-hexa-section-label-text-box', this.$svg); } HexaSectionLabel.prototype.redrawBackground = function () { var indexBound = this.$index.getBoundingClientRect(); var textBound = this.$text.getBoundingClientRect(); var cHeight = indexBound.height; var cWidth = textBound.right - indexBound.left; this.$svg.attr({ height: cHeight + '', width: cWidth + '', viewBox: [0, 0, cWidth, cHeight].join(' ') }); var borderWidth = cHeight * HexaSectionLabel_Design.borderWidth / HexaSectionLabel_Design.hexaHeight; var radius = (cHeight / Math.cos(Math.PI / 6) / 2) - borderWidth / 2; var x0 = indexBound.width / 2; var y0 = cHeight / 2; this.$indexBox.attr('d', Array(6).fill(0).map(function (u, i) { var angle = Math.PI / 3 + i * Math.PI / 3; var x = radius * Math.cos(angle) + x0; var y = radius * Math.sin(angle) + y0; return (i == 0 ? 'M' : 'L') + x + ' ' + y; }).join(' ') + 'Z') .addStyle({ strokeWidth: borderWidth + '' }); var skewX = 18 / 45; var textBoxHeight = textBound.height; this.$textBox.attr('d', [ [x0, (cHeight - textBoxHeight) / 2], [cWidth - 1, (cHeight - textBoxHeight) / 2], [cWidth - 1 - textBoxHeight * skewX, (cHeight - textBoxHeight) / 2 + textBoxHeight], [x0, (cHeight - textBoxHeight) / 2 + textBoxHeight], ].map(function (point, i) { return (i == 0 ? 'M' : 'L') + point.join(' ') }).join(' ') + 'Z') }; HexaSectionLabel.tag = 'HexaSectionLabel'.toLowerCase(); HexaSectionLabel.render = function () { return HexaSectionLabel_({ class: 'as-hexa-section-label', child: [ { class: 'as-hexa-section-label-background' }, '.as-hexa-section-label-index', '.as-hexa-section-label-text' ] }); }; HexaSectionLabel.property = {}; HexaSectionLabel.property.index = { set: function (value) { this._index = value; this.$index.clearChild().addChild(HexaSectionLabel_({ text: value + '' })) }, get: function () { return this._index; } }; HexaSectionLabel.property.text = { set: function (value) { this._text = value; this.$text.clearChild().addChild(HexaSectionLabel_({ text: value + '' })) }, get: function () { return this._text; } }; ACore/* default.install */.Z.install(HexaSectionLabel); /* harmony default export */ const js_HexaSectionLabel = (HexaSectionLabel); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/vruler.css var vruler = __webpack_require__(9786); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/VRuler.js var VRuler_ = ACore/* default._ */.Z._; var VRuler_$ = ACore/* default.$ */.Z.$; /** * @extends AElement * @constructor */ function VRuler() { var self = this; this.$attachHook = VRuler_('attachhook').on('error', function () { this.updateSize = self.update.bind(self); Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.updateSize(); }).addTo(this); this.$lines = []; this.$numbers = []; this.$measureTarget = undefined; this._viewingNumberCount = 0; this._viewingLineCount = 0; this._spacing = 10; this._major = 10; this._valueFloat = 'top'; /** * @type {number} * @name major * @memberof VRuler# */ /** * @type {number} * @name spacing * @memberof VRuler# */ /** * @type {boolean} * @name inverse * @memberof VRuler# */ } VRuler.tag = 'vruler'; VRuler.render = function () { return VRuler_({ class: 'as-vruler' }); }; VRuler.prototype.revokeResource = function () { this.$measureTarget = null; this.$attachHook.cancelWaiting(); (0,utils.revokeResource)(this.$lines); (0,utils.revokeResource)(this.$numbers); this.clearChild(); this.revokeResource = noop/* default */.Z; } VRuler.prototype.measureElement = function (elt) { if (typeof elt == "string") elt = VRuler_$(elt); this.$measureTarget = elt; this.update(); }; VRuler.prototype.update = function () { var fontSize = this.getFontSize() || 14; var measureBound; var bound = this.getBoundingClientRect(); if (!bound.width ||!bound.height) return; var contentBound = { left: bound.left + 1, right: bound.right - 1, top: bound.top + 1, bottom: bound.bottom - 1, width: bound.width - 2, height: bound.height - 2 }; if (this.$measureTarget) { measureBound = this.$measureTarget.getBoundingClientRect(); } else { measureBound = contentBound; } var startOffset = (measureBound[this._valueFloat] - contentBound[this._valueFloat]) * (this.inverse ? -1 : 1) % this._spacing; if (startOffset < 0) startOffset += this._spacing; var lineIndexOffset = Math.round(((contentBound[this._valueFloat] - measureBound[this._valueFloat]) * (this.inverse ? -1 : 1) + startOffset) / this._spacing); var lineCount = Math.floor((contentBound.height - startOffset) / this._spacing) + 1; while (this.$lines.length < lineCount) { this.$lines.push(VRuler_('.as-vruler-line')); } var i; var lineElt; for (i = 0; i < lineCount; ++i) { lineElt = this.$lines[i]; if ((i + lineIndexOffset) % this._major == 0) { lineElt.addClass('major'); } else { lineElt.removeClass('major'); } lineElt.addStyle(this._valueFloat, startOffset + this._spacing * i - 0.5 + 'px'); } try { while (this._viewingLineCount < lineCount) { this.$lines[this._viewingLineCount++].addTo(this); } while (this._viewingLineCount > lineCount) { this.$lines[--this._viewingLineCount].remove(); } } catch (e) { } var numberCount = Math.floor((lineCount + lineIndexOffset - 1) / this._major) - Math.ceil(lineIndexOffset / this._major) + 1; while (this.$numbers.length < numberCount) { this.$numbers.push(VRuler_('.as-vruler-major-number')); } var numberElt; var number; var majorStartOfset = startOffset; if (lineIndexOffset > 0) { majorStartOfset += (this._major - lineIndexOffset % this._spacing) * this._spacing; } else { majorStartOfset += (this._major - (this._spacing + lineIndexOffset % this._spacing)) * this._spacing; } for (i = 0; i < numberCount; ++i) { number = (Math.ceil(lineIndexOffset / this._major) + i) * this._spacing * this._major; numberElt = this.$numbers[i]; if (numberElt.__cacheNumber__ != number) { numberElt.__cacheNumber__ = number; numberElt.innerHTML = number + ''; } numberElt.addStyle(this._valueFloat, majorStartOfset + this._major * i * this._spacing - 0.7 * 0.5 * fontSize + 'px') } while (this._viewingNumberCount < numberCount) { this.$numbers[this._viewingNumberCount++].addTo(this); } try { while (this._viewingNumberCount > numberCount) { this.$numbers[--this._viewingNumberCount].remove(); } } catch (e) { } }; VRuler.property = {}; VRuler.property.major = { set: function (value) { if (value > 0) { this._major = value; this.update(); } }, get: function () { return this._major; } }; VRuler.property.spacing = { set: function (value) { if (value > 0) { this._spacing = value; this.update(); } }, get: function () { return this._spacing; } }; VRuler.property.inverse = { set: function (value) { this._valueFloat = value ? 'bottom' : 'top'; this.update(); }, get: function () { return this._valueFloat === 'bottom'; } }; ACore/* default.install */.Z.install(VRuler); /* harmony default export */ const js_VRuler = (VRuler); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/hruler.css var hruler = __webpack_require__(1138); // EXTERNAL MODULE: ./node_modules/absol/src/DataStructure/Object.js var DataStructure_Object = __webpack_require__(2722); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/HRuler.js var HRuler_ = ACore/* default._ */.Z._; var HRuler_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function HRuler() { this.$attachHook = HRuler_('attachhook').on('attached', () => { this.requestUpdateSize = this.update.bind(this); ResizeSystem/* default.add */.Z.add(this.$attachHook); this.requestUpdateSize(); }).addTo(this); this.$attachHook.requestRevokeResource = this.revokeResource.bind(this); this.$lines = []; this.$numbers = []; this._viewingNumberCount = 0; this._viewingLineCount = 0; this._spacing = 10; this._major = 10; this.$measureTarget = null; this._valueFloat = 'left'; /** * @type {number} * @name major * @memberof HRuler# */ /** * @type {number} * @name spacing * @memberof HRuler# */ /** * @type {boolean} * @name inverse * @memberof HRuler# */ } HRuler.tag = 'hruler'; HRuler.render = function () { return HRuler_({ class: 'as-hruler' }); }; HRuler.prototype.measureElement = function (elt) { if (typeof elt == "string") elt = HRuler_$(elt); this.$measureTarget = elt; this.update(); }; HRuler.prototype.update = function () { var fontSize = this.getFontSize(); var measureBound; var bound = this.getBoundingClientRect(); if (!bound.width || !bound.height) return; var contentBound = { left: bound.left + 1, right: bound.right - 1, top: bound.top + 1, bottom: bound.bottom - 1, width: bound.width - 2, height: bound.height - 2 }; if (this.$measureTarget) { measureBound = this.$measureTarget.getBoundingClientRect(); } else { measureBound = contentBound; } var startOffset = (measureBound[this._valueFloat] - contentBound[this._valueFloat]) * (this.inverse ? -1 : 1) % this._spacing; if (startOffset < 0) startOffset += this._spacing; var lineIndexOffset = Math.round(((contentBound[this._valueFloat] - measureBound[this._valueFloat]) * (this.inverse ? -1 : 1) + startOffset) / this._spacing); var lineCount = Math.floor((contentBound.width - startOffset) / this._spacing) + 1; lineCount = Math.max(0, lineCount); while (this.$lines.length < lineCount) { this.$lines.push(HRuler_('.as-hruler-line')); } var i; var lineElt; for (i = 0; i < lineCount; ++i) { lineElt = this.$lines[i]; if ((i + lineIndexOffset) % this._major === 0) { lineElt.addClass('major'); } else { lineElt.removeClass('major'); } lineElt.addStyle(this._valueFloat, startOffset + this._spacing * i - 0.5 + 'px'); } while (this._viewingLineCount < lineCount) { this.$lines[this._viewingLineCount++].addTo(this); } while (this._viewingLineCount > lineCount) { this.$lines[--this._viewingLineCount].remove(); } var numberCount = Math.floor((lineCount + lineIndexOffset - 1) / this._major) - Math.ceil(lineIndexOffset / this._major) + 1; while (this.$numbers.length < numberCount) { this.$numbers.push(HRuler_('.as-hruler-major-number')); } var numberElt; var number; var majorStartOfset = startOffset; if (lineIndexOffset > 0) { majorStartOfset += (this._major - lineIndexOffset % this._spacing) * this._spacing; } else { majorStartOfset += (this._major - (this._spacing + lineIndexOffset % this._spacing)) * this._spacing; } for (i = 0; i < numberCount; ++i) { number = (Math.ceil(lineIndexOffset / this._major) + i) * this._spacing * this._major; numberElt = this.$numbers[i]; if (numberElt.__cacheNumber__ != number) { numberElt.__cacheNumber__ = number; numberElt.innerHTML = number + ''; } numberElt.addStyle(this._valueFloat, majorStartOfset + this._major * i * this._spacing - 0.7 * 2.5 * fontSize + 'px') } while (this._viewingNumberCount < numberCount) { this.$numbers[this._viewingNumberCount++].addTo(this); } while (this._viewingNumberCount > numberCount) { this.$numbers[--this._viewingNumberCount].remove(); } }; HRuler.prototype.revokeResource = function () { this.$attachHook.cancelWaiting(); this.$measureTarget = null; (0,DataStructure_Object/* revokeResource */.bU)(this.$lines); (0,DataStructure_Object/* revokeResource */.bU)(this.$numbers); this.clearChild(); this.revokeResource = noop/* default */.Z; }; HRuler.property = {}; HRuler.property.major = { set: function (value) { if (value > 0) { this._major = value; this.update(); } }, get: function () { return this._major; } }; HRuler.property.spacing = { set: function (value) { if (value > 0) { this._spacing = value; this.update(); } }, get: function () { return this._spacing; } }; HRuler.property.inverse = { set: function (value) { this._valueFloat = value ? 'right' : 'left'; this.update(); }, get: function () { return this._valueFloat === 'right'; } }; ACore/* default.install */.Z.install(HRuler); /* harmony default export */ const js_HRuler = (HRuler); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/IconSprite.js var IconSprite_ = ACore/* default._ */.Z._; var IconSprite_$ = ACore/* default.$ */.Z.$; function IconSprite() { this.$attachhook = IconSprite_('attachhook').addTo(this).on('error', this.eventHandler.attached); this.on('frame', this.eventHandler.frame); this._checkRootTimeout = 30; this.loop = true; } IconSprite.tag = 'iconsprite'; IconSprite.render = function () { return IconSprite_('sprite', true); }; /** * @type {IconSprite} */ IconSprite.eventHandler = {}; IconSprite.eventHandler.attached = function () { var thisAS = this; this._checkRootTimeout = 30; this.afterReady().then(function () { thisAS.width = thisAS.texture.naturalWidth; thisAS.height = thisAS.width; thisAS.frames = { type: 'grid', col: 1, row: thisAS.texture.naturalHeight / thisAS.texture.naturalWidth } thisAS.drawFrame(0); thisAS.play(); }); }; IconSprite.eventHandler.frame = function () { this._checkRootTimeout--; if (this._checkRootTimeout == 0){ if (this.isDescendantOf(document.body)){ this._checkRootTimeout = 30; } else{ this.stop(); this.remove(); } } }; ACore/* default.install */.Z.install(IconSprite); /* harmony default export */ const js_IconSprite = (IconSprite); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/linearcolorbar.css var linearcolorbar = __webpack_require__(3262); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LinearColorBar.js var LinearColorBar_ = ACore/* default._ */.Z._; var LinearColorBar_$ = ACore/* default.$ */.Z.$; var LinearColorBar_g = Svg/* default.ShareInstance._ */.ZP.ShareInstance._; var LinearColorBar_$g = Svg/* default.ShareInstance.$ */.ZP.ShareInstance.$; var LinearColorBar_Design = { textHeight: 56, barHeight: 97, barBlockWidth: 79, barBlockMargin: 19, valueTextHeight: 70, valueStrokeWidth: 5, valueHeight: 99, valueWidth: 52, valueTripHeight: 32, height: 430, barY: 201 }; var SyleSheet = { '.as-linear-color-bar': { height: LinearColorBar_Design.height / LinearColorBar_Design.textHeight + 'em' }, '.as-linear-color-value-text': { 'font-size': LinearColorBar_Design.valueTextHeight / LinearColorBar_Design.textHeight + 'em' } }; (0,utils.buildCss)(SyleSheet); function LinearColorBar() { this._indent = (Math.random() + '').replace(/[^0-9]/g, '_'); this._extendValue = 0; this._value = 0; this._valueText = ''; this.$valueText = LinearColorBar_$('.as-linear-color-value-text', this); this.$minValueText = LinearColorBar_$('.as-linear-color-min-value-text', this); this.$maxValueText = LinearColorBar_$('.as-linear-color-max-value-text', this); this.$background = LinearColorBar_$('svg.as-linear-color-background', this); this._attached = false; var thisBar = this; this.$attachhook = LinearColorBar_('attachhook').addTo(this).on('error', function () { thisBar._attached = true; Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.requestUpdateSize(); }); this.$background.attr({ height: 0, width: 0, }); this.$attachhook.requestUpdateSize = this.redraw.bind(this); this.$defs = LinearColorBar_g('defs').addTo(this.$background); this.$gradient = LinearColorBar_g('linearGradient#gradient_' + this._indent) .attr({ x1: "0%", y1: "0%", x2: "100%", y2: "0%" }).addTo(this.$defs); this.$rect = LinearColorBar_g('rect.as-linear-color-bar-rect') .attr({ fill: 'url(#gradient_' + this._indent + ')' }) .addTo(this.$background); this.$splitLine = LinearColorBar_g('path.as-linear-color-split-line').addTo(this.$background) this.$valueArrow = LinearColorBar_g('path.as-linear-color-value-arrow').addTo(this.$background); this.colorMapping = 'rainbow'; } LinearColorBar.prototype.redraw = function () { var bBound = this.getBoundingClientRect(); var cWidth = bBound.width; var cHeight = bBound.height; var maxTextBound = this.$maxValueText.getBoundingClientRect(); var minTextBound = this.$minValueText.getBoundingClientRect(); var valueTextBound = this.$valueText.getBoundingClientRect(); var valueWidth = LinearColorBar_Design.valueWidth / LinearColorBar_Design.height * cHeight; var minValueX = valueWidth / 1.5; this.$minValueText.addStyle('left', Math.max((minValueX - minTextBound.width) / 2, 0) + 'px'); var maxValueX = (cWidth - LinearColorBar_Design.valueWidth) / (1 + this._extendValue); var extendX = cWidth - valueWidth / 1.5; var valueX = minValueX + this._value * (maxValueX - minValueX); this.$valueText.addStyle('left', valueX - valueTextBound.width / 2 + 'px'); this.$maxValueText.addStyle('left', maxValueX - maxTextBound.width / 2 + 'px'); var barY = LinearColorBar_Design.barY / LinearColorBar_Design.height * cHeight; var barHeight = LinearColorBar_Design.barHeight / LinearColorBar_Design.height * cHeight; this.$rect.attr({ x: '' + minValueX, y: '' + barY, width: extendX - minValueX + '', height: barHeight }); this.$background.attr({ height: cHeight + '', width: cWidth + '', viewBox: [0, 0, cWidth, cHeight].join(' ') }); var valueTripHeight = LinearColorBar_Design.valueTripHeight / LinearColorBar_Design.height * cHeight; var valueHeight = LinearColorBar_Design.valueHeight / LinearColorBar_Design.height * cHeight; this.$valueArrow .addStyle('stroke-width', LinearColorBar_Design.valueStrokeWidth / LinearColorBar_Design.height * cHeight + '') .attr('d', [ [ [valueX, barY], [valueX - valueWidth / 2, barY - valueTripHeight], [valueX - valueWidth / 2, barY - valueHeight], [valueX + valueWidth / 2, barY - valueHeight], [valueX + valueWidth / 2, barY - valueTripHeight] ] ].map(function (point, i) { return (i == 0 ? 'M' : 'L') + point.join(' ') }).join(' ') + 'Z'); var splitDistMin = (LinearColorBar_Design.barBlockWidth + LinearColorBar_Design.barBlockMargin) / LinearColorBar_Design.height * cHeight; var splitCounts = [100, 50, 20, 10, 5, 2, 1]; var splitDist = maxValueX - minValueX; var splitCount = 1; for (var i = 0; i < splitCounts.length; ++i) { splitDist = (maxValueX - minValueX) / splitCounts[i]; if (splitDist >= splitDistMin) { splitCount = splitCounts[i]; break; } } this.$splitLine.addStyle('stroke-width', LinearColorBar_Design.barBlockMargin / LinearColorBar_Design.height * cHeight + '') .attr({ d: Array(splitCount + 1).fill(0).map(function (u, i) { return 'M' + (maxValueX - i * splitDist) + ' ' + (barY - 1) + 'v' + (barHeight + 2); }).join(' ') }) }; LinearColorBar.prototype._updateGradient = function () { var barMax = 1 + this._extendValue; var gradientElt = this.$gradient.clearChild(); this._colorMapping.forEach(function (it) { LinearColorBar_g({ tag: 'stop', attr: { offset: (it.value <= 1 ? it.value / barMax * 100 : 100) + '%' }, style: { 'stop-color': it.color + '', 'stop-opacity': '1' } }).addTo(gradientElt); }); }; LinearColorBar.prototype.BUILDIN_COLORS_RANGE = { 'rainbow': [ { value: 0, color: 'red' }, { value: 1 / 6, color: 'orange' }, { value: 1 / 3, color: 'yellow' }, { value: 1 / 2, color: 'green' }, { value: 2 / 3, color: 'blue' }, { value: 5 / 6, color: 'indigo' }, { value: 1, color: 'violet' }, { value: Infinity, color: 'violet' } ], 'rainbow-invert': [ { value: 0, color: 'violet' }, { value: 1 / 6, color: 'indigo' }, { value: 1 / 3, color: 'blue' }, { value: 1 / 2, color: 'green' }, { value: 2 / 3, color: 'yellow' }, { value: 5 / 6, color: 'orange' }, { value: 1, color: 'red' }, { value: Infinity, color: 'violet' } ], 'performance': [ { value: 0, color: 'red' }, { value: 0.5, color: 'orange' }, { value: 1, color: 'green' }, { value: Infinity, color: 'green' } ], 'performance-invert': [ { value: 0, color: 'green' }, { value: 0.5, color: 'orange' }, { value: 1, color: 'red' }, { value: Infinity, color: 'red' } ] } LinearColorBar.tag = 'LinearColorBar'.toLowerCase(); LinearColorBar.render = function () { return LinearColorBar_({ class: 'as-linear-color-bar', child: [ 'svg.as-linear-color-background', '.as-linear-color-value-text', '.as-linear-color-min-value-text', '.as-linear-color-max-value-text' ] }); }; LinearColorBar.property = {}; LinearColorBar.property.valueText = { set: function (value) { value = value + ''; this._valueText = value; this.$valueText.clearChild().addChild(LinearColorBar_({ text: value })); }, get: function () { return this._valueText; } }; LinearColorBar.property.minValueText = { set: function (value) { value = value + ''; this._minValueText = value; this.$minValueText.clearChild().addChild(LinearColorBar_({ text: value })); }, get: function () { return this._valueText; } }; LinearColorBar.property.maxValueText = { set: function (value) { value = value + ''; this._maxValueText = value; this.$maxValueText.clearChild().addChild(LinearColorBar_({ text: value })); }, get: function () { return this._valueText; } }; LinearColorBar.property.value = { set: function (value) { this._value = value; }, get: function () { return this._value; } }; LinearColorBar.property.extendValue = { set: function (value) { this._extendValue = value; this._updateGradient(); }, get: function () { return this._extendValue; } }; LinearColorBar.property.colorMapping = { set: function (value) { if (typeof (value) == "string") value = this.BUILDIN_COLORS_RANGE[value]; this._colorMapping = value.slice(); this._colorMapping.sort(function (a, b) { return a.value - b.value; }) this._updateGradient(); }, get: function () { return this._colorMapping; } }; ACore/* default.install */.Z.install(LinearColorBar); /* harmony default export */ const js_LinearColorBar = (LinearColorBar); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/mediainput.css var mediainput = __webpack_require__(3475); // EXTERNAL MODULE: ./node_modules/absol/src/Converter/file.js var Converter_file = __webpack_require__(4574); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Text.js var Text = __webpack_require__(5827); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MediaInput.js var MediACore = new Dom/* default */.ZP(); MediACore.install(ACore/* default */.Z); var MediaInput_ = MediACore._; var MediaInput_$ = MediACore.$; function openFileDialog(props) { if (!MediACore.$fileInput) { MediACore.$fileInput = MediaInput_({ tag: 'input', class: 'vmedia-no-show', attr: { type: 'file' }, props: {} }).addTo(document.body); } props = props || {}; if (props.accept) { if (props.accept instanceof Array) MediACore.$fileInput.attr('accept', props.accept.join(',')); else MediACore.$fileInput.attr('accept', props.accept); } else { MediACore.$fileInput.attr('accept', null); } if (props.multiple) { MediACore.$fileInput.attr('multiple', 'true'); } else { MediACore.$fileInput.attr('multiple'); } MediACore.$fileInput.value = null; MediACore.$fileInput.click(); return new Promise(function (resolve, reject) { var finish = false; var body = MediaInput_$('body'); MediACore.$fileInput.once('change', function () { finish = true; resolve(Array.prototype.map.call(this.files, function (file) { return file; })); }); body.once('mousedown', function () { if (finish) return; resolve(); }); }); } function MediaInput() { this.$editor = MediaInput_$('.vmedia-media-input-text-container-editor', this); this.$editor.on('paste', this.eventHandler.paste); this.$editor.on('keydown', this.eventHandler.keydown, true); this.$addImagebtn = MediaInput_$('#add-image-btn', this); this.$addImagebtn.on('click', this.eventHandler.clickAddImage); this.$addFilebtn = MediaInput_$('#add-file-btn', this); this.$addFilebtn.on('click', this.eventHandler.clickAddFile); this.$imagePreviewContainer = MediaInput_$('.vmedia-media-input-imagepreview-container', this); this.on('dragover', this.eventHandler.dragOver); this.on('drop', this.eventHandler.drop); this.$sendbtn = MediaInput_$('#send-btn', this); this.$sendbtn.on('click', this.eventHandler.send); this.$toolLeftCtn = MediaInput_$('.vmedia-media-input-tool-container-left', this); this.$pluginContentCtn = MediaInput_$('.vmedia-media-input-plugin-content-container', this); this.snapData = []; this.snapDataHead = 0; this.sync = this.afterAttached(); this.snapText(); } MediaInput.tag = 'MediaInput'.toLowerCase(); MediaInput.render = function () { return MediaInput_({ class: 'vmedia-media-input', extendEvent: ['send', 'update', 'releaseplugin'], child: { class: 'vmedia-media-input-text-container', child: [{ class: 'vmedia-media-input-imagepreview-container', child: { class: 'vmedia-media-input-dropover', child: 'download-ico' } }, { class: 'vmedia-media-input-text-container-editor', attr: { contenteditable: 'true' }, on: {} }, { class: 'vmedia-media-input-text-container-buttons', attr: { title: 'Send' } }, { class: 'vmedia-media-input-tool-container', child: [ { class: 'vmedia-media-input-tool-container-left', child: [ { tag: 'button', attr: { id: 'add-image-btn', title: 'Add image' }, child: 'add-image-ico' }, { tag: 'button', attr: { id: 'add-file-btn', title: 'Add file' }, child: 'add-file-ico' }, ] }, { class: 'vmedia-media-input-tool-container-right', child: [{ tag: 'button', id: 'send-btn', attr: { title: 'Send' }, child: 'send-ico' }] } ], }, '.vmedia-media-input-plugin-content-container.blur', ] } }); }; MediaInput.prototype.addImage = function (url, title, data) { MediaInput_({ tag: 'imagepreview', attr: { title: title }, props: { data: data, imgSrc: url }, on: { pressremove: function () { this.selfRemove(); } } }).addTo(this.$imagePreviewContainer); }; MediaInput.prototype.addFile = function (url, ext, title, data) { MediaInput_({ tag: 'filepreview', attr: { title: title }, props: { fileSrc: url, ext: ext, data: data }, on: { pressremove: function () { this.selfRemove(); } } }).addTo(this.$imagePreviewContainer); }; MediaInput.property = {}; MediaInput.property.text = { set: function (value) { this.$editor.clearChild(); value = value || ''; var lines = value.split(/\r*\n/); if (lines.length < 1) return; this.$editor.addChild(document.createTextNode(lines[0])); lines.shift(); lines.forEach(function (line) { this.$editor.addChild(MediaInput_({ child: document.createTextNode(line) })); }.bind(this)); this.snapText(); }, get: function () { return this.getTextFromElements(this.$editor); } }; MediaInput.property.files = { get: function () { return Array.prototype.filter.call(this.$imagePreviewContainer.childNodes, function (e) { return e._azar_extendTags && e._azar_extendTags.filepreview; }).map(function (e) { return e.data; }); } }; MediaInput.property.images = { get: function () { return Array.prototype.filter.call(this.$imagePreviewContainer.childNodes, function (e) { return e._azar_extendTags && e._azar_extendTags.imagepreview; }).map(function (e) { return e.data; }); } }; // MediaInput.property MediaInput.property.plugins = { set: function (value) { this.sync = this.sync.then(this._dettachPlugins.bind(this, this._plugins)); if (value) { if (!(value instanceof Array)) value = [value]; this._plugins = value; this.addClass('has-plugin'); } else { //remove plugin this.sync.then(this._dettachPlugins.bind(this)); this._plugins = null; this.removeClass('has-plugin'); } this.sync = this.sync.then(this._attachPlugins.bind(this, this._plugins)); }, get: function () { return this._plugins || null; } } MediaInput.prototype.appendText = function (text) { var lastBr = null; if (this.$editor.childNodes && this.$editor.childNodes.length > 0 && this.$editor.childNodes[this.$editor.childNodes.length - 1].tagName && this.$editor.childNodes[this.$editor.childNodes.length - 1].tagName.toLowerCase() == 'br') { lastBr = this.$editor.childNodes[this.$editor.childNodes.length - 1]; } var lines = text.split(/\r?\n/); if (lastBr) { for (var i = 0; i < lines.length; ++i) { if (i > 0) this.$editor.addChild(MediaInput_('br')); var e = MediaInput_({ text: lines[i] }); this.$editor.addChild(e); } } else { for (var i = 0; i < lines.length; ++i) { if (i > 0) this.$editor.addChildBefore(MediaInput_('br'), lastBr); var e = MediaInput_({ text: lines[i] }); } this.$editor.addChildBefore(e, lastBr); } (0,Text.setSelectionRange)(this.$editor, Infinity); }; MediaInput.prototype._attachPlugins = function (plugins) { if (!plugins) return; var self = this; plugins.forEach(function (plugin) { var oldContent = null; var $button = MediaInput_('button').addTo(self.$toolLeftCtn).on('click', function () { if (self._lastActivePlugin == plugin) return; self.releasePlugin(); self._lastActivePlugin = plugin; self.$pluginContentCtn.removeClass('blur'); self.$pluginContentCtn.clearChild(); if (plugin.getContent) { var newContent = plugin.getContent(self, MediaInput_, MediaInput_$, self.$pluginContentCtn, oldContent); oldContent = newContent; self.$pluginContentCtn.addChild(newContent); } var buttonBound = $button.getBoundingClientRect(); var rootBound = self.$pluginContentCtn.parentNode.getBoundingClientRect(); self.$pluginContentCtn.addStyle({ left: buttonBound.left + buttonBound.width / 2 - rootBound.left + 'px', bottom: rootBound.bottom - buttonBound.top + 'px' }); if (plugin.onActive) plugin.onActive(self); setTimeout(function () { var outListener = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(self.$pluginContentCtn, event)) { } else if (self._lastActivePlugin == plugin) { var prevented = true; if (plugin.onBlur) plugin.onBlur({ preventDefault: function () { prevented = false; } }); if (prevented) { self.releasePlugin(); MediaInput_$(document.body).off('click', outListener); } } else { MediaInput_$(document.body).off('click', outListener); } }; MediaInput_$(document.body).on('click', outListener); self.once('releaseplugin', function (ev) { if (ev.plugin == plugin) { MediaInput_$(document.body).off('click', outListener); } }); }, 100); }); var btnInners = plugin.getTriggerInner(self, MediaInput_, MediaInput_$, $button); if (!(btnInners instanceof Array)) btnInners = [btnInners]; btnInners.forEach(function (e) { if (typeof e == 'string') { e = MediaInput_({ text: e }); } $button.addChild(e); }); if (plugin.onAttached) plugin.onAttached(self); }); //todo return true; }; MediaInput.prototype.releasePlugin = function () { if (this._lastActivePlugin) { var plugin = this._lastActivePlugin; plugin.onDeactived && plugin.onDeactived(self); this.$pluginContentCtn.addClass('blur'); this.emit('releaseplugin', { target: this, plugin: plugin }, this); this._lastActivePlugin = null; } } MediaInput.prototype._dettachPlugins = function (plugins) { if (!plugins) return; var self = this; plugins.forEach(function (plugin) { if (plugin.onAttached) plugin.onAttached(self); }); //todo this._lastActivePlugin = null; return true; }; MediaInput.prototype.focus = function () { this.$editor.focus(); (0,Text.setSelectionRange)(this.$editor, Infinity); }; MediaInput.prototype.clear = function () { Array.prototype.filter.call(this.$imagePreviewContainer.childNodes, function (e) { return e._azar_extendTags && e._azar_extendTags.imagepreview; }).forEach(function (e) { e.selfRemove(); }); Array.prototype.filter.call(this.$imagePreviewContainer.childNodes, function (e) { return e._azar_extendTags && e._azar_extendTags.filepreview; }).forEach(function (e) { return e.selfRemove(); }); this.$editor.innerHTML = ""; this.emit('update', { target: this }, this); }; MediaInput.prototype.escapeSpace = function (s) { return s.replace(/\s/g, ' '); }; MediaInput.prototype.unescapeSpace = function (s) { return s.replace(/ /g, ' '); }; MediaInput.prototype.getTextFromElements = function (element) { return (0,Text.getTextIn)(element); // var self = this; // function visit(e, prevE) { // var ac = ''; // var isNewLine = false; // if (prevE && prevE.nodeType != Node.TEXT_NODE) { // if (prevE.tagName && prevE.tagName.toLowerCase() == 'br') { // isNewLine = true; // } // else if (Element.prototype.getComputedStyleValue.call(prevE, 'display') == 'block') { // isNewLine = true; // } // } // if (e.nodeType == Node.TEXT_NODE) { // if (isNewLine) ac += '\n'; // ac += e.data; // } // else { // var lastE = undefined; // for (var i = 0; i < e.childNodes.length; ++i) { // ac += visit(e.childNodes[i], i > 0 ? e.childNodes[i - 1] : null); // } // } // return ac; // } // return visit(element); }; MediaInput.prototype.getElementsFromText = function (text) { var newElements = text.split('\n') .map(function (text) { return document.createTextNode(text); }) .reduce(function (ac, cr, i, arr) { if (i > 0) ac.push(MediaInput_('br')); ac.push(cr); return ac; }, []); return newElements; }; // MediaInput.prototype.textOnly = function(e) { // if (e.nodeType == Node.TEXT_NODE) return e.textContent; // if (!e.tagName) return ''; // if (e.tagName.toLowerCase() == 'br') return '\n'; // return ($(e).getComputedStyleValue('display') == 'block' ? '\n' : '') + Array.prototype.map.call(e.childNodes, this.textOnly.bind(this)).join('') // }; MediaInput.prototype.makeTextOnly = function () { var self = this; var editor = this.$editor; Array.apply(null, this.$editor.childNodes).forEach(function (e) { e = MediaInput_$(e); if (e.nodeType == Node.TEXT_NODE) return; if (e.tagName) { var tagName = e.tagName.toLowerCase(); if (tagName == 'br') return; if (tagName.match(/img|script|svg|button|iframe|hr|video|canvas/)) { e.selfRemove(e); } if (tagName.match(/select|input|textarea/)) { e.selfReplace(document.createTextNode(e.value)); return; } var newElements = self.getElementsFromText(self.getTextFromElements(e)); var lastElement; if (e.getComputedStyleValue('display') == 'block') { lastElement = MediaInput_('br'); } else { lastElement = newElements.pop(); } e.selfReplace(lastElement); newElements.forEach(function (nE) { editor.addChildBefore(nE, lastElement); }); } }); this.emit('update', { target: editor }, this); }; MediaInput.eventHandler = {}; MediaInput.eventHandler.keydown = function (event) { if (event.key == "Enter") { if (!event.ctrlKey && !event.altKey && !event.shiftKey) { event.preventDefault(); this.eventHandler.send(event); this.snapText(); } } if (event.ctrlKey && event.key == 'z') { event.preventDefault(); this.undoText(); } if (event.ctrlKey && event.key == 'x') { setTimeout(this.snapText.bind(this), 100) } setTimeout(this.emit.bind(this, 'update', event, this), 1); }; MediaInput.eventHandler.send = function (event) { if (this.images.length == 0 && this.text.trim().length == 0 && this.files.length == 0) { return; } this.emit('send', event, this); this.snapText(); }; MediaInput.eventHandler.clickAddImage = function (event) { openFileDialog({ accept: 'image/*', multiple: true }).then(function (files) { if (!files) return; files.map(function (file) { var url = (window.URL || window.webkitURL).createObjectURL(file); this.addImage(url, file.name, { file: file, name: file.name, url: url }); this.emit('update', event, this); }.bind(this)); }.bind(this)); }; MediaInput.eventHandler.clickAddFile = function (event) { openFileDialog({ multiple: true }).then(function (files) { if (!files) return; files.map(function (file) { var url = (window.URL || window.webkitURL).createObjectURL(file); if (file.type.match(/^image/)) { this.addImage(url, file.name, { file: file, name: file.name, url: url }); } else { var p = file.name.split('.'); var ext = p.length > 1 ? p[p.length - 1] : ''; this.addFile(url, ext.toUpperCase(), file.name, { file: file, name: file.name, url: url }); } }.bind(this)); this.emit('update', event, this); }.bind(this)); }; MediaInput.eventHandler.dragOver = function (event) { event.preventDefault(); this._lastDragOver = new Date().getTime(); var currentDragOver = this._lastDragOver; if (!this.dragOver) { this.dragOver = true; this.addClass('dragover'); this.emit('update', event, this); } setTimeout(function () { this._waitDragFileOut if (this._lastDragOver == currentDragOver) { this.removeClass('dragover'); this.dragOver = false; this.emit('update', event, this); } }.bind(this), 200); }; MediaInput.eventHandler.drop = function (event) { event.preventDefault(); if (event.dataTransfer.items) { for (var i = 0; i < event.dataTransfer.items.length; i++) { if (event.dataTransfer.items[i].kind === 'file') { var file = event.dataTransfer.items[i].getAsFile(); if (!file.type && file.size % 4096 == 0) { //todo: folder } else { this.addSystemFile(file); this.emit('update', event, this); } } } } else { for (var i = 0; i < event.dataTransfer.files.length; i++) { var file = event.dataTransfer.files[i]; if (!file.type && file.size % 4096 == 0) { } else { this.addSystemFile(file); this.emit('update', event, this); } } } }; MediaInput.prototype.addSystemFile = function (file) { var url = (window.URL || window.webkitURL).createObjectURL(file); if (file.type.match(/^image/)) { this.addImage(url, file.name, { file: file, name: file.name, url: url }); } else { var p = file.name.split('.'); var ext = p.length > 1 ? p[p.length - 1] : ''; this.addFile(url, ext.toUpperCase(), file.name, { file: file, name: file.name, url: url }); } } MediaInput.eventHandler.paste = function (event) { var pasteData = (event.clipboardData || window.clipboardData); var beforePasteElement = []; var self = this; function visit(e, ac) { ac.push(e); if (e.childNodes) { for (var i = 0; i < e.childNodes.length; ++i) { visit(e.childNodes[i], ac) } } } visit(this.$editor, beforePasteElement); function relocalCursor() { var afterPasteElement = []; visit(self.$editor, afterPasteElement); var diffElts = afterPasteElement.filter(function (e) { return beforePasteElement.indexOf(e) < 0; }); if (diffElts.length > 0) { var last = diffElts.pop(); if (last.nodeType == Node.TEXT_NODE) { var range = document.createRange(); range.selectNodeContents(last); range.setStart(last, last.data.length); var sel = window.getSelection(); sel.removeAllRanges(); sel.addRange(range); } else { (0,Text.setSelectionRange)(last, Infinity); } } } /**Safari bug */ if (pasteData && pasteData.items) { var items = pasteData.items; var isAddImage = false; for (var i = 0; i < items.length; i++) { if (items[i].type.indexOf('image') !== -1) { var blob = items[i].getAsFile(); var URLObj = (window.URL || window.webkitURL); var source = URLObj.createObjectURL(blob); var file = (0,Converter_file.blobToFile)(blob); var buffer = (0,Converter_file.blobToArrayBuffer)(blob).then(function (arrayBuffer) { this.addImage(source, 'Clipboard', { file: blob, name: null, url: source, blob: blob, arrayBuffer: arrayBuffer }); this.emit('update', event, this); }.bind(this)); isAddImage = true; this.emit('update', event, this); } } if (isAddImage) event.preventDefault(); requestAnimationFrame(function () { self.makeTextOnly(); relocalCursor(); }); } else { requestAnimationFrame(function () { var img = MediaInput_$('img', this.$editor, function (img) { if (img) { img = MediaInput_$(img); var source = img.getAttribute('src'); img.selfRemove(); Dom/* default.imageToCanvas */.ZP.imageToCanvas(img).then(function (canvas) { var dataURI = canvas.toDataURL(); var blob = (0,Converter_file.dataURItoBlob)(dataURI); var file = (0,Converter_file.blobToFile)(blob); var buffer = (0,Converter_file.blobToArrayBuffer)(blob).then(function (arrayBuffer) { this.addImage(source, 'Clipboard', { dataURI: dataURI, file: blob, name: null, url: source, blob: blob, arrayBuffer: arrayBuffer }); this.emit('update', event, this); }.bind(this)); }.bind(this), function (e) { }).catch(function (e) { }); } }.bind(this)); this.makeTextOnly(); relocalCursor(); }.bind(this)); } }; MediaInput.prototype.undoText = function () { if (this.snapDataHead <= 1) return; this.snapDataHead--; if (this.snapDataHead <= 0) return; var newText = this.snapData[this.snapDataHead - 1]; this.text = newText; (0,Text.setSelectionRange)(this.$editor, Infinity); }; MediaInput.prototype.redoText = function () { if (this.snapData.length <= this.snapDataHead) return; this.snapDataHead++; var newText = this.snapData[this.snapDataHead - 1]; var currentText = this.text; this.text = newText; (0,Text.setSelectionRange)(this.$editor, Infinity); }; MediaInput.prototype.snapText = function () { while (this.snapData.length > this.snapDataHead && this.snapData.length > 0) this.snapData.pop(); var oldText = this.snapData[this.snapDataHead - 1]; var newText = this.text; if (newText == oldText) return; this.snapData.push(this.text); this.snapDataHead++; } function ImagePreview() { var res = MediaInput_({ extendEvent: 'pressremove', class: ['vmedia-media-input-imagepreview', 'vmedia-no-select'], child: ['img', 'times-ico'] }); res.$img = MediaInput_$('img', res); res.$timesIco = MediaInput_$('times-ico', res); res.$timesIco.on('click', function (event) { res.emit('pressremove', event, res); }); OOP/* default.drillProperty */.ZP.drillProperty(res, res.$img, 'imgSrc', 'src'); return res; }; function FilePreview() { var res = MediaInput_({ extendEvent: 'pressremove', class: ['vmedia-media-input-filepreview', 'vmedia-no-select'], child: ['attachment-ico', 'times-ico'] }); res.$img = MediaInput_$('attachment-ico', res); OOP/* default.drillProperty */.ZP.drillProperty(res, res.$img, 'ext'); res.$timesIco = MediaInput_$('times-ico', res); res.$timesIco.on('click', function (event) { res.emit('pressremove', event, res); }); return res; }; MediACore.creator.mediainput = MediaInput; MediACore.creator.imagepreview = ImagePreview; MediACore.creator.filepreview = FilePreview; MediACore.creator['send-ico'] = function () { return MediaInput_( [ '<svg class="send" width="100" height="100" version="1.1" viewBox="0 0 26.458 26.458">', ' <g transform="translate(0 -270.54)">', ' <path d="m0.64298 272.44 3.1712 9.5402 22.152 1.7742-22.152 1.7482-3.1712 9.4749 25.323-11.223z" />', ' </g>', '</svg>' ].join('') ); }; MediACore.creator['add-file-ico'] = function () { return MediaInput_( [ '<svg class="add-file" width="100" height="100" version="1.1" viewBox="0 0 26.458 26.458" xmlns="http://www.w3.org/2000/svg">', ' <g transform="translate(0 -270.54)">', ' <path d="m4.2431 295.69c-0.74006-0.0759-1.4136-0.33772-2.0047-0.77942-0.19965-0.14919-0.60549-0.55475-0.75233-0.75182-0.45099-0.60524-0.7154-1.2913-0.77699-2.016-0.01275-0.15007-0.01628-2.6111-0.01252-8.7468 0.0049-8.0504 0.0068-8.5472 0.03338-8.6986 0.0883-0.50391 0.22692-0.91024 0.44705-1.3104 0.52794-0.95973 1.452-1.6645 2.5119-1.9158 0.44319-0.10508 0.12729-0.0972 4.1445-0.10308 2.5538-4e-3 3.6864-1e-4 3.7795 0.0121 0.38853 0.0508 0.80777 0.24687 1.2709 0.59434 0.44102 0.33085 0.68272 0.55272 1.7227 1.5813 0.46507 0.45998 1.2812 1.2664 1.8136 1.7921 0.96172 0.94958 1.3847 1.3824 1.696 1.7354 0.61073 0.69257 0.92 1.2063 1.0441 1.7344 0.02613 0.11122 0.02875 0.28598 0.03409 2.2731 0.0047 1.7451 0.0018 2.1574-0.01502 2.178-0.01424 0.0174-0.10685 0.0394-0.2936 0.0699-0.45695 0.0745-1.0078 0.22363-1.4356 0.38862-0.10025 0.0387-0.1888 0.0663-0.19678 0.0613-0.0085-5e-3 -0.01461-0.7983-0.01475-1.9156-2.09e-4 -1.6438-0.0036-1.9208-0.0245-2.0096-0.06972-0.29578-0.28642-0.50043-0.63767-0.60222-0.32942-0.0955-0.31104-0.0947-2.4299-0.10482l-1.9437-9e-3 -0.12495-0.0442c-0.25474-0.0901-0.45899-0.26526-0.5666-0.48578-0.10853-0.22238-0.10356-0.127-0.10407-1.9994-4.63e-4 -1.7153-0.01031-2.1544-0.05446-2.4288-0.06935-0.43095-0.22893-0.69171-0.5027-0.82138l-0.10904-0.0516h-3.1807c-3.4262 0-3.27-4e-3 -3.5482 0.0835-0.68034 0.21325-1.1718 0.754-1.3329 1.4666l-0.0345 0.15261v8.5059c0 8.1045 0.0014 8.5125 0.02871 8.6468 0.08088 0.39719 0.25808 0.72858 0.53956 1.0091 0.28082 0.27984 0.576 0.44186 0.98191 0.53896 0.11389 0.0273 0.36156 0.0293 4.5294 0.0374l4.409 9e-3 0.02019 0.0402c0.0111 0.0221 0.07695 0.15943 0.14632 0.30521s0.17519 0.3518 0.23515 0.45783c0.14341 0.25357 0.43703 0.69284 0.61725 0.92343 0.0793 0.10148 0.14077 0.19003 0.13659 0.19679-0.0073 0.0118-9.9306 0.0132-10.046 1e-3z" />', ' <path transform="matrix(.26458 0 0 .26458 0 270.54)" d="m72.469 65.742v7.4062h-7.4062v7.2852h7.4062v7.2812h7.2793v-7.2812h7.3535v-7.2852h-7.3535v-7.4062zm24.948 11.119a21.371 21.371 0 0 1-21.371 21.371 21.371 21.371 0 0 1-21.371-21.371 21.371 21.371 0 0 1 21.371-21.371 21.371 21.371 0 0 1 21.371 21.371z" style="fill-rule:evenodd;" />', ' <path d="m17.256 283.76 1.921-0.47607-0.04725-4.2884c0-0.50159-0.29516-1.2441-1.0789-2.0168l-4.6989-4.6324c-0.73814-0.72769-1.5947-0.97084-2.1519-0.97084h-7.0235c-2.1533 0.0144-3.4601 2.6226-3.4778 3.4778v17.284c0 2.121 2.2409 3.5346 3.5346 3.5346h10.058l-1.1146-1.9305h-8.6658c-1.1271 0-1.8503-1.1115-1.8503-1.8503v-16.867c0-1.0721 1.1373-1.6977 1.6977-1.6977h6.2175c0.43142 0 0.8103 0.28958 0.8103 1.1742v3.714c0 0.24768 0.36442 0.90967 0.90968 0.90967h3.2537c1.2453 0 1.6905 0.32876 1.6905 1.1613z" />', ' </g>', '</svg>' ].join('') ); }; MediACore.creator['add-image-ico'] = function () { return MediaInput_( [ '<svg class="add-image" width="100" height="100" version="1.1" viewBox="0 0 26.458 26.458" xmlns="http://www.w3.org/2000/svg" xmlns:cc="http://creativecommons.org/ns#" xmlns:dc="absol/src/HTML5/Elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">', ' <g transform="translate(0 -270.54)">', ' <path d="m24.73 288.69a5.9808 5.9808 0 0 1-5.9808 5.9808 5.9808 5.9808 0 0 1-5.9808-5.9808 5.9808 5.9808 0 0 1 5.9808-5.9808 5.9808 5.9808 0 0 1 5.9808 5.9808zm1.503-0.037a7.5843 7.5843 0 0 1-7.5843 7.5843 7.5843 7.5843 0 0 1-7.5843-7.5843 7.5843 7.5843 0 0 1 7.5843-7.5843 7.5843 7.5843 0 0 1 7.5843 7.5843z" style="fill-rule:evenodd;fill:#414141"/>', ' <path d="m17.869 284.42v3.4127h-3.4081v1.6066h3.4081v3.438h1.6061v-3.438h3.4432v-1.6066h-3.4432v-3.4127z" style="fill-rule:evenodd;fill:#414141"/>', ' <path d="m24.614 281.39v-6.1305c0-1.6957-1.2841-2.6602-2.6602-2.6602h-18.412c-1.4547 0-2.7249 1.0223-2.7249 2.7249v14.986c0 1.2346 0.99768 2.6028 2.586 2.586h6.9542c-0.36184-0.63963-0.51495-1.0286-0.69323-1.6506h-6.4562c-0.29938 0-0.72246-0.40379-0.72246-0.72247v-1.8082l6.0428-6.7569 2.0296 2.0129 0.9605-1.3029-2.9734-3.1488-5.9885 6.7736v-11.426c0-0.24935 0.30766-0.63476 0.63476-0.63476h18.934c0.3592 0 0.84357 0.19284 0.84357 0.84357v5.2285c0.61147 0.22444 1.1564 0.59412 1.6454 1.0858z" style="fill:#414141"/>', ' <circle cx="17.869" cy="277.61" r="1.6891" style="fill-rule:evenodd;fill:#414141"/>', ' </g>', '</svg>' ].join('') ); }; MediACore.creator['attachment-ico'] = function () { return MediaInput_( [ '<svg class="attachment" width="1024" height="1024" version="1.1" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" >', ' <path d="M145.6 0C100.8 0 64 35.2 64 80v862.4C64 987.2 100.8 1024 145.6 1024h732.8c44.8 0 81.6-36.8 81.6-81.6V324.8L657.6 0h-512z" fill="#8199AF"/>', ' <path d="M960 326.4v16H755.2s-100.8-20.8-99.2-108.8c0 0 4.8 92.8 97.6 92.8H960z" fill="#617F9B"/>', ' <path d="M657.6 0v233.6c0 25.6 17.6 92.8 97.6 92.8H960L657.6 0z" fill="#fff"/>', ' <path d="m491.77 770.31c17.6-19.2 17.6-48 0-67.2s-48-17.6-65.6 0l-147.2 147.2c-17.6 17.6-17.6 48 0 65.6s48 19.2 65.6 0l91.2-89.6c4.8-4.8 4.8-12.8 0-17.6s-14.4-6.4-19.2 0l-57.6 56c-8 8-19.2 8-27.2 0s-8-20.8 0-28.8l56-56c20.8-20.8 54.4-20.8 75.2 0s20.8 54.4 0 75.2l-89.6 89.6c-33.6 33.6-88 33.6-123.2 0-33.6-33.6-33.6-88 0-121.6l147.2-147.2c33.6-33.6 89.6-33.6 123.2 0s33.6 88 0 121.6l-14.4 14.4c-1.6-14.4-6.4-28.8-16-41.6z" style="fill:#fff"/>', ' <path d="m130.09 23.864h504.75v182.93h-545.65v-140.08c0.34155-16.845 13.608-42.414 40.9-42.847z" style="fill-opacity:.29648;fill-rule:evenodd;fill:#fff"/>', '</svg>' ] .join('') ); }; MediACore.creator['attachment-ico'].property = { ext: { set: function (value) { value = value || ''; if (this.$ext) { this.$ext.selfRemove(); } this.$ext = Svg/* default.ShareInstance._ */.ZP.ShareInstance._('<text text-anchor="middle" x="321.39" y="170" font-size="145.76" style="fill:white;" >' + value + '</text>').addTo(this); }, get: function () { return this._ext || ''; } } }; MediACore.creator['times-ico'] = function () { return MediaInput_( [ '<svg class="times" width="100" height="100" version="1.1" viewBox="0 0 26.458 26.458" xmlns="http://www.w3.org/2000/svg">', ' <g transform="translate(0 -270.54)">', ' <path d="m7.7013 276.49 5.4832 5.4832 5.5494-5.5494 1.7874 1.7874-5.5291 5.5291 5.4957 5.4957-1.754 1.754-5.5124-5.5124-5.5542 5.5542-1.7623-1.7623 5.5375-5.5375-5.5208-5.5208zm17.103 7.3351a11.558 11.558 0 0 1-11.558 11.558 11.558 11.558 0 0 1-11.558-11.558 11.558 11.558 0 0 1 11.558-11.558 11.558 11.558 0 0 1 11.558 11.558z" style="fill-rule:evenodd;"/>', ' </g>' ].join('') ); }; MediACore.creator['download-ico'] = function () { return MediaInput_( [ '<svg class="download" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">', ' <g transform="translate(0,-197)">', ' <path d="m44.888 209.14h13.982c1.1087 0.0459 2.2328 0.74137 2.317 2.3612v23.694h13.622c1.9742-0.18801 3.004 2.6244 1.9175 4.1118l-23.469 23.918c-0.876 0.77477-1.9993 0.77232-2.9362 0l-23.559-24.009c-0.86532-1.0422 0.11658-4.1953 2.3821-4.2047h13.268v-22.939c-0.08167-1.1772 0.78292-2.9507 2.4768-2.9312z" style="fill:#00c3e5"/>', ' <path d="m86.97 276.99a3.5027 3.5696 0 0 1-3.5027 3.5696 3.5027 3.5696 0 0 1-3.5027-3.5696 3.5027 3.5696 0 0 1 3.5027-3.5696 3.5027 3.5696 0 0 1 3.5027 3.5696zm-12.768 0a3.5027 3.5696 0 0 1-3.5027 3.5696 3.5027 3.5696 0 0 1-3.5027-3.5696 3.5027 3.5696 0 0 1 3.5027-3.5696 3.5027 3.5696 0 0 1 3.5027 3.5696zm-60.003-16.135h24.609c9.1206 13.508 17.573 12.942 26.609 0h23.839c2.8529 5e-3 3.5087 2.3205 3.4679 3.8227v18.953c0.04867 1.3083-1.5145 2.9901-2.7505 2.9832h-76.253c-1.049 0.0441-2.6554-1.4851-2.6306-3.1451l-1.56e-4 -18.792c0.0024-1.3549 0.50958-3.7927 3.1091-3.8227z" style="fill-rule:evenodd;fill:#00c3e5"/>', ' </g>', '</svg>' ].join('') ); }; MediACore.creator['plus-ico'] = function () { return MediaInput_( '<svg class="_7oal" height="24" width="24" viewBox="0 0 24 24"><g fill="none" fill-rule="evenodd"><polygon points="-6,30 30,30 30,-6 -6,-6 "></polygon><path d="m18,11l-5,0l0,-5c0,-0.552 -0.448,-1 -1,-1c-0.5525,0 -1,0.448 -1,1l0,5l-5,0c-0.5525,0 -1,0.448 -1,1c0,0.552 0.4475,1 1,1l5,0l0,5c0,0.552 0.4475,1 1,1c0.552,0 1,-0.448 1,-1l0,-5l5,0c0.552,0 1,-0.448 1,-1c0,-0.552 -0.448,-1 -1,-1m-6,13c-6.6275,0 -12,-5.3725 -12,-12c0,-6.6275 5.3725,-12 12,-12c6.627,0 12,5.3725 12,12c0,6.6275 -5.373,12 -12,12" ></path></g></svg>' ); }; ACore/* default.install */.Z.install(MediaInput); /* harmony default export */ const js_MediaInput = (MediaInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/messageinput/MessageInput.js + 2 modules var MessageInput = __webpack_require__(4877); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/numberinput.css var numberinput = __webpack_require__(5699); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/numberinput/NITextController.js /*** * * @param {NumberInput} elt * @constructor */ function NITextController(elt) { this.elt = elt; /*** * * @type {HTMLInputElement|AElement} */ this.$input = this.elt.$input; Object.keys(NITextController.prototype).forEach(key => { if (key.startsWith('on')) this[key] = this[key].bind(this); }); this.elt.$input.on('keydown', this.onKeyDown) .on('paste', this.onKeyDown) .on('blur', this.onBlur); } NITextController.prototype.estimateWidthBy = function (text) { if (this.elt.hasClass('as-pressing')) return; var bound = this.elt.getBoundingClientRect(); var width = (0,Text.measureText)(text, this.$input.getComputedStyleValue('font')).width; this.elt.addStyle('--text-width', width + 'px'); var newBound = this.elt.getBoundingClientRect(); if (newBound.width !== bound.width) ResizeSystem/* default.requestUpdateUpSignal */.Z.requestUpdateUpSignal(this.elt, true); }; NITextController.prototype.flushTextToValue = function () { var thousandsSeparator = this.elt.thousandsSeparator || ''; var decimalSeparator = this.elt.decimalSeparator; var text = this.$input.value; var floatText = text.split(thousandsSeparator).join('').split(decimalSeparator).join('.'); this.elt._value = parseFloat(floatText); if (!(0,utils.isRealNumber)(this.elt._value)) this.elt._value = null; this.elt._value = this.elt.value;//normalize value }; NITextController.prototype.flushValueToText = function () { var formatter; var opt = Object.assign({}, this.elt._format); var value = this.elt.value; var text, parts; if (value === null) { text = ''; } else if (opt.locales === 'none') { if (opt.maximumFractionDigits === 20) { text = value + ''; } else if (opt.maximumFractionDigits === opt.minimumIntegerDigits) { text = value.toFixed(opt.maximumFractionDigits); } else { text = value + ''; parts = text.split('.'); parts[1] = parts[1] || ''; if (parts[1].length < opt.minimumIntegerDigits) { text = value.toFixed(opt.minimumIntegerDigits); } } } else { formatter = new Intl.NumberFormat(this.elt._format.locales, opt); text = formatter.format(value); } this.$input.value = text; this.estimateWidthBy(text); }; NITextController.prototype.reformat = function () { var thousandsSeparator = this.elt.thousandsSeparator || ''; var decimalSeparator = this.elt.decimalSeparator; var caretPos = this.$input.selectionEnd; var value = this.$input.value; var parts = value.split(decimalSeparator); var caretWTSPos = value.substring(0, caretPos).split(thousandsSeparator).join('').length; parts[0] = parts[0].split('').filter(x => x.match(/[0-9\-]/)).reduce((ac, c, i, arr) => { ac += c; if ((i + 1 < arr.length) && ((arr.length - i) % 3 === 1) && arr[i] !== '-') { ac += thousandsSeparator; } return ac; }, ''); if (parts[1]) parts[1] = parts[1].split('').filter(x => x.match(/[0-9]/)).join(''); var newValue = parts.join(decimalSeparator); var newCaretPos = 0; var counter = 0; for (newCaretPos = 0; newCaretPos < newValue.length && counter < caretWTSPos; ++newCaretPos) { if (newValue[newCaretPos].match(/[0-9\-]/) || newValue[newCaretPos] === decimalSeparator) { counter++; } } this.$input.value = newValue; this.$input.setSelectionRange(newCaretPos, newCaretPos); this.estimateWidthBy(newValue); }; NITextController.prototype.onBlur = function () { this.flushValueToText(); this.elt.notifyChanged({ by: 'blur' }); } /*** * @param {KeyboardEvent|ClipboardEvent|{}} event * @param {boolean=} event */ NITextController.prototype.onKeyDown = function (event, dontInsert) { var key = event.type === 'keydown' ? (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event) : ''; if ((key.length === 1 && !key.match(/[0-9.,\-]/)) || key.match(/^shift-.$/)) { event.preventDefault(); return; } var thousandsSeparator = this.elt.thousandsSeparator; var decimalSeparator = this.elt.decimalSeparator; var value = this.$input.value; var sStart = this.$input.selectionStart; var sEnd = this.$input.selectionEnd; var sDir = this.$input.selectionDirection; var onKeys = {}; onKeys.unidentified = () => { var oldText = this.$input.value; setTimeout(() => { var newText = this.$input.value; if (oldText === newText) return; var key = newText[sStart]; if (!key) return;//todo var fakeEvent = { type: 'keydown', preventDefault: noop/* default */.Z, key: key } if (key.match(/^[0-9.]$/)) { this.onKeyDown(fakeEvent, true); } else { this.$input.value = oldText; this.$input.setSelectionRange(sStart, sStart); this.onKeyDown(fakeEvent); } }, 10); }; onKeys.process = () => { setTimeout(() => { this.flushTextToValue(); }, 10); } onKeys.paste = () => { var clipboardData = event.clipboardData || window.clipboardData; var pastedData = clipboardData.getData('Text'); var hasSeparator = value.indexOf(decimalSeparator) >= 0; pastedData = pastedData.split('').filter(c => { if (c.match(/[0-9]/)) return true; if (!hasSeparator && c === hasSeparator) { hasSeparator = true; return true; } }).join(''); if (this.elt.readOnly) return; if (!dontInsert) { this.$input.value = value.substring(0, sStart) + pastedData + value.substring(sEnd); this.$input.setSelectionRange(sStart + pastedData.length, sStart + pastedData.length); } this.reformat(); this.flushTextToValue(); }; onKeys.arrowleft = () => { if (sStart === sEnd) { if (value[sStart - 2] === thousandsSeparator) { this.$input.setSelectionRange(sStart - 2, sStart - 2); } else if (sStart > 0) { this.$input.setSelectionRange(sStart - 1, sStart - 1); } } else { this.$input.setSelectionRange(sStart, sStart); } }; onKeys['shift-arrowleft'] = () => { var newSStart; var newSEnd; if (sDir === 'backward') { newSStart = sEnd; newSEnd = sStart - 1; } else { newSStart = sStart; newSEnd = sEnd - 1; } if (value[newSEnd - 1] === thousandsSeparator) newSEnd--; newSEnd = Math.max(0, newSEnd); if (newSStart <= newSEnd) { this.$input.setSelectionRange(newSStart, newSEnd, "forward"); } else { this.$input.setSelectionRange(newSEnd, newSStart, "backward"); } }; onKeys.arrowright = () => { if (sStart === sEnd) { if (value[sStart] === thousandsSeparator) { this.$input.setSelectionRange(sStart + 2, sStart + 2); } else if (sStart < value.length) { this.$input.setSelectionRange(sStart + 1, sStart + 1); } } else { this.$input.setSelectionRange(sStart, sStart); } }; onKeys['shift-arrowright'] = () => { var newSStart; var newSEnd; if (sDir === 'backward') { newSStart = sEnd; newSEnd = sStart + 1; } else { newSStart = sStart; newSEnd = sEnd + 1; } if (value[newSEnd - 1] === thousandsSeparator) newSEnd++; newSEnd = Math.min(value.length, newSEnd); if (newSStart <= newSEnd) { this.$input.setSelectionRange(newSStart, newSEnd, "forward"); } else { this.$input.setSelectionRange(newSEnd, newSStart, "backward"); } }; onKeys.number = () => { if (this.elt.readOnly) return; if (!dontInsert) { this.$input.value = value.substring(0, sStart) + key + value.substring(sEnd); this.$input.setSelectionRange(sStart + 1, sStart + 1); } this.reformat(); this.flushTextToValue(); }; onKeys['-'] = () => { if (this.elt.readOnly) return; if (value.indexOf('-') >= 0 || sStart > 0) return; this.$input.value = '-' + value.substring(sEnd); this.$input.setSelectionRange(1, 1); this.reformat(); this.flushTextToValue(); }; onKeys.backspace = () => { if (this.elt.readOnly) return; var delStart, delEnd; if (sStart === sEnd) { if (sStart > 0) { delStart = sStart - 1; delEnd = sStart; } } else { delStart = sStart; delEnd = sEnd; } if (delStart === undefined || delEnd === undefined) return; this.$input.value = value.substring(0, delStart) + value.substring(delEnd); this.$input.setSelectionRange(delStart, delStart); this.reformat(); this.flushTextToValue(); }; onKeys.enter = () => { if (this.elt.readOnly) return; this.flushValueToText(); this.$input.setSelectionRange(this.$input.value.length, this.$input.value.length); this.elt.notifyChanged({ by: 'enter' }); }; onKeys.delete = () => { if (this.elt.readOnly) return; var delStart, delEnd; if (sStart === sEnd) { if (sStart < value.length) { delStart = sStart; delEnd = sStart + 1; if (value[delStart] === thousandsSeparator) delEnd++; } } else { delStart = sStart; delEnd = sEnd; } if ((0,utils.isNaturalNumber)(delStart) && (0,utils.isNaturalNumber)(delEnd)) { this.$input.value = value.substring(0, delStart) + value.substring(delEnd); this.$input.setSelectionRange(delStart, delStart); this.reformat(); this.flushTextToValue(); } }; onKeys.decimalSeparator = () => { if (this.elt.readOnly) return; var idx = value.indexOf(decimalSeparator); if (idx >= 0) { if (idx < sStart) { this.$input.value = value.substring(0, sStart).replace(decimalSeparator, '') + decimalSeparator + value.substring(sEnd); this.$input.setSelectionRange(sStart, sStart); } else if (idx < sEnd) { this.$input.value = value.substring(0, sStart) + decimalSeparator + value.substring(sEnd); this.$input.setSelectionRange(sStart + 1, sStart + 1); } else { this.$input.value = value.substring(0, sStart) + decimalSeparator + value.substring(sEnd).replace(decimalSeparator, ''); this.$input.setSelectionRange(sStart + 1, sStart + 1); } } else { this.$input.value = value.substring(0, sStart) + decimalSeparator + value.substring(sEnd); this.$input.setSelectionRange(sStart + 1, sStart + 1); } this.reformat(); this.flushTextToValue(); }; if (key === 'arrowup') { if (sStart === 0 && sEnd === 0) { this.elt.nextStep(); event.preventDefault(); this.$input.setSelectionRange(0, 0); } } else if (key === 'arrowdown') { if (sStart === value.length && sEnd === value.length) { this.elt.prevStep(); event.preventDefault(); this.$input.setSelectionRange(this.$input.value.length, this.$input.value.length); } } else if (key === 'ctrl-x') { onKeys.delete(); } else if (onKeys[event.type]) { event.preventDefault(); onKeys[event.type](); } else if (onKeys[key]) { event.preventDefault(); onKeys[key](); } else if (key.match(/^[0-9.]$/)) { event.preventDefault(); onKeys.number(); } else if (key === decimalSeparator) { event.preventDefault(); onKeys.decimalSeparator(); } }; /* harmony default export */ const numberinput_NITextController = (NITextController); // EXTERNAL MODULE: ./node_modules/absol/src/Math/int.js var Math_int = __webpack_require__(7988); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/numberinput/NumberInput.js var NumberInput_ = ACore/* default._ */.Z._; var NumberInput_$ = ACore/* default.$ */.Z.$; /*** * @typedef NumberInputFormat * @property {string} locales * @property {string|null} decimalSeparator * @property {string|null} thousandSeparator */ /*** * @extends AElement * @constructor */ function NumberInput() { /*** * * @type {HTMLInputElement|AElement} */ this.$input = NumberInput_$('input', this); // .on('keyup', this.eventHandler.keyup) // .on('paste', this.eventHandler.paste) // .on('change', this.eventHandler.change); this.$input.value = '0'; this._prevValue = 0;//to know whenever the value changed this._value = 0; this._max = Infinity; this._min = -Infinity; this._step = 1; this._format = this._makeDefaultFormat(); this.$upBtn = NumberInput_$('.absol-number-input-button-up-container button', this) .on('mousedown', this.eventHandler.mouseDownBtn.bind(this, 1)); this.$downBtn = NumberInput_$('.absol-number-input-button-down-container button', this) .on('mousedown', this.eventHandler.mouseDownBtn.bind(this, -1)); this.textCtrl = new numberinput_NITextController(this); this.$domSignal = NumberInput_('attachhook').addTo(this); this.$domSignal.once('attached', () => { this.textCtrl.estimateWidthBy(this.$input.value); }); this.dragCtrl = new NIDragController(this); /**** * @name min * @type {number} * @memberOf NumberInput# */ /**** * @name max * @type {number} * @memberOf NumberInput# */ /**** * @name value * @type {number} * @memberOf NumberInput# */ /**** * @name format * @type {NumberInputFormat} * @memberOf NumberInput# */ /**** * @name thousandsSeparator * @type {string|null} * @memberOf NumberInput# */ /**** * @name decimalSeparator * @type {string|null} * @memberOf NumberInput# */ /**** * @name readOnly * @type {boolean} * @memberOf NumberInput# */ /**** * @name disabled * @type {boolean} * @memberOf NumberInput# */ /**** * @name notNull * @type {boolean} * @memberOf NumberInput# */ /**** * @name stepper * @type {boolean} * @memberOf NumberInput# */ /** * @type {number} * @name step * @memberOf NumberInput# */ /** * @type {boolean} * @name valueDraggable * @memberOf NumberInput# */ this.valueDraggable = false; /*** * * @type {number|null} * @name rawValue */ } NumberInput.tag = 'NumberInput'.toLowerCase(); NumberInput.render = function () { return NumberInput_({ class: ['absol-number-input', 'as-must-not-null'], extendEvent: ['change'], child: [ { class: 'absol-number-input-text-container', child: 'input[type="text"]' }, { class: 'absol-number-input-button-up-container', child: { tag: 'button', child: 'span.mdi.mdi-menu-up' } }, { class: 'absol-number-input-button-down-container', child: { tag: 'button', child: 'span.mdi.mdi-menu-down' } } ] }); }; NumberInput.prototype.addStyle = function (arg0, arg1) { if (arg0 === 'textAlign' || arg0 === 'text-align') { this.$input.addStyle(arg0, arg1); return this; } else { return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } }; NumberInput.prototype._makeDefaultFormat = function () { var res = { locales: 'vi-VN', maximumFractionDigits: 20, minimumFractionDigits: 0, pow10: null//only apply if maximumFractionDigits === 0 }; if (window['systemconfig'] && window['systemconfig']['numberFormatLocales']) { res.locales = window['systemconfig']['numberFormatLocales']; } return res; }; /*****17 number********/ NumberInput.prototype.nextStep = function () { var ofs = 0; if ((0,utils.isRealNumber)(this.min)) { ofs = this.min; } var step = this.step; var idx = (0,utils.nearFloor)((this.value - ofs) / step, 0.01); this._value = Math.min(step * (idx + 1) + ofs, this.max); this._value = (0,Math_int.numberAutoFixed)(this._value, (step + '').length); this.textCtrl.flushValueToText(); }; NumberInput.prototype.prevStep = function () { var ofs = 0; if ((0,utils.isRealNumber)(this.min)) { ofs = this.min; } var step = this.step; var idx = (0,utils.nearFloor)((this.value - ofs) /step, 0.01); this._value = Math.max(step * (idx - 1) + ofs, this.min); this._value = (0,Math_int.numberAutoFixed)(this._value, (step + '').length); this.textCtrl.flushValueToText(); }; NumberInput.eventHandler = {}; NumberInput.eventHandler.mouseDownBtn = function (dir, event) { if (EventEmitter/* default.isMouseRight */.ZP.isMouseRight(event)) return; var self = this; var pressing = true; var timeout = -1; var i = 0; this.addClass('as-pressing'); var tick = () => { if (pressing) { if (i === 0 || i >= 4) { if (dir > 0) this.nextStep(); else this.prevStep(); if (i === 0) { this.notifyChanged({ by: 'press_button' }); } else { this.notifyChanged({ by: 'long_press_button' }); } } ++i; self.__pressingUpTimeout__ = setTimeout(tick, 100); } } var finish = (event) => { pressing = false; this.removeClass('as-pressing'); if (timeout >= 0) { clearTimeout(timeout); timeout = -1; } document.removeEventListener('mouseup', finish); document.removeEventListener('mouseleave', finish); if (event.type === 'mouseup') { this.$input.focus(); } this.notifyChanged({ originEvent: event, by: 'press_button' }); this.textCtrl.estimateWidthBy(this.$input.value); } document.addEventListener('mouseup', finish); document.addEventListener('mouseleave', finish); tick(); }; NumberInput.prototype.focus = function () { this.$input.focus(); } NumberInput.prototype.notifyChanged = function (option) { option = option || {}; var value = this.value; if (this._prevValue !== value) { this.emit('change', Object.assign({ target: this, value: value, previousValue: this._prevValue }, option || {}), this); this._prevValue = value; // this._prevBy = option.by; } }; NumberInput.property = {}; NumberInput.property.rawValue = { get: function () { return this._prevValue; } }; NumberInput.property.value = { set: function (value) { if (typeof value === "string") value = parseFloat(value); if (typeof (value) != 'number' || isNaN(value)) value = null; this._value = value; this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { var value = this._value; if (value === null) { if (this.notNull) { value = 0; } else { return null; } } if (this._format.maximumFractionDigits === 0) { if ((0,utils.isNaturalNumber)(this._format.pow10)) { value = Math.round(value / Math.pow(10, this._format.pow10)) * Math.pow(10, this._format.pow10); } else { value = Math.round(value); } } else if (this._format.maximumFractionDigits < 20) value = (0,Math_int.numberAutoFixed)(value, this._format.maximumFractionDigits); value = Math.min(this.max, Math.max(value, this.min)); return value; } }; NumberInput.property.step = { set: function (value) { if (!(0,utils.isRealNumber)(value)) value = 1; if (value === 0) value = 1; value = Math.abs(value); this._step = value; }, get: function () { if (this._format.maximumFractionDigits === 0 && (0,utils.isNaturalNumber)(this._format.pow10)) { return Math.max(this._step, Math.pow(10, this._format.pow10)); } return this._step; } }; NumberInput.property.max = { set: function (value) { if (!(0,utils.isRealNumber)(value)) { value = Infinity; } this._max = value; this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { return Math.max(this._max, this._min); } }; NumberInput.property.min = { set: function (value) { if (!(0,utils.isRealNumber)(value)) { value = -Infinity; } this._min = value; this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { return Math.min(this._min, this._max); } }; NumberInput.prototype.locales2Format = { 'vi-VN': { decimalSeparator: ',', thousandsSeparator: '.' }, 'en-US': { decimalSeparator: '.', thousandsSeparator: ',' }, 'none': { decimalSeparator: '.', thousandsSeparator: '' } }; NumberInput.property.decimalSeparator = { get: function () { var lF = this.locales2Format[this._format.locales]; if (lF) return lF.decimalSeparator; return '.'; }, set: () => { } }; NumberInput.property.thousandsSeparator = { get: function () { var lF = this.locales2Format[this._format.locales]; if (lF) return lF.thousandsSeparator; return null; }, set: () => { } }; NumberInput.property.disabled = { set: function (value) { this.$input.disabled = !!value; this.$upBtn.disabled = !!value; this.$downBtn.disabled = !!value; if (value) this.addClass('absol-disabled'); else this.removeClass('absol-disabled'); }, get: function () { return this.$input.disabled; } }; NumberInput.property.readOnly = { set: function (value) { this.$input.readOnly = !!value; if (value) this.addClass('as-read-only'); else this.removeClass('as-read-only'); }, get: function () { return this.$input.readOnly; } }; NumberInput.property.format = { /*** * @this NumberInput * @param value * @this NumberInput */ set: function (value) { if (value in this.locales2Format) { this._format = { locales: value, maximumFractionDigits: this._format.maximumFractionDigits, minimumFractionDigits: this._format.minimumFractionDigits, }; } else if (!value) { this._format = this._makeDefaultFormat(); } else { this._format = Object.assign(this._makeDefaultFormat(), value); } // console.log(this._format) this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { return this._format; } }; NumberInput.property.floatFixed = { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.round(value); if (value >= 0) { value = Math.min(value, 20); this._format.maximumFractionDigits = value; this._format.minimumFractionDigits = value; delete this._format.pow10; } else { this._format.maximumFractionDigits = 0; this._format.minimumFractionDigits = 0; this._format.pow10 = -value; } } else { this._format.maximumFractionDigits = 20; delete this._format.minimumFractionDigits; delete this._format.pow10; } this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { if (this._format.maximumFractionDigits === 20) return null; if (this._format.maximumFractionDigits === 0 && this._format.pow10 > 0) return -this._format.pow10; return this._format.maximumFractionDigits; } }; NumberInput.property.notNull = { set: function (value) { if (value) { this.addClass('as-must-not-null'); } else { this.removeClass('as-must-not-null'); } this._prevValue = this.value; this.textCtrl.flushValueToText(); }, get: function () { return this.hasClass('as-must-not-null'); } }; NumberInput.property.stepper = { set: function (value) { if (value) { this.addClass('as-has-stepper'); } else { this.removeClass('as-has-stepper'); } }, get: function () { return this.hasClass('as-has-stepper'); } } ACore/* default.install */.Z.install('NumberInput'.toLowerCase(), NumberInput); /* harmony default export */ const numberinput_NumberInput = (NumberInput); /** * * @param {NumberInput} elt * @constructor */ function NIDragController(elt) { this.elt = elt; NumberInput_({ elt: elt, tag: Hanger/* default */.Z }); Object.keys(this.constructor.prototype).forEach((key) => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this.elt.on({ dragstart: this.ev_dragStart, drag: this.ev_drag, dragend: this.ev_dragEnd, draginit: this.ev_dragInit }); this.state = 0; this.prevDistance = 0; this.$mouseLine = null; } NIDragController.prototype.ev_dragInit = function (event) { if (!this.elt.valueDraggable || EventEmitter/* default.isMouseRight */.ZP.isMouseRight(event.originEvent)) { event.cancel(); } }; NIDragController.prototype.ev_dragStart = function (event) { if (this.elt.valueDraggable === false) return; }; NIDragController.prototype.ev_drag = function (event) { if (this.calcDistance(event) > 0 && !this.isSelecting() && this.state === 0) { this.state = 1; document.body.classList.add('as-number-input-force-dragging'); this.$mouseLine = NumberInput_({ tag: 'div', class: 'as-number-input-mouse-line', style: { zIndex: (0,utils.findMaxZIndex)(this.elt) + 1 } }).addTo(document.body); } if (this.state !== 1) return; var distance = this.calcDistance(event); var delta = distance - this.prevDistance; if (delta >= 1) { this.prevDistance = distance; this.elt.nextStep(); } else if (delta <= -1) { this.prevDistance = distance; this.elt.prevStep(); } var deltaVector = event.currentPoint.sub(event.startingPoint); var length = deltaVector.abs(); var angle = deltaVector.direction(); this.$mouseLine.addStyle({ left: event.startingPoint.x + 'px', top: event.startingPoint.y + 'px', width: length + 'px', transform: 'rotate(' + angle + 'rad)', transformOrigin: '0 0' }); }; NIDragController.prototype.ev_dragEnd = function (event) { this.elt.removeClass('as-dragging'); document.body.classList.remove('as-number-input-force-dragging'); if (this.$mouseLine) { this.$mouseLine.remove(); this.$mouseLine = null; } this.state = 0; this.elt.emit('change', { by: 'drag' }); }; NIDragController.prototype.isSelecting = function () { return this.elt.$input.selectionStart !== this.elt.$input.selectionEnd; }; NIDragController.prototype.calcDistance = function (event) { var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.getBoundingClientRect()); var mouse = new Vec2/* default */.Z(event.clientX, event.clientY); bound.x -= 10; bound.y -= 10; bound.height += 20; bound.width += 20; if (bound.containsPoint(mouse)) return 0; var res = Infinity; if (mouse.x > bound.x && mouse.x < bound.x + bound.width) { res = Math.min(res, Math.abs(mouse.y - bound.y), Math.abs(mouse.y - bound.y - bound.height)); } else if (mouse.y > bound.y && mouse.y < bound.y + bound.height) { res = Math.min(res, Math.abs(mouse.x - bound.x), Math.abs(mouse.x - bound.x - bound.width)); } else { res = Math.min(res, mouse.sub(bound.A()).abs(), mouse.sub(bound.B()).abs(), mouse.sub(bound.C()).abs(), mouse.sub(bound.D()).abs(), ); } return res; }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/NumberSpanInput.js var NumberSpanInput_ = ACore/* default._ */.Z._; var NumberSpanInput_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function NumberSpanInput() { this.ev_keydown = this.ev_keydown.bind(this); this.on('keydown', this.ev_keydown, true); this.readOnly = false; this.value = 0; this.on('paste', function (event) { event.preventDefault(); }) } NumberSpanInput.tag = 'NumberSpanInput'.toLowerCase(); NumberSpanInput.render = function () { return NumberSpanInput_({ tag: 'span', child: { text: '' } }); }; NumberSpanInput.prototype.selectAll = function(){ var sel; if (window.getSelection) { sel = window.getSelection(); sel.removeAllRanges(); var range = document.createRange(); range.selectNode(this.childNodes[this.childNodes.length - 1]); sel.addRange(range); } else { console.error("TimePicker: Not support!") } }; NumberSpanInput.prototype.selectEnd = function(){ var sel; if (window.getSelection) { sel = window.getSelection(); sel.removeAllRanges(); this._autoAddZero(); var length = this.firstChild.data.length; var range = document.createRange(); range.setStart(this.firstChild, length); range.setEnd(this.firstChild, length); sel.addRange(range); } else { console.error("TimePicker: Not support!") } }; NumberSpanInput.prototype.selectNone = function(){ var sel; if (document.activeElement === this){ sel = window.getSelection(); sel.removeAllRanges(); } } NumberSpanInput.prototype._autoAddZero = function (){ if (!this.firstChild){ this.addChild(NumberSpanInput_({text:'0'})); } } /*** * * @param {KeyboardEvent} event */ NumberSpanInput.prototype.ev_keydown = function (event) { if (event.key && event.key.length == 1 && !event.ctrlKey && !event.altKey) { if (event.key.match(/[0-9]/)) { } else { event.preventDefault(); } } else if (event.key == 'Enter'){ event.preventDefault(); } }; NumberSpanInput.property = {}; NumberSpanInput.property.readOnly = { set: function (value) { this.contentEditable = !value; }, get: function () { return this.contentEditable === false|| this.contentEditable === 'false'; } }; /*** * * @type {NumberSpanInput} */ NumberSpanInput.property.value = { set: function (value) { this._autoAddZero(); this.firstChild.data = value + ''; }, get: function () { return (this.firstChild && this.firstChild.data)||''; } } ACore/* default.install */.Z.install(NumberSpanInput); /* harmony default export */ const js_NumberSpanInput = (NumberSpanInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/onscreenwindow.css var onscreenwindow = __webpack_require__(8848); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/WindowBox.js var WindowBox = __webpack_require__(774); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/OnsScreenWindow.js var OnsScreenWindow_ = ACore/* default._ */.Z._; var OnsScreenWindow_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function OnScreenWindow() { var self = this; this._lastSize = { width: 0, height: 0 } /*** * * @type {WindowBox} */ this.$windowBox = OnsScreenWindow_$(WindowBox/* default.tag */.Z.tag, this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$windowBox, 'windowTitle'); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$windowBox, 'windowActions'); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$windowBox, 'windowIcon'); this.$windowBox.on('action', function (event){ self.emit('action', event, self); }); this.$header = OnsScreenWindow_({ tag: Hanger/* default.tag */.Z.tag, elt: this.$windowBox.$header }); this.$header.on('dragstart', this.eventHandler.dragStart.bind(this, this.$header, 'move')); // this.$bottomResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom', this); this.$bottomResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$bottomResizer, 'bottom')); // this.$rightResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-right', this); this.$rightResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$rightResizer, 'right')); // this.$topResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-top', this); this.$topResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$topResizer, 'top')); this.$leftResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-left', this); this.$leftResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$leftResizer, 'left')); this.$bottomRightResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-right', this); this.$bottomRightResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$bottomRightResizer, 'bottomRight')); // this.$bottomLeftResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-left', this); this.$bottomLeftResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$bottomLeftResizer, 'bottomLeft')); // this.$topLeftResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-left', this) this.$topLeftResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$topLeftResizer, 'topLeft')); this.$topRightResizer = OnsScreenWindow_$('.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-right', this); this.$topRightResizer.on('dragstart', this.eventHandler.dragStart.bind(this, this.$topRightResizer, 'topRight')); this.$attachhook = OnsScreenWindow_('attachhook').addTo(this); this.$attachhook.requestUpdateSize = this.relocation.bind(this); this.$attachhook.on('error', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); }); } OnScreenWindow.tag = 'OnScreenWindow'.toLowerCase(); OnScreenWindow.render = function () { return OnsScreenWindow_({ extendEvent: ['sizechange', 'drag', 'relocation', 'action'], class: 'absol-onscreen-window', child: [ { tag: WindowBox/* default.tag */.Z.tag, class: 'as-window-box', }, 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-top', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-left', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-right', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-right', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-left', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-left', 'hanger.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-right' ] }); }; OnScreenWindow.prototype.maybeSizeChange = function () { var bound = this.getBoundingClientRect(); if (this._lastSize.width !== bound.width || this._lastSize.height !== bound.height) { this._lastSize = bound; window.dispatchEvent(new Event('resize')); this.emit('sizechange', { size: bound, target: this, type: 'sizechange' }, this); } }; OnScreenWindow.prototype.moveFators = { move: { x: 1, y: 1, /*** * @this OnScreenWindow * @param event */ canMove: function (event) { return true; }, cursor: 'move' }, top: { y: 1, height: -1 }, bottom: { height: 1, cursor: 's-resize' }, bottomRight: { height: 1, width: 1, cursor: 'se-resize' }, bottomLeft: { height: 1, width: -1, x: 1, cursor: 'sw-resize' }, topLeft: { height: -1, width: -1, x: 1, y: 1, cursor: 'nw-resize' }, topRight: { height: -1, width: 1, y: 1, cursor: 'ne-resize' }, right: { width: 1, cursor: 'e-resize' }, left: { x: 1, width: -1, cursor: 'w-resize' } }; /*** * * @type {{}} * @memberOf OnScreenWindow# */ OnScreenWindow.eventHandler = {}; /*** * @this OnScreenWindow * @param {Hanger} elt * @param fN * @param event */ OnScreenWindow.eventHandler.dragStart = function (elt, fN, event) { var factor = this.moveFators[fN]; if (factor.canMove && !factor.canMove.call(this, event)) return; this.movingData = { factor: factor, screenSize: (0,Dom/* getScreenSize */.tE)(), modal: OnsScreenWindow_('.absol-onscreen-window-moving-modal') .addStyle('cursor', factor.cursor).addTo(document.body), elt: elt, bound: this.getBoundingClientRect() }; elt.on('drag', this.eventHandler.drag) .on('dragend', this.eventHandler.dragEnd); }; /*** * @this OnScreenWindow * @param event */ OnScreenWindow.eventHandler.drag = function (event) { var movingData = this.movingData; var factor = movingData.factor; var bound = movingData.bound; var screenSize = movingData.screenSize; var dv = event.currentPoint.sub(event.startingPoint); var x, y, width, height; if (factor.x) { x = dv.x * factor.x + bound.left; x = Math.min(x, screenSize.width - bound.width); x = Math.max(0, x); this.addStyle('left', x + 'px'); } if (factor.y) { y = dv.y * factor.y + bound.top; y = Math.min(y, screenSize.height - bound.height); y = Math.max(0, y); this.addStyle('top', y + 'px'); } if (factor.width) { width = dv.x * factor.width + bound.width; this.addStyle('width', width + 'px'); } if (factor.height) { height = dv.y * factor.height + bound.height; this.addStyle('height', height + 'px'); } this.emit('relocation', { type: 'relocation', target: this }, this); this.maybeSizeChange(); }; /*** * @this OnScreenWindow * @param event */ OnScreenWindow.eventHandler.dragEnd = function (event) { var movingData = this.movingData; var elt = movingData.elt; elt.off('drag', this.eventHandler.drag) .off('dragend', this.eventHandler.dragEnd); setTimeout(function () { movingData.modal.remove(); }, 50); this.movingData = null; }; ['addChild', 'addChildBefore', 'addChildAfter', 'clearChild', 'findChildBefore', 'findChildAfter'].forEach(function (key) { OnScreenWindow.prototype[key] = function () { return this.$windowBox[key].apply(this.$windowBox, arguments); }; }); OnScreenWindow.property = {}; OnScreenWindow.prototype.relocation = function () { var bound = this.getBoundingClientRect(); var screenSize = Dom/* default.getScreenSize */.ZP.getScreenSize(); var isRelocated = false; if (bound.bottom >= screenSize.height) { this.addStyle('top', Math.max(0, screenSize.height - bound.height) + 'px'); isRelocated = true; } if (bound.right >= screenSize.width) { this.addStyle('left', Math.max(0, screenSize.width - bound.width) + 'px'); isRelocated = true; } if (isRelocated) { this.emit('relocation', { type: 'relocation', target: this }, this) } }; ACore/* default.install */.Z.install(OnScreenWindow); /* harmony default export */ const OnsScreenWindow = (OnScreenWindow); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/pageselector.css var pageselector = __webpack_require__(8526); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PageSelector.js var PageSelector_ = ACore/* default._ */.Z._; var PageSelector_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function PageSelector() { this.$pageCount = PageSelector_$('.absol-page-count', this); this.$pageInput = PageSelector_$('.absol-page-number-input input', this); this.$pageInput.on('keyup', this.eventHandler.pressEnterKey) .on('change', this.eventHandler.pressEnterKey); this.$prevBtn = PageSelector_$('li.page-previous', this); this.$nextBtn = PageSelector_$('li.page-next', this); this.$firstBtn = PageSelector_$('li.page-first', this); this.$lastBtn = PageSelector_$('li.page-last', this); this.$nextBtn.on('click', this.eventHandler.clickNext); this.$prevBtn.on('click', this.eventHandler.clickPrev); this.$firstBtn.on('click', this.eventHandler.clickFirst); this.$lastBtn.on('click', this.eventHandler.clickLast); this.$buttonContainer = PageSelector_$('.absol-page-number-buttons', this); this._buttons = []; this._pageOffset = 1; this._selectedIndex = 1; this._pageCount = 1; this._pageRange = 1; this.$pageInput.value = this._selectedIndex; } PageSelector.tag = 'PageSelector'.toLowerCase(); PageSelector.render = function () { return PageSelector_({ class: ['absol-page-selector'], extendEvent: ['change'], child: [ { class: 'absol-page-number-input', child: [{ tag: 'label', child: { text: "Page" } }, { tag: 'input', attr: { type: 'text' } }, { tag: 'span', child: { text: '/ ' } }, { tag: 'span', class: 'absol-page-count', child: { text: '1' } } ] }, { tag: 'ul', class: 'absol-page-number-buttons', child: [ { tag: 'li', class: "page-first", attr: { title: 'First' }, child: 'a.mdi.mdi-chevron-double-left' }, { tag: 'li', attr: { title: 'Previous' }, class: 'page-previous', child: 'a.mdi.mdi-chevron-left' }, { tag: 'li', attr: { title: 'Next' }, class: 'page-next', child: 'a.mdi.mdi-chevron-right' }, { tag: 'li', attr: { title: 'Last' }, class: 'page-last', child: 'a.mdi.mdi-chevron-double-right' } ] } ] }); } PageSelector.eventHandler = {}; /** * * @param {KeyboardEvent} event */ PageSelector.eventHandler.pressEnterKey = function (event) { if (event.key !== 'Enter' && event.type !== 'change') return; var index = parseInt(this.$pageInput.value.trim(), 10); if ((index < 1) || (index > this._pageCount)) { index = Math.max(1, Math.min(this._pageCount, index)); this.$pageInput.value = index; } this.selectPage(index, true); } PageSelector.eventHandler.clickLast = function (event) { this.selectPage(this._pageCount, true); }; PageSelector.eventHandler.clickFirst = function (event) { this.selectPage(1, true); }; PageSelector.eventHandler.clickNext = function (event) { if (this._selectedIndex == this._pageCount) return; this.selectPage(this._selectedIndex + 1, true); }; PageSelector.eventHandler.clickPrev = function (event) { if (this._selectedIndex == 1) return; this.selectPage(this._selectedIndex - 1, true); } PageSelector.eventHandler.clickIndex = function (index, event) { this.selectPage(index + this._pageOffset, true); }; PageSelector.prototype._createButton = function (index) { var button = PageSelector_({ tag: 'li', class: 'absol-page-number', child: { tag: 'a', attr: { 'data-index-text': index + 1 }, }, on: { click: PageSelector.eventHandler.clickIndex.bind(this, index) } }); this.$buttonContainer.addChildBefore(button, this.$nextBtn); return button; }; PageSelector.prototype.setPageRange = function (pageCount) { this._pageRange = pageCount; while (this._buttons.length < pageCount) { this._buttons.push(this._createButton(this._buttons.length)); } while (this._buttons.length > pageCount) { this._buttons.pop().remove(); } }; PageSelector.prototype.setStartPage = function (index) { this._buttons.forEach(function (e, i) { e.firstChild.attr('data-index-text', i + index + ''); }); this._pageOffset = index; }; PageSelector.prototype.selectPage = function (index, userActive) { if (index == this._selectedIndex) this.setStartPage(index - parseInt(this._pageRange / 2)); if (index >= this._pageOffset + this._pageRange) this.setStartPage(index - parseInt(this._pageRange / 2)); if (index > this._selectedIndex) { if (index == (this._pageOffset + this._pageRange - 1)) this.setStartPage(index - parseInt(this._pageRange / 2)); } if (index < this._selectedIndex) { if (index == this._pageOffset) this.setStartPage(index - parseInt(this._pageRange / 2)); } if (index > (this._pageCount - parseInt(this._pageRange / 2))) this.setStartPage(this._pageCount - this._pageRange + 1); if (index <= (parseInt(this._pageRange / 2))) this.setStartPage(1); var pageOffset = this._pageOffset; this._buttons.forEach(function (e, i) { if (i + pageOffset == index) { e.addClass('active'); } else { e.removeClass('active'); } }); if (this._selectedIndex != index) { this._selectedIndex = index; this.$pageInput.value = index; this.emit('change', { target: this, selectedIndex: index, userActive: !!userActive }, this); } }; PageSelector.prototype.getSelectedPage = function () { return this._selectedIndex; } PageSelector.prototype.setPageCount = function (count) { this._pageCount = count; this.$pageCount.firstChild.data = '' + count; this.attr('data-page-count', count); }; PageSelector.property = {}; PageSelector.property.selectedIndex = { set: function (value) { this.selectPage(value, false); }, get: function () { return this._selectedIndex; } }; PageSelector.property.pageCount = { set: function (value) { this.setPageCount(value); }, get: function () { return this._pageCount; } }; PageSelector.property.pageOffset = { set: function (value) { this.setStartPage(value); }, get: function () { return this._pageOffset; } }; PageSelector.property.pageRange = { set: function (value) { this.setPageRange(value); }, get: function () { return this._pageRange; } }; PageSelector.property.simpleMode = { set: function (value) { if (value) { this.addClass('as-simple-mode'); } else { this.removeClass('as-simple-mode'); } }, get: function () { return this.hasClass('as-simple-mode'); } }; PageSelector.prototype.init = function (props) { props = props || {}; props.pageOffset = props.pageOffset || 1; props.pageRange = props.pageRange || 5; props.pageCount = props.pageCount || 15; props.selectedIndex = typeof (props.selectedIndex) == "number" ? props.selectedIndex : props.pageOffset; if (props.pageCount < props.pageRange) props.pageRange = props.pageCount; this.setPageCount(props.pageCount); this.setPageRange(props.pageRange); this.setStartPage(props.pageOffset); this.selectPage(props.selectedIndex); props = Object.assign({}, props); delete props.pageOffset; delete props.pageRange; delete props.pageCount; delete props.selectedIndex; Object.assign(this, props); }; ACore/* default.install */.Z.install(PageSelector); /* harmony default export */ const js_PageSelector = (PageSelector); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/preinput.css var preinput = __webpack_require__(4981); // EXTERNAL MODULE: ./node_modules/absol/src/Detector/BrowserDetector.js var BrowserDetector = __webpack_require__(9399); // EXTERNAL MODULE: ./node_modules/absol/src/Print/printer.js + 2 modules var printer = __webpack_require__(2691); // EXTERNAL MODULE: ./node_modules/absol/src/Print/PrintSerialHandlers.js var PrintSerialHandlers = __webpack_require__(5421); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PreInput.js var PreInput_ = ACore/* default._ */.Z._; var PreInput_$ = ACore/* default.$ */.Z.$; var textDelay = BrowserDetector/* default.isSafari */.Z.isSafari ? 100 : 1; /*** * @extends AElement * @constructor */ function PreInput() { this.defineEvent(['pasteimg', 'pastetext', 'change']); this.on('paste', this.eventHandler.paste); this.on('keydown', this.eventHandler.keydown); this.history = []; this.value = ''; this.historyIndex = -1; this.changePendingEvent = null; this.commitChange('', 0); } PreInput.tag = 'preinput'; PreInput.render = function () { return PreInput_({ tag: 'pre', class: 'as-preinput', attr: { contenteditable: 'true' }, child: 'br' }); }; PreInput.prototype.notifyChange = function (data, originalEvent) { this.emit('change', Object.assign({ type: 'change', target: this, originalEvent: originalEvent || this.changePendingEvent }, data)); this.changePendingEvent = null; }; PreInput.prototype.applyData = function (text, offset) { var textNode = PreInput_({ text: text }); this.clearChild() .addChild(textNode).addChild(PreInput_('br')); if (document.activeElement === this && this.isDescendantOf(document.body)) { if (document.getSelection) { var sel = document.getSelection(); sel.removeAllRanges(); var range = document.createRange(); if (typeof offset == 'number') { range.setStart(textNode, Math.min(text.length, offset)); } else { range.setStart(textNode, Math.min(text.length, offset.start)); range.setEnd(textNode, Math.min(text.length, offset.end)); } sel.addRange(range); this.scrollIntoRange(range); } else { console.error("PreInput: Not support!"); } } }; PreInput.prototype.select = function (offset) { if (document.activeElement !== this) this.focus(); this.applyData(this.value, offset); }; PreInput.prototype.scrollIntoRange = function (range) { var elementBound = range.getBoundingClientRect(); var viewportBound = this.getBoundingClientRect(); var dBottom = 0; if (range.startContainer && range.startContainer.data && range.startContainer.data.charAt(range.startContainer.data.length - 1) == '\n') dBottom += this.getFontSize() * 1.5; var currentScrollTop = this.scrollTop; var newScrollTop = currentScrollTop; if (elementBound.bottom + dBottom > viewportBound.bottom) { newScrollTop = currentScrollTop + (elementBound.bottom + dBottom - viewportBound.bottom); } if (elementBound.top < viewportBound.top) { newScrollTop = currentScrollTop - (viewportBound.top - elementBound.top); } if (newScrollTop != currentScrollTop) { this.scrollTop = newScrollTop; } var currentScrollLeft = this.scrollLeft; var newScrollLeft = currentScrollLeft; if (elementBound.right > viewportBound.right) { newScrollLeft = currentScrollLeft + (elementBound.right - viewportBound.right); } if (elementBound.left < viewportBound.left) { newScrollLeft = currentScrollLeft - (viewportBound.left - elementBound.left); } if (newScrollLeft != currentScrollLeft) { this.scrollLeft = newScrollLeft; } }; PreInput.prototype.undo = function () { if (this.historyIndex <= 0) return; this.historyIndex--; var record = this.history[this.historyIndex]; this.applyData(record.text, record.offset); this.notifyChange({value: record.text, action: 'undo', record: record}); }; PreInput.prototype.redo = function () { if (this.historyIndex + 1 >= this.history.length) return; this.historyIndex++; var record = this.history[this.historyIndex]; this.applyData(record.text, record.offset); this.notifyChange({value: record.text, action: 'redo', record: record}); }; /** * * @param text * @param offset * @param {Event=} event */ PreInput.prototype.commitChange = function (text, offset) { while (this.historyIndex < this.history.length - 1) { this.history.pop(); } var lastText = this.history.length > 0 ? this.history[this.history.length - 1].text : null; if (text === lastText) { if (this.history[this.history.length - 1].offset != offset) this.history[this.history.length - 1].offset = offset; } else { this.historyIndex = this.history.length; var record = { text: text, offset: offset }; this.history.push(record); this.notifyChange({ value: record.text, action: 'commit', record: record }); } }; /** * * @param text * @param offset * @param {Event=} event */ PreInput.prototype.waitToCommit = function (text, offset, event) { var thisInput = this; if (this._commitTimeout > 0) clearTimeout(this._commitTimeout); this._commitTimeout = setTimeout(function () { thisInput.commitChange(text, offset); }, textDelay); }; PreInput.prototype.getPosition = function (node, offset) { if (!node) return NaN; if (node == this) return offset; var parent = node.parentElement; if (!parent) return NaN; var text = ''; var child; var lastBr = false; for (var i = 0; i < parent.childNodes.length; ++i) { child = parent.childNodes[i]; if (child == node) break; text += this.stringOf(child); } return this.getPosition(parent, text.length + offset); }; PreInput.prototype.getSelectPosition = function () { if (window.getSelection) { var sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { var range = sel.getRangeAt(0); var direction = 'forward'; var cmpPosition = sel.anchorNode.compareDocumentPosition(sel.focusNode); if (cmpPosition === 4) { direction = 'forward'; } else if (cmpPosition === 2) { direction = 'backward' } else if (!cmpPosition && sel.anchorOffset > sel.focusOffset || cmpPosition === Node.DOCUMENT_POSITION_PRECEDING) { direction = 'backward'; } var startOffset = this.getPosition(range.startContainer, range.startOffset); var endOffset = this.getPosition(range.endContainer, range.endOffset); if (isNaN(startOffset)) return null; return { start: startOffset, end: endOffset, direction: direction } } } else if (document.selection) { console.error('May not support!'); } }; PreInput.prototype.stringOf = function (node, parent) { if (!node) return ''; if (node.nodeType === 3) { return node.data; } var res = ''; if ((node.tagName === 'BR' || node.tagName === 'br') && parent && parent.lastChild !== node) { return '\n'; } else if ((node.tagName === 'DIV' || node.tagName === 'div') && parent && parent.firstChild !== node) { res += '\n'; } var thisInput = this; return res + Array.prototype.map.call(node.childNodes, function (cNode, index, arr) { return thisInput.stringOf(cNode, node); }).join(''); }; PreInput.prototype._pasteText = function (text) { var sel = window.getSelection(); var range; if (window.getSelection) { sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { try { range = sel.getRangeAt(0); range.deleteContents(); var textNode = PreInput_({ text: text }); range.insertNode(textNode); if (sel.removeRange) { sel.removeRange(range); } else { sel.removeAllRanges(); } range = document.createRange(); range.setStart(textNode, text.length); sel.addRange(range); this.scrollIntoRange(range); this.commitChange(this.stringOf(this), this.getPosition(textNode, text.length)); } catch (error) { alert(error.message) } } } else if (document.selection && document.selection.createRange) { document.selection.createRange().text = text; this.commitChange(this.stringOf(this), this.getPosition(textNode, text.length)); console.error('May not support!'); } }; /** * @type {PreInput} */ PreInput.eventHandler = {}; PreInput.eventHandler.paste = function (event) { this.changePendingEvent = event; var thisIp = this; var clipboardData = (event.clipboardData || window.clipboardData); /**Safari bug */ if (clipboardData) { if (clipboardData.items) { var items = Array.prototype.slice.call(clipboardData.items); var imgItems = items.filter(function (item) { return item.type.indexOf('image') >= 0; }); var plainTextItems = items.filter(function (item) { return item.type.indexOf('text/plain') >= 0; }); if (imgItems.length > 0) { var imgFiles = imgItems.map(function (it) { return it.getAsFile(); }); this.emit('pasteimg', { target: this, imageFile: imgFiles[0], imageFiles: imgFiles, orginEvent: event }, this); } else if (plainTextItems.length > 0) { var plainTextItem = plainTextItems[0];//only one item plainTextItem.getAsString(function (text) { thisIp._pasteText(text); }); } else { window.ABSOL_DEBUG && console.error("Can not handle clipboard data"); } event.preventDefault(); } else { var text = event.clipboardData.getData('text/plain'); if (text) { event.preventDefault(); this._pasteText(text); } else { var currentText = this.stringOf(this); var currentSelection = this.getSelectPosition(); setTimeout(function () { var images = []; PreInput_$('img', thisIp, function (elt) { images.push(elt); }); Promise.all(images.map(function (img) { return Dom/* default.imageToCanvas */.ZP.imageToCanvas(img).then(function (canvas) { var dataURI = canvas.toDataURL(); var blob = (0,Converter_file.dataURItoBlob)(dataURI); var file = (0,Converter_file.blobToFile)(blob); return { file: file, blob: blob, url: dataURI } }, function (error) { console.error(error) }).catch(function (error) { console.error(error) }); })).then(function (results) { results = results.filter(function (it) { return !!it; }); if (results.length > 0) { var imgFiles = results.map(function (it) { return it.file }); var urls = results.map(function (it) { return it.url }); thisIp.emit('pasteimg', { target: this, imageFile: imgFiles[0], imageFiles: imgFiles, urls: urls, url: urls[0], orginEvent: event }, thisIp); } }); thisIp.applyData(currentText, currentSelection); }, textDelay); } } } else { setTimeout(function () { if (window.getSelection) { var sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { var range = sel.getRangeAt(0); var text = this.stringOf(this); var offset = this.getPosition(range.startContainer, range.startOffset); this.waitToCommit(text, offset); } } else if (document.selection) { console.error('May not support!'); } }.bind(this), textDelay); } }; PreInput.eventHandler.keydown = function (event) { this.changePendingEvent = event; if (event.ctrlKey) { switch (event.key) { case 'z': this.undo(); event.preventDefault(); break; case 'y': this.redo(); event.preventDefault(); break; default: break; } } if (!event.ctrlKey && !event.altKey) { setTimeout(function () { if (window.getSelection) { var sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { var range = sel.getRangeAt(0); var text = this.stringOf(this); var offset = this.getPosition(range.startContainer, range.startOffset); this.waitToCommit(text, offset); } } else if (document.selection) { console.error('May not support!'); } }.bind(this), textDelay); } }; PreInput.property = {}; PreInput.property.value = { set: function (value) { value = value || ''; this.applyData(value, value.length); this.commitChange(value, value.length); }, get: function () { return this.stringOf(this); } }; PreInput.property.disabled = { set: function (value) { value = !!value; if (value === this.hasClass('as-disabled')) return; if (value) { this.addClass('as-disabled'); this.attr({ contenteditable: undefined, oncut: 'return false', onpaste: 'return false', onkeydown: 'if(event.metaKey) return true; return false;' }); } else { this.removeClass('as-disabled'); this.attr({ contenteditable: true, oncut: undefined, onpaste: undefined, onkeydown: undefined }); } }, get: function () { return this.hasClass('as-disabled'); } }; PreInput.property.readOnly = { set: function (value) { value = !!value; if (value === this.hasClass('as-read-only')) return; if (value) { this.addClass('as-read-only'); this.attr({ contenteditable: undefined, oncut: 'return false', onpaste: 'return false', onkeydown: 'if(event.metaKey) return true; return false;' }); } else { this.removeClass('as-read-only'); this.attr({ contenteditable: true, oncut: undefined, onpaste: undefined, onkeydown: undefined }); } }, get: function () { return this.hasClass('as-read-only'); } }; ACore/* default.install */.Z.install(PreInput); /* harmony default export */ const js_PreInput = (PreInput); /* ShareSerializer.addHandlerBefore({ id: 'PreInput', match: (elt, scope, stack) => { if (elt.nodeType !== Node.ELEMENT_NODE) return false; return elt.hasClass('as-preinput') || elt.hasClass('as-tokenize-hyper-input'); }, exec: (printer, elt, scope, stack, accept) => { var O = printer.O; var printAttr = computePrintAttr(elt); var rect = printAttr.contentBound; rect.x -= O.x; rect.y -= O.y; printer.text(PreInput.prototype.stringOf(elt), rect, printAttr.style); return false; } }, '*'); */ // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ProgressBar.js var ProgressBar = __webpack_require__(6535); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/quicklistbutton.css var quicklistbutton = __webpack_require__(5674); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FollowerToggler.js var FollowerToggler_ = ACore/* default._ */.Z._; var FollowerToggler_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function FollowerToggler() { this.defineEvent(['close', 'open', 'preopen']); this.on('click', this.eventHandler.click); this.addClass('as-follower-trigger'); this.$follower = null; this._opened = false; } FollowerToggler.tag = 'FollowerToggler'.toLowerCase(); FollowerToggler.render = function () { return FollowerToggler_('div'); }; FollowerToggler.prototype.toggle = function () { if (this._opened) this.close(); else this.open(); }; FollowerToggler.prototype.open = function () { if (this._opened) return; this._opened = true; this.addClass('as-follower-trigger-open'); if (!this.$follower) return; this.emit('preopen', { name: 'preopen', target: this }, this); var thisTg = this; setTimeout(function () { thisTg.$follower.refollow(); thisTg.$follower.removeClass('absol-follower-hidden'); document.body.addEventListener('click', thisTg.eventHandler.clickBody); thisTg.emit('open', { name: 'open', target: this }, this); }, 1); }; FollowerToggler.prototype.close = function () { if (!this._opened) return; this._opened = false; this.removeClass('as-follower-trigger-open'); if (!this.$follower) return; this.$follower.unfollow(); this.$follower.addClass('absol-follower-hidden'); document.body.removeEventListener('click', this.eventHandler.clickBody); this.emit('close', { name: 'close', target: this }, this); }; FollowerToggler.prototype.bindFollower = function (elt) { if (this.$follower) { this.$follower.followTarget = null; } if (elt && elt.refollow) { if (this._opened) elt.removeClass('absol-follower-hidden'); else elt.addClass('absol-follower-hidden'); elt.followTarget = this; elt.sponsorElement = this; this.$follower = elt; } else { throw new Error("Must be a follower!"); } } FollowerToggler.eventHandler = {}; FollowerToggler.eventHandler.clickBody = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this, event) || EventEmitter/* default.hitElement */.ZP.hitElement(this.$follower, event)) return; this.close(); }; FollowerToggler.eventHandler.click = function () { this.toggle(); }; ACore/* default.install */.Z.install(FollowerToggler); /* harmony default export */ const js_FollowerToggler = (FollowerToggler); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/QuickListButton.js var QuickListButton_ = ACore/* default._ */.Z._; var QuickListButton_$ = ACore/* default.$ */.Z.$; /**** * @extends FollowerToggler * @constructor */ function QuickListButton() { this.$shareFollower = QuickListButton.getFollower(); QuickListButton_({ tag: 'followertoggler', elt: this, on: { preopen: this.eventHandler.preopen, close: this.eventHandler.closeFollower } }); this.bindFollower(this.$shareFollower); this.$iconCtn.remove(); this.$content.addChild(this.$iconCtn); this._items = this._items; this._anchor = []; this.$list = null; this._listUpdated = true; this._opened = false; this.anchor = [12, 13, 15, 14];//todo: add property } QuickListButton.getFollower = function () { if (!QuickListButton.$follower) QuickListButton.$follower = QuickListButton_('follower.as-quick-list-button-follower'); QuickListButton.$follower.cancelWaiting(); return QuickListButton.$follower; }; QuickListButton.tag = 'QuickListButton'.toLowerCase(); QuickListButton.render = function () { return QuickListButton_({ tag: 'flexiconbutton', class: 'as-quick-list-button', extendEvent: 'select', props: { text: "+ Thêm", icon: 'span.mdi.mdi-menu-down' } }); }; QuickListButton.property = {}; QuickListButton.property.items = { set: function (value) { value = value || []; this._items = value; this._listUpdated = false; }, get: function () { return this._items; } }; /** * @type {QuickListButton} */ QuickListButton.eventHandler = {}; QuickListButton.eventHandler.preopen = function () { this.$shareFollower.addTo(document.body); this.$shareFollower.anchor = this.anchor; if (this.$list == null) { this.$list = QuickListButton_('selectlist.absol-bscroller') .on('pressitem', this.eventHandler.pressitem); } if (!this._listUpdated) { this._listUpdated = true; this.$list.items = this._items; } this.$shareFollower.addChild(this.$list); this.$shareFollower.on({ preupdateposition: this.eventHandler.preUpdatePosition, }); }; QuickListButton.eventHandler.preUpdatePosition = function () { var bound = this.getBoundingClientRect(); var screenSize = Dom/* default.getScreenSize */.ZP.getScreenSize(); var maxHeight = Math.max(screenSize.height - bound.bottom, bound.top) - 10; this.$list.addStyle('max-height', maxHeight + 'px'); }; QuickListButton.eventHandler.closeFollower = function () { this.$shareFollower.off({ preupdateposition: this.eventHandler.preUpdatePosition }); }; QuickListButton.eventHandler.pressitem = function (event) { this.close(); this.emit('select', Object.assign({}, event, { type: 'select', target: this })); }; ACore/* default.install */.Z.install(QuickListButton); /* harmony default export */ const js_QuickListButton = (QuickListButton); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/SelectList.js var SelectList = __webpack_require__(133); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/QuickMenu.js var QuickMenu = __webpack_require__(1274); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/quickpath.css var quickpath = __webpack_require__(7786); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/QuickPath.js var QuickPath_ = ACore/* default._ */.Z._; var QuickPath_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function QuickPath() { this._holders = []; } /** * @type {QuickPath} */ QuickPath.eventHandler = {}; /*** * @this QuickPath * @param event */ QuickPath.eventHandler.click = function (event) { var button = this._fileButton(event.target) if (button) this.pressButton(button); }; QuickPath.tag = 'QuickPath'.toLowerCase(); /** * @returns {QuickPath} */ QuickPath.render = function () { return QuickPath_({ class: 'absol-quick-path', extendEvent: ['change', 'press'] }); }; QuickPath.prototype.updatePath = function () { this.clearChild(); var self = this; this._holders = this._path.map(function (data, index) { var holder = self._createButton(data, index); holder.buttom.addTo(self); return holder; }) }; QuickPath.prototype._createButton = function (pathItem, index) { var buttom = QuickPath_({ tag: 'expnode', class: 'absol-quick-path-btn', attr: { 'data-index': '' + index } }); buttom.status = 'close'; buttom.name = pathItem.name; if (pathItem.icon) { buttom.icon = pathItem.icon; } if (pathItem.iconSrc) { buttom.icon = { tag: 'img', props: { src: pathItem.iconSrc } }; } var thisQuickpath = this; if (pathItem.items) { QuickMenu/* default.toggleWhenClick */.Z.toggleWhenClick(buttom, { getAnchor: function () { return [1, 2, 6, 5]; }, getMenuProps: function () { return { extendStyle: { fontSize: buttom.getComputedStyleValue('font-size') }, items: pathItem.items.map(function (it, menuIndex) { var res = { text: it.name, menuIndex: menuIndex, icon: it.iconSrc ? { tag: 'img', props: { src: it.iconSrc } } : (it.icon || undefined), extendStyle: it.extendStyle || {}, extendClass: it.extendClass || [], } return res; }) } }, onOpen: function () { buttom.status = 'open'; thisQuickpath.emit('press', { target: thisQuickpath, pathItem: pathItem, index: index }, thisQuickpath); }, onClose: function () { buttom.status = 'close'; }, onSelect: function (item) { var dataItem = pathItem.items[item.menuIndex]; thisQuickpath.emit('change', { target: thisQuickpath, pathItem: pathItem, item: dataItem, index: index }, thisQuickpath); thisQuickpath.status = 'close'; } }) } else { buttom.on('click', function () { this.emit('press', { target: thisQuickpath, pathItem: pathItem, index: index }, thisQuickpath); }); } return { buttom: buttom }; } QuickPath.prototype.push = function (item) { this.path.push(item); var holder = this._createButton(item, this.path.length - 1); this.addChild(holder, buttom); this._holders.push(holder); }; QuickPath.prototype.clear = function () { this.path = []; this._holders = []; } QuickPath.prototype.pop = function () { //todo var res = this.path.pop(); var button = QuickPath_$('button[data-index="' + this.path.length + '"]'); if (button) button.remove(); return res; }; QuickPath.property = {}; /** * @typedef PathElement * @property {String} name * @property {String} icon * @property {Array<String>} items * */ QuickPath.property.path = { /** * @param {Array<PathElement>} value */ set: function (value) { this._path = value || []; this.updatePath(); }, get: function () { return this._path || []; } }; QuickPath.property.textPath = { get: function () { return this.path.join('/'); } }; ACore/* default.install */.Z.install('quickpath', QuickPath); /* harmony default export */ const js_QuickPath = (QuickPath); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/RadioButton.js var RadioButton = __webpack_require__(7234); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Radio.js var Radio = __webpack_require__(7002); // EXTERNAL MODULE: ./node_modules/absol/src/Network/XHR.js var XHR = __webpack_require__(6069); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/RemoteSvg.js var RemoteSvg_ = ACore/* default._ */.Z._; var RemoteSvg_$ = ACore/* default.$ */.Z.$; function RemoteSvg() { } RemoteSvg.tag = 'RemoteSvg'.toLowerCase(); RemoteSvg.render = function () { return RemoteSvg_('svg').defineEvent('load'); }; RemoteSvg.property = { src: { set: function (value) { this._src = value; var self = this; RemoteSvg.loadIcon(value).then(function (data) { self.emit('load', { target: self, src: value, data: data }, self); self.attr(data.attr); self.init(data.props); }); }, get: function () { return this._name; } } }; RemoteSvg.attribute = { src: { set: function (value) { }, get: function () { }, remove: function () { } } }; RemoteSvg.__cache__ = {}; RemoteSvg.__div_parser__ = document.createElement('div'); RemoteSvg.loadIcon = function (path) { if (RemoteSvg.__cache__[path]) { return RemoteSvg.__cache__[path]; } else { RemoteSvg.__cache__[path] = XHR/* default.getRequest */.Z.getRequest(path, 'text').then(function (result) { RemoteSvg.__div_parser__.innerHTML = result; var svgElt = RemoteSvg_$('svg', RemoteSvg.__div_parser__); var res = { attr: {}, props: {} }; if (svgElt) { Array.prototype.forEach.call(svgElt.attributes, function (attribute) { res.attr[attribute.name] = attribute.value; }); res.props.innerHTML = svgElt.innerHTML; } return res; }, function () { return {}; }); return RemoteSvg.__cache__[path]; } }; ACore/* default.install */.Z.install(RemoteSvg); /* harmony default export */ const js_RemoteSvg = (RemoteSvg); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ResizeBox.js var ResizeBox = __webpack_require__(4860); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Searcher.js var Searcher = __webpack_require__(9024); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selectbox.css var selectbox = __webpack_require__(7694); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selectmenu.css var selectmenu = __webpack_require__(7001); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectMenu2.js ACore/* default.creator.dropdown-ico */.Z.creator["dropdown-ico"] = function () { return (0,ACore._)([ '<svg class="dropdown" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">', '<g transform="translate(0,-197)">', '<path d="m6.3152 218.09a4.5283 4.5283 0 0 0-3.5673 7.3141l43.361 55.641a4.5283 4.5283 0 0 0 7.1421 7e-3l43.496-55.641a4.5283 4.5283 0 0 0-3.5673-7.3216z" />', '</g>', '</svg>' ].join('')); }; /*** * @extends AElement * @constructor */ function SelectMenu() { this._value = null; this._lastValue = null; this.$holderItem = (0,ACore.$)('.absol-selectmenu-holder-item', this); this.$viewItem = (0,ACore.$)('.absol-selectmenu-holder-item selectlistitem', this); /*** * * @type {SelectListBox} */ this.$selectlistBox = (0,ACore._)({ tag: 'selectlistbox', props: { anchor: [1, 6, 2, 5], strictValue: true }, on: { preupdateposition: this.eventHandler.preUpdateListPosition } }); if (this.$selectlistBox.cancelWaiting) this.$selectlistBox.cancelWaiting(); this.widthLimit = this.$selectlistBox.widthLimit; this.addStyle('--as-width-limit', this.$selectlistBox.widthLimit + 'px'); var firstCheckView = false; var this1 = this; var checkView = () => { if (this1.isDescendantOf && this1.isDescendantOf(document.body)) { setTimeout(checkView, 5000); firstCheckView = true; } else if (firstCheckView) { setTimeout(checkView, 1000); } else { if (this1.$selectlistBox.searchMaster) this1.$selectlistBox.searchMaster.destroy(); } } setTimeout(checkView, 3000); this.$selectlistBox.on('pressitem', this.eventHandler.selectListBoxPressItem); this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectlistBox, 'enableSearch'); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'selectedvalue', 'value'); this.strictValue = true; this._lastValue = "NOTHING_VALUE"; this._isFocus = false; this.isFocus = false; this.on('mousedown', this.eventHandler.click, true); /*** * @name items * @type {[]} * @memberOf SelectMenu# */ } SelectMenu.tag = 'selectmenu'; SelectMenu.render = function () { return (0,ACore._)({ class: ['absol-selectmenu', 'as-select-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { class: 'absol-selectmenu-holder-item', child: 'selectlistitem' }, { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] } ] }); }; SelectMenu.prototype.addStyle = function (arg0, arg1) { if (arg0 === 'textAlign' || arg0 === 'text-align') { if (arg1 === 'center') { this.addClass('as-text-align-center'); this.$selectlistBox.addClass('as-text-align-center'); } else { this.removeClass('as-text-align-center'); this.$selectlistBox.removeClass('as-text-align-center'); } } else { return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } }; SelectMenu.prototype.init = function (props) { props = props || {}; Object.keys(props).forEach(function (key) { if (props[key] === undefined) delete props[key]; }); if ('selectedvalue' in props) { props.value = props.selectedvalue; } if (!('value' in props)) { if (props.items && props.items.length > 0) props.value = typeof props.items[0] == 'string' ? props.items[0] : props.items[0].value; } var value = props.value; delete props.value; this.super(props); this.value = value; }; SelectMenu.prototype.revokeResource = function () { // return; // this.$selectlistBox.revokeResource(); }; SelectMenu.prototype.selfRemove = function () { setTimeout(() => { if (!this.parentElement) this.revokeResource(); }, 100); this.remove(); } SelectMenu.prototype.updateItem = function () { var value = this._explicit(this._value); var selectedItems = this.$selectlistBox.findDisplayItemsByValue(value); var data; if (selectedItems.length >= 1) { data = selectedItems[0].item; this.$viewItem.data = data; if (data.text && (0,utils.measureText)(data.text + '', '14px arial').width - 30 > this.widthLimit) { this.$viewItem.attr('title', data.text); } else this.$viewItem.attr('title', null); } else { this.$viewItem.data = { text: '', value: null }; this.$viewItem.attr('title', null); } }; SelectMenu.prototype.findItemsByValue = function (value) { return this.$selectlistBox.findItemsByValue(value); }; SelectMenu.prototype.findItemByValue = function (value) { return this.$selectlistBox.findItemByValue(value); } SelectMenu.prototype._explicit = function (value) { var items = this.$selectlistBox.findItemsByValue(value); if (items.length > 0 || !this.strictValue || this.items.length === 0) { return value; } else { return this.items[0].value; } }; SelectMenu.property = {}; SelectMenu.property.items = { set: function (items) { items = items || []; this.$selectlistBox.items = items; this.addStyle('--select-list-estimate-width', (this.$selectlistBox._estimateWidth) / 14 + 'em'); this.addStyle('--select-list-desc-width', (this.$selectlistBox._estimateDescWidth) / 14 + 'em'); this.updateItem(); }, get: function () { return this.$selectlistBox.items; } }; SelectMenu.property.value = { set: function (value) { this.$selectlistBox.values = [value]; this._lastValue = value; this._value = value; this.updateItem(); }, get: function () { return this._explicit(this._value); } }; /*** * * @type {SelectMenu|{}} */ SelectMenu.property.isFocus = { set: function (value) { if (value && (this.disabled || this.readOnly)) return; var thisSM = this; if (!this.items || this.items.length === 0) value = false;//prevent focus if (this._isFocus === value) return; this._isFocus = !!value; if (this._isFocus) { this.$selectlistBox.addTo(document.body); // this.$selectlistBox.domSignal.$attachhook.emit('attached'); var bound = this.getBoundingClientRect(); this.$selectlistBox.addStyle('min-width', bound.width + 'px'); this.$selectlistBox.refollow(); this.$selectlistBox.updatePosition(); setTimeout(function () { if (!BrowserDetector/* default.isMobile */.Z.isMobile) thisSM.$selectlistBox.focus(); document.addEventListener('click', thisSM.eventHandler.bodyClick); }, 100); this.$selectlistBox.viewListAtFirstSelected(); } else { document.removeEventListener('click', thisSM.eventHandler.bodyClick); this.$selectlistBox.selfRemove(); this.$selectlistBox.unfollow(); this.$selectlistBox.resetSearchState(); } }, get: function () { return this._isFocus; } }; SelectMenu.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; SelectMenu.property.hidden = { set: function (value) { if (value) { this.addClass('as-hidden'); } else { this.removeClass('as-hidden'); } }, get: function () { return this.addClass('as-hidden'); } }; SelectMenu.property.selectedIndex = { get: function () { var selectedItems = this.$selectlistBox.findItemsByValue(this._value); if (selectedItems.length > 0) { return selectedItems[0].idx; } return -1; } }; SelectMenu.property.strictValue = { set: function (value) { if (value) { this.attr('data-strict-value', null); } else { this.attr('data-strict-value', 'false'); } this.updateItem(); }, get: function () { return !this.attr('data-strict-value') || (this.attr('data-strict-value') !== 'false' && this.attr('data-strict-value') !== '0'); } }; SelectMenu.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; /** * @type {SelectMenu|{}} */ SelectMenu.eventHandler = {}; SelectMenu.eventHandler.click = function (event) { if (this.readOnly) return; if (EventEmitter/* default.isMouseRight */.ZP.isMouseRight(event)) return; if (EventEmitter/* default.hitElement */.ZP.hitElement(this.$selectlistBox, event)) return; this.isFocus = !this.isFocus; }; SelectMenu.eventHandler.bodyClick = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this, event) && !EventEmitter/* default.hitElement */.ZP.hitElement(this.$selectlistBox, event)) { setTimeout(function () { this.isFocus = false; }.bind(this), 5) } }; SelectMenu.eventHandler.selectListBoxPressItem = function (event) { this._value = event.data.value; this.$selectlistBox.values = [this._value]; this.updateItem(); if (this._lastValue !== this.value) { event.lastValue = this._lastValue; event.value = this.value; setTimeout(function () { this.emit('change', event, this); }.bind(this), 1) this._lastValue = this.value; } setTimeout(function () { this.isFocus = false; }.bind(this), 50) }; SelectMenu.eventHandler.preUpdateListPosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$selectlistBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { if (!BrowserDetector/* default.isMobile */.Z.isMobile) this.isFocus = false; } }; ACore/* default.install */.Z.install(SelectMenu); /* harmony default export */ const SelectMenu2 = (SelectMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectBoxItem.js var SelectBoxItem_ = ACore/* default._ */.Z._; var SelectBoxItem_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function SelectBoxItem() { this._themeClassName = null; this.$text = SelectBoxItem_$('.absol-selectbox-item-text', this); this.$close = SelectBoxItem_$('.absol-selectbox-item-close', this); this.$close.on('click', this.eventHandler.clickClose); this.on('click', this.eventHandler.click); }; SelectBoxItem.tag = 'SelectBoxItem'.toLowerCase(); SelectBoxItem.render = function () { return SelectBoxItem_({ class: ['absol-selectbox-item'], extendEvent: ['close', 'press'], child: [ '.absol-selectbox-item-text', { class: 'absol-selectbox-item-close', child: '<span class="mdi mdi-close"></span>' } ] }); }; SelectBoxItem.eventHandler = {}; SelectBoxItem.eventHandler.clickClose = function (event) { this.emit('close', event); }; SelectBoxItem.eventHandler.click = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$close, event)) { this.emit('press', event, this); } }; SelectBoxItem.property = {}; SelectBoxItem.property.data = { set: function (value) { this._data = value; this.$text.clearChild(); this.$text.addChild(SelectBoxItem_('<span>' + this.text + '</span>')); if (value && value.desc) { this.attr('title', value.desc); } else { this.attr('title', undefined); } if (this._themeClassName) this.removeClass(this._themeClassName); this._themeClassName = null; if (this.theme) { this._themeClassName = 'as-theme-' + this.theme; this.addClass(this._themeClassName); } }, get: function () { return this._data; } }; SelectBoxItem.property.text = { get: function () { if (typeof this._data == 'string') return this._data; else return this._data.text; } }; SelectBoxItem.property.value = { get: function () { if (typeof this._data == 'string') return this._data; else return this._data.value; } }; SelectBoxItem.property.theme = { get: function () { return this._data.theme || null; } }; SelectBoxItem.property.active = { set: function (value) { if (value) { this.addClass('as-active'); } else { this.removeClass('as-active'); } }, get: function () { return this.hasClass('as-active'); } }; ACore/* default.install */.Z.install(SelectBoxItem); /* harmony default export */ const js_SelectBoxItem = (SelectBoxItem); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selectlistbox.css var selectlistbox = __webpack_require__(6250); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/list/listIndexing.js function depthIndexingByValue(items, context) { context = context || {idx: 0, dict: {}}; return items.reduce(function (ac, cr, idx) { var value = typeof cr === "string" ? cr : cr.value + ''; ac[value] = ac[value] || []; ac[value].push({ idx: context.idx++, item: cr }); if (cr && cr.items && cr.items.length > 0) { depthIndexingByValue(cr.items, context); } return ac; }, context.dict); } function indexingByValue(items, dict) { return items.reduce(function (ac, cr, idx) { var value = typeof cr === "string" ? cr : cr.value + ''; ac[value] = ac[value] || []; ac[value].push({ idx: idx, item: cr }); return ac; }, dict || {}); } // EXTERNAL MODULE: ./node_modules/absol-acomp/js/list/ListSearchMaster.js + 1 modules var ListSearchMaster = __webpack_require__(4623); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectListBox.js var SelectListBox_ = ACore/* default._ */.Z._; var SelectListBox_$ = ACore/* default.$ */.Z.$; var SelectListBox_$$ = ACore/* default.$$ */.Z.$$; var VALUE_HIDDEN = -1; var VALUE_NORMAL = 1; var calcWidthLimit = () => { var width = (0,Dom/* getScreenSize */.tE)().width; if (BrowserDetector/* default.isMobile */.Z.isMobile) { width -= 20; } else { width = width * 0.9 - 250; } return Math.min(width, 1280); } var makeSearchItem = (it, idx2key) => { var res = { value: idx2key.length }; var valueKey; res.text = it.text + ''; if (it.desc) res.text += it.desc; valueKey = (0,utils.keyStringOf)(it.value); it.valueKey = valueKey; idx2key.push(valueKey); if (it.items && it.items.length > 0 && it.items.map) { res.items = it.items.map(cIt=>makeSearchItem(cIt, idx2key)); } return res; }; /*** * @extends Follower * @constructor */ function SelectListBox() { this._initDomHook(); this._initControl(); this._initScroller(); this._initProperty(); /*** * @name strictValue * @type {boolean} * @memberOf SelectListBox# */ /*** * @name enableSearch * @type {boolean} * @memberOf SelectListBox# */ } SelectListBox.tag = 'SelectListBox'.toLowerCase(); SelectListBox.render = function () { return SelectListBox_({ tag: 'follower', attr: { tabindex: 0 }, class: 'as-select-list-box', extendEvent: ['pressitem'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller'], child: [ { class: ['as-select-list-box-content'], child: Array(SelectListBox.prototype.preLoadN).fill('.as-select-list-box-page') } ] }, 'attachhook.as-dom-signal' ], props: { anchor: [1, 6, 2, 5] } }); }; SelectListBox.prototype.toLoadNextY = 200; SelectListBox.prototype.preLoadN = 3; SelectListBox.prototype.itemHeightMode = [20, 30]; SelectListBox.prototype.itemHeight = 20; SelectListBox.prototype.revokeResource = function () { if (this.searchMaster) { this.searchMaster.destroy(); this.searchMaster = null; } /* return revokeResource(this._items); // var n = items.length; this._items = undefined; revokeResource(this.idx2key); this.idx2key = undefined; revokeResource(this.key2idx) this.key2idx = undefined; revokeResource(this.searchingItems); this.searchingItems = undefined; revokeResource(this._itemNodeHolderByValue); this._itemNodeHolderByValue = undefined; // this._filteredItems = [];// not need , only use when search revokeResource(this._preDisplayItems); this._preDisplayItems = undefined; revokeResource(this._displayItems); this._displayItems = undefined; revokeResource(this._searchCache) this._searchCache = undefined; */ }; SelectListBox.prototype._initDomHook = function () { if (this.$attachhook) this.$attachhook.cancelWaiting(); this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('viewListAt', this.viewListAt.bind(this)); this.domSignal.on('viewListAtFirstSelected', this.viewListAtFirstSelected.bind(this)); this.domSignal.on('viewListAtCurrentScrollTop', this.viewListAtCurrentScrollTop.bind(this)); /** * * @type {ListSearchMaster|null} */ this.searchMaster = null; this.widthLimit = calcWidthLimit(); this.addStyle('--as-width-limit', this.widthLimit + 'px'); }; SelectListBox.prototype._initControl = function () { this._currentOffset = 0; this._startItemIdx = 0; this.$searchInput = SelectListBox_$('searchtextinput', this) .on('stoptyping', this.eventHandler.searchModify); }; SelectListBox.prototype._initScroller = function () { this.$content = SelectListBox_$('.as-select-list-box-content', this); this._estimateHeight = 0; this._pageOffsets = Array(this.preLoadN + 1).fill(0); this.$listPages = SelectListBox_$$('.as-select-list-box-page', this); this.$listScroller = SelectListBox_$('.as-select-list-box-scroller', this) .on('scroll', this.eventHandler.scroll); }; SelectListBox.prototype._initProperty = function () { /*** * items =(search, filler)=> filteredItems =(list to list, tree to list)=> preDisplayItems =(remove hidden item)=> displayItem * */ this._items = []; this._itemNodeList = [];// use for tree this._values = []; this._valueDict = {}; this._itemNodeHolderByValue = {}; // this._filteredItems = [];// not need , only use when search this._preDisplayItems = []; this._displayItems = []; this._searchCache = {}; this._displayValue = VALUE_NORMAL; this.displayValue = VALUE_NORMAL; this.items = []; }; SelectListBox.prototype._requireItem = function (pageElt, n) { var itemElt; while (pageElt.childNodes.length > n) { itemElt = pageElt.lastChild; itemElt.selfRemove(); (0,SelectList/* releaseItem */.Ag)(itemElt); } while (pageElt.childNodes.length < n) { itemElt = (0,SelectList/* requireItem */.wA)(this); pageElt.addChild(itemElt); } }; SelectListBox.prototype._assignItems = function (pageElt, offset) { var n = Math.min(this._displayItems.length - offset, pageElt.childNodes.length); var itemElt, value; var data; for (var i = 0; i < n; ++i) { itemElt = pageElt.childNodes[i]; data = this._displayItems[offset + i]; if (data && data !== true && data.text) { if (!data.textLength) data.textLength = (0,utils.measureText)(data.text + '', '14px arial').width; if (data.textLength > this.widthLimit - 5) { itemElt.attr('title', data.text); } else itemElt.attr('title', null); } else { itemElt.attr('title', null); } itemElt.data = data; value = itemElt.value + ''; } }; SelectListBox.prototype._itemsToNodeList = function (items) { return items; }; /*** * * @param {Array<{value:String|Number}>} items * @return {Array<{value:String|Number}>} */ SelectListBox.prototype._filterDisplayItems = function (items) { if (this._displayValue === VALUE_NORMAL) return items; var dict = this._valueDict; return items.filter(function (item) { return !dict[item.value + '']; }); }; SelectListBox.prototype._updateSelectedItem = function () { var valueDict = this._valueDict; this.$listPages.forEach(function (pageElt) { Array.prototype.forEach.call(pageElt.childNodes, function (itemElt) { var value = itemElt.value + ''; if (valueDict[value]) { itemElt.selected = true; } else { itemElt.selected = false; } }); }); }; /*** * * @param {number} offset */ SelectListBox.prototype.viewListAt = function (offset) { if (!this.isDescendantOf(document.body)) { this.$attachhook.once('attached', ()=>{ this.domSignal.emit('viewListAt', offset); }); return; } var fontSize = this.$listScroller.getFontSize() || 14; offset = Math.max(0, Math.min(offset, this._displayItems.length - 1)); var screenSize = (0,Dom/* getScreenSize */.tE)(); var maxItem = Math.ceil(Math.max(window.screen.height, screenSize.height) / this.itemHeight); this._pageOffsets[0] = Math.max(offset - maxItem, 0); for (var i = 1; i <= this.preLoadN; ++i) { this._pageOffsets[i] = Math.min(this._pageOffsets[i - 1] + maxItem, this._displayItems.length); } var sIdx, nItem, pageBound; var pageElt; for (var pageIndex = 0; pageIndex < this.preLoadN; ++pageIndex) { sIdx = this._pageOffsets[pageIndex]; nItem = this._pageOffsets[pageIndex + 1] - sIdx; pageElt = this.$listPages[pageIndex]; pageElt.addStyle('top', this._pageOffsets[pageIndex] * this.itemHeight / 14 + 'em'); this._requireItem(pageElt, nItem); this._assignItems(pageElt, sIdx); pageBound = pageElt.getBoundingClientRect(); } this._updateSelectedItem(); }; SelectListBox.prototype.viewListAtFirstSelected = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('viewListAtFirstSelected'); return; } if (this._displayValue == VALUE_HIDDEN) { return false; } else if (this._values.length > 0) { var value = this._values[0]; var itemHolders = this._displayItemHolderByValue[value + '']; if (itemHolders) { this.domSignal.once('scrollIntoSelected', function () { var holder = itemHolders[0]; this.viewListAt(holder.idx); var itemElt = SelectListBox_$('.as-selected', this.$listScroller); if (itemElt) { var scrollBound = this.$listScroller.getBoundingClientRect(); var itemBound = itemElt.getBoundingClientRect(); this.$listScroller.scrollTop += itemBound.top - scrollBound.top; } }.bind(this)); this.domSignal.emit('scrollIntoSelected'); return true; } else return false; } else return false; }; SelectListBox.prototype.viewListAtCurrentScrollTop = function () { if (!this.isDescendantOf(document.body)) { this.emit('viewListAtCurrentScrollTop'); return; } this.viewListAt(Math.floor(this.$listScroller.scrollTop / this.itemHeight)); }; SelectListBox.prototype.searchItemByText = function (text) { text = text.trim().replace(/\s\s+/, ' '); if (text.length === 0) return Promise.resolve(this._items); this.prepareSearch(); this._searchCache[text] = this._searchCache[text] || this.searchMaster.query({ text: text }).then(searchResult => { if (!searchResult) return; var scoreOf = it => { var idx = this.key2idx [it.valueKey]; var sc = searchResult[idx]; if (!sc) return -Infinity; return Math.max(sc[0], sc[1]) * 1000000 - idx; } var makeList = originItems => { var items = originItems.filter(it => { var idx = this.key2idx [it.valueKey]; if (searchResult[idx]) return true; return false; }).map(it => { var cpItem = Object.assign({}, it); if (it.items) cpItem.items = makeList(it.items); return cpItem; }); items.sort((a, b) => scoreOf(b) - scoreOf(a)); return items; } return makeList(this._items); }); return this._searchCache[text]; }; SelectListBox.prototype.resetSearchState = function () { this.$searchInput.value = ''; this._preDisplayItems = this._itemsToNodeList(this._items); this._updateDisplayItem(); this.domSignal.emit('viewListAt', 0); this.$listScroller.scrollTop = 0; }; SelectListBox.prototype.notifyPressOut = function () { this.emit('pressout', { target: this, type: 'pressout' }, this); }; SelectListBox.prototype.notifyPressClose = function () { this.emit('pressclose', { target: this, type: 'pressclose' }, this); }; SelectListBox.prototype._findFirstPageIdx = function () { for (var i = 0; i < this.preLoadN; ++i) { if (this._pageOffsets[i + 1] - this._pageOffsets[i] > 0) { return i; } } return -1; }; SelectListBox.prototype._findLastPageIdx = function () { for (var i = this.preLoadN - 1; i >= 0; --i) { if (this._pageOffsets[i + 1] - this._pageOffsets[i] > 0) { return i; } } return -1; }; SelectListBox.prototype._updateDisplayItemIndex = function () { this._displayItemHolderByValue = indexingByValue(this._displayItems, {}); }; SelectListBox.prototype._updateItemNodeIndex = function () { this._itemNodeHolderByValue = depthIndexingByValue(this._items); }; SelectListBox.prototype._updateDisplayItem = function () { this._displayItems = this._filterDisplayItems(this._preDisplayItems); this._updateDisplayItemIndex(); this.$content.addStyle({ 'height': this._displayItems.length * this.itemHeight / 14 + 'em' }); }; SelectListBox.prototype.focus = function () { if (this.enableSearch) this.$searchInput.focus(); }; SelectListBox.prototype.footerMinWidth = 0; SelectListBox.prototype._updateItems = function () { this._hasIcon = this._items.some(function hasIcon(it) { var res = !!it.icon; if (!res && it.items) { res = it.items.some(hasIcon); } return res; }); if (this._hasIcon) { this.itemHeight = this.itemHeightMode[1]; } else { this.itemHeight = this.itemHeightMode[0]; } this._preDisplayItems = this._itemsToNodeList(this._items); this._searchCache = {}; var estimateSize = (0,SelectList/* measureListSize */.bw)(this._itemNodeList); estimateSize.width = Math.min(this.widthLimit || Infinity, estimateSize.width); this._estimateSize = estimateSize; this._estimateWidth = estimateSize.width; this._estimateDescWidth = estimateSize.descWidth; if (this._hasIcon) { this._estimateWidth += 32; this.addClass('as-has-icon'); } else { this.removeClass('as-has-icon'); } this.addStyle('--select-list-estimate-width', Math.max(this.footerMinWidth, this._estimateWidth) / 14 + 'em'); this.addStyle('--select-list-desc-width', (this._estimateDescWidth) / 14 + 'em'); this._updateDisplayItem(); this.transferSearchDataIfNeed(); }; SelectListBox.prototype.transferSearchDataIfNeed = function () { if (!this.searchMaster) return; this.idx2key = []; this.searchingItems = this._items.map(it => makeSearchItem(it, this.idx2key)); this.key2idx = this.idx2key.reduce((ac, cr, i) => { ac[cr] = i; return ac; }, {}); this.searchMaster.transfer(this.searchingItems); }; SelectListBox.prototype.prepareSearch = function () { if (!this.searchMaster) { this.searchMaster = new ListSearchMaster/* default */.Z(); this.transferSearchDataIfNeed(); } }; /*** * * @param value * @returns {{idx: number, item:{text:string, value:number|string}}[]} */ SelectListBox.prototype.findDisplayItemsByValue = function (value) { return (this._displayItemHolderByValue[value] || []).slice(); }; SelectListBox.prototype._implicit = function (values) { if (!(values instanceof Array)) { if (values === null || values === undefined) values = []; else values = [values]; } return values.reduce(function (ac, cr) { if (!ac.dict[cr]) { ac.dict[cr] = true; ac.result.push(cr); } return ac; }, { result: [], dict: {} }).result; }; SelectListBox.prototype._explicit = function (values) { if (this.strictValue) { return values.filter(function (value) { return !!this._itemNodeHolderByValue[value]; }.bind(this)); } else { return values.slice(); } }; /*** * * @param value * @returns {{idx: number, item:{text:string, value:number|string}}[]} */ SelectListBox.prototype.findItemsByValue = function (value) { return (this._itemNodeHolderByValue[value] || []).slice(); }; SelectListBox.prototype.findItemByValue = function (value) { var t = this._itemNodeHolderByValue[value]; if (t && t.length > 0) { return t[0].item; } else return null; }; SelectListBox.property = {}; /*** * * @type {SelectListBox|{}} */ SelectListBox.property.items = { set: function (items) { items = items || []; if (!(items instanceof Array)) items = []; items = (0,utils.copySelectionItemArray)(items, { removeNoView: true, removeNewLine: true }); this._items = items; this._itemNodeList = this._itemsToNodeList(this._items); this._updateItemNodeIndex(); this._updateItems(); this.viewListAt(0); }, get: function () { return this._items; } } SelectListBox.property.values = { set: function (values) { values = this._implicit(values); this._values = values; this._valueDict = values.reduce(function (ac, cr) { ac[cr + ''] = true; return ac; }, {}); this._updateDisplayItem(); this.viewListAtCurrentScrollTop(); if (this._pageOffsets[this.preLoadN] > this._pageOffsets[0]) this._updateSelectedItem(); }, get: function () { return this._explicit(this._values); } }; SelectListBox.property.strictValue = { set: function (value) { if (value) { this.addClass('as-strict-value'); } else { this.removeClass('as-strict-value'); } }, get: function () { return this.hasClass('as-strict-value'); } }; SelectListBox.property.displayValue = { set: function (value) { this._displayValue = value; this._displayItems = this._filterDisplayItems(this._preDisplayItems); this._updateItemNodeIndex(); if (value === VALUE_HIDDEN) { this.addClass('as-value-hidden'); } else { this.removeClass('as-value-hidden'); } }, get: function () { return this._displayValue; } } SelectListBox.property.enableSearch = { set: function (value) { if (value) this.addClass('as-enable-search'); else this.removeClass('as-enable-search'); }, get: function () { return this.hasClass('as-enable-search'); } }; /*** * * @type {SelectListBox|{}} */ SelectListBox.eventHandler = {}; /* * * @param {MouseEvent} event */ SelectListBox.eventHandler.click = function (event) { if (event.target === this) this.notifyPressOut(); }; /*** * @this SelectListBox */ SelectListBox.eventHandler.searchModify = function () { var text = this.$searchInput.value; var searchSession = Math.random() + ''; this._searchSession = searchSession; this.searchItemByText(text).then(searchedItems => { if (searchSession !== this._searchSession) return; this._preDisplayItems = this._itemsToNodeList(searchedItems); this._displayItems = this._filterDisplayItems(this._preDisplayItems); this.$content.addStyle({ 'height': this._displayItems.length * this.itemHeight / 14 + 'em' }); this._updateItemNodeIndex(); this.viewListAt(0); this.$listScroller.scrollTop = 0; this.updatePosition(); }); }; SelectListBox.eventHandler.scroll = function () { var itemHeight = this.itemHeight * SelectListBox_$(document.body).getFontSize() / 14; var scrollerBound = this.$listScroller.getBoundingClientRect(); var topIdx = this._findFirstPageIdx(); if (!this.$listPages[topIdx]) return; var screenSize = (0,Dom/* getScreenSize */.tE)(); var maxItem = Math.ceil(Math.max(window.screen.height, screenSize.height) / itemHeight); var topBound = this.$listPages[topIdx].getBoundingClientRect(); var botIdx = this._findLastPageIdx(); if (!this.$listPages[botIdx]) return; var botBound; botBound = this.$listPages[botIdx].getBoundingClientRect(); if (topBound.top > scrollerBound.top || topBound.bottom < scrollerBound.bottom) { this.viewListAt(Math.floor(this.$listScroller.scrollTop / itemHeight)) return; } if (this._pageOffsets[topIdx] > 0) { if (topBound.top + this.toLoadNextY > scrollerBound.top) { this._pageOffsets.unshift(this._pageOffsets.pop()); this.$listPages.unshift(this.$listPages.pop()); this._pageOffsets[topIdx] = Math.max(0, this._pageOffsets[topIdx + 1] - maxItem); this._requireItem(this.$listPages[topIdx], this._pageOffsets[topIdx + 1] - this._pageOffsets[topIdx]); this._assignItems(this.$listPages[topIdx], this._pageOffsets[topIdx]); this._updateSelectedItem(); this.$listPages[topIdx].addStyle('top', this._pageOffsets[topIdx] * itemHeight + 'px'); } } if (this._pageOffsets[botIdx + 1] < this._displayItems.length) { if (botBound.bottom - this.toLoadNextY < scrollerBound.bottom) { this._pageOffsets.push(this._pageOffsets.shift()); this.$listPages.push(this.$listPages.shift()); this._pageOffsets[botIdx + 1] = Math.min(this._displayItems.length, this._pageOffsets[botIdx] + maxItem); this.$listPages[botIdx].addStyle('top', this._pageOffsets[botIdx] * itemHeight + 'px'); this._requireItem(this.$listPages[botIdx], this._pageOffsets[botIdx + 1] - this._pageOffsets[botIdx]); this._assignItems(this.$listPages[botIdx], this._pageOffsets[botIdx]); this._updateSelectedItem(); } } }; ACore/* default.install */.Z.install(SelectListBox); /* harmony default export */ const js_SelectListBox = (SelectListBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectBox.js var SelectBox_ = ACore/* default._ */.Z._; var SelectBox_$ = ACore/* default.$ */.Z.$; function pressCloseEventHandler(event) { var parentElt = this.$parent; if (!parentElt) return; parentElt.eventHandler.pressCloseItem(this, event); } function pressHandler(event) { var parentElt = this.$parent; if (!parentElt) return; parentElt.eventHandler.pressItem(this, event); } /*** * * @returns {SelectBoxItem} */ function makeItem() { return SelectBox_({ tag: 'selectboxitem', on: { close: pressCloseEventHandler, press: pressHandler } }); } var itemPool = []; function requireItem($parent) { var item; if (itemPool.length > 0) { item = itemPool.pop(); } else { item = makeItem(); } item.$parent = $parent; return item; } function releaseItem(item) { item.$parent = null; itemPool.push(item); } /*** * @extends PositionTracker * @return {SelectBox} * @constructor */ function SelectBox() { this.on('click', this.eventHandler.click); this.$selectlistBox = SelectBox_({ tag: 'selectlistbox', props: { anchor: [1, 6, 2, 5], displayValue: VALUE_HIDDEN }, on: { preupdateposition: this.eventHandler.preUpdateListPosition, pressitem: this.eventHandler.selectListBoxPressItem } }); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectlistBox, 'enableSearch'); this.$items = []; this._values = []; this.items = []; this.values = []; this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; this.disableClickToFocus = false; this.orderly = true; this.itemFocusable = false; this._activeValue = undefined; return this; } SelectBox.tag = 'selectbox'; SelectBox.render = function () { return SelectBox_({ tag: 'bscroller', class: ['absol-selectbox', 'absol-bscroller'], extendEvent: ['change', 'add', 'remove', 'activevaluechange'], attr: { tabindex: '1' } }, true); }; SelectBox.prototype._requireItem = function (n) { var itemElt; while (this.$items.length < n) { itemElt = requireItem(this); this.addChild(itemElt); this.$items.push(itemElt); } while (this.$items.length > n) { itemElt = this.$items.pop(); this.removeChild(itemElt); releaseItem(itemElt); } }; SelectBox.prototype._assignItems = function (items) { for (var i = 0; i < this.$items.length && i < items.length; ++i) { this.$items[i].data = items[i]; } }; /*** * * @param {string[] | number[]} values * @private */ SelectBox.prototype._getItemsByValues = function (values) { var selectListBoxElt = this.$selectlistBox; var itemHolders = values.reduce(function (ac, cr) { ac.push.apply(ac, selectListBoxElt.findItemsByValue(cr)); return ac; }, []); if (this.orderly) { itemHolders.sort(function (a, b) { return a.idx - b.idx; }); } return itemHolders.map(function (holder) { return holder.item; }) }; SelectBox.prototype._updateItems = function () { this.viewItemsByValues(this._values); }; SelectBox.prototype.viewItemsByValues = function (values) { var items = this._getItemsByValues(values); var cBound = this.getBoundingClientRect(); this._requireItem(items.length); this._assignItems(items); if (this.itemFocusable) { this._updateFocusItem(); } var nBound = this.getBoundingClientRect(); if (nBound.width != cBound.width || nBound.height != cBound.height) { ResizeSystem/* default.updateUp */.Z.updateUp(this); } }; SelectBox.property = {}; SelectBox.property.disabled = SelectMenu2.property.disabled; SelectBox.property.hidden = SelectMenu2.property.hidden; SelectBox.property.isFocus = SelectMenu2.property.isFocus; SelectBox.prototype.init = function (props) { props = props || []; Object.keys(props).forEach(function (key) { if (props[key] === undefined) delete props[key]; }); this.super(props); }; SelectBox.prototype._updateFocusItem = function () { for (var i = 0; i < this.$items.length; ++i) { this.$items[i].active = this.$items[i].value == this._activeValue; } }; SelectBox.prototype.init = SelectMenu2.prototype.init; SelectBox.property.items = { set: function (items) { items = items || []; this.$selectlistBox.items = items; this.addStyle('--list-min-width', this.$selectlistBox._estimateWidth + 'px'); this._updateItems(); }, get: function () { return this.$selectlistBox.items } }; SelectBox.property.values = { set: function (values) { values = values || []; values = (values instanceof Array) ? values : [values]; this._values = values; this.$selectlistBox.values = values; this._updateItems(); }, get: function () { return this._values || []; } }; SelectBox.property.orderly = { set: function (value) { var needUpdate = this._orderly === this._orderly; if (typeof value === 'function') { this._orderly; } else this._orderly = !!value; if (needUpdate) { this.values = this.values; } }, get: function () { return !!this._orderly; } }; SelectBox.property.disableClickToFocus = { set: function (value) { if (value) { this.addClass('as-disable-click-to-focus'); } else { this.removeClass('as-disable-click-to-focus'); } }, get: function () { return this.hasClass('as-disable-click-to-focus'); } }; SelectBox.property.itemFocusable = { set: function (value) { if (value) { this.addClass('as-item-focusable'); } else { this.removeClass('as-item-focusable'); } this._updateFocusItem(); }, get: function () { return this.hasClass('as-item-focusable'); } }; SelectBox.property.activeValue = { set: function (value) { this._activeValue = value; if (this.itemFocusable) { this._updateFocusItem(); //todo } }, get: function () { return this._activeValue; } }; SelectBox.eventHandler = Object.assign({}, SelectMenu2.eventHandler); SelectBox.eventHandler.click = function (event) { if (event.target === this && !this.disableClickToFocus) { this.isFocus = !this.isFocus; } }; SelectBox.eventHandler.bodyClick = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$selectlistBox, event) && event.target !== this) { this.isFocus = false; } }; SelectBox.eventHandler.selectListBoxPressItem = function (event) { var data = event.data; var currentValues = this.$selectlistBox.values; currentValues.push(data.value); this.$selectlistBox.values = currentValues; this.$selectlistBox.updatePosition(); this._activeValue = data.value; this._updateItems(); this.isFocus = false; this.emit('add', Object.assign({}, event, { type: 'add', target: this, value: data.value, data: data, itemData: data }), this); this.emit('change', Object.assign({}, event, { type: 'change', action: 'add', target: this, value: data.value, data: data, values: this.values }), this); }; SelectBox.eventHandler.pressCloseItem = function (item, event) { var value = item.value; var data = item.data; var currentValues = this.$selectlistBox.values; var index = currentValues.indexOf(value); if (index >= 0) { currentValues.splice(index, 1); } this.$selectlistBox.values = currentValues; this.$selectlistBox.updatePosition(); this._values = currentValues; this._updateItems(); this.emit('remove', Object.assign({}, event, { type: 'change', target: this, data: data, value: value, itemData: data }), this); this.emit('change', Object.assign({}, event, { type: 'change', action: 'remove', target: this, data: data, value: value, itemData: data }), this); }; SelectBox.eventHandler.pressItem = function (item, event) { var value = item.value; if (this.itemFocusable) { var prevActiveValue = this.activeValue; if (value !== prevActiveValue) { this.activeValue = value; this.emit('activevaluechange', { target: this, originEvent: event, prevActiveValue: prevActiveValue, activeValue: value }, this); } } }; SelectBox.eventHandler.pressCloseItem = function (item, event) { var value = item.value; var data = item.data; var index; index = this._values.indexOf(value); if (index >= 0) { this._values.splice(index, 1); this._updateItems(); this.$selectlistBox.values = this._values; this.emit('remove', Object.assign({}, event, { type: 'change', target: this, data: data, value: value, itemData: data }), this); this.emit('change', Object.assign({}, event, { type: 'change', action: 'remove', target: this, data: data, value: value, itemData: data }), this); } }; ACore/* default.install */.Z.install(SelectBox); /* harmony default export */ const js_SelectBox = (SelectBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selecttable.css var selecttable = __webpack_require__(32); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringMatching.js var stringMatching = __webpack_require__(991); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringFormat.js var stringFormat = __webpack_require__(6382); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTable.js var privateDom = new Dom/* default */.ZP().install(ACore/* default */.Z); var SelectTable_$ = privateDom.$; var SelectTable_ = privateDom._; function SelectTable() { var thisST = this; this.$attachhook = SelectTable_('attachhook').addTo(this); this.sync = new Promise(function (rs) { thisST.$attachhook.on('error', rs); }); this.$buttonsContainer = SelectTable_$('.absol-select-table-buttons-container', this); this.$searchContainer = SelectTable_$('.absol-select-table-searchtextinput-container', this); this.$nonselectedItemsContainer = SelectTable_$('.absol-select-table-nonselected-items-container', this); this.$selectedItemsContainer = SelectTable_$('.absol-select-table-selected-items-container', this); this.$nonselectedSearchItemsContainer = SelectTable_$('.absol-select-table-nonselected-search-items-container', this); this.$selectedSearchItemsContainer = SelectTable_$('.absol-select-table-selected-search-items-container', this); this.$removeAllBtn = SelectTable_$('button.remove-all', this).on('click', this.eventHandler.removeAllBtnClick); this.$addAllBtn = SelectTable_$('button.add-all', this).on('click', this.eventHandler.addAllBtnClick); this.$vscrollerSelected = SelectTable_$('bscroller#selected', this) this.$vscrollerNonselected = SelectTable_$('bscroller#nonselected', this); this.$body = SelectTable_$('.absol-select-table-body', this); this.$header = SelectTable_$('.absol-select-table-header', this); /*** * * @type {SearchTextInput} */ this.$searchTextInput = SelectTable_$('searchtextinput', this).on('stoptyping', this.eventHandler.searchTextInputModify); this.$addAllBtn.updateSize = function () { thisST.updateScroller && thisST.updateScroller(); }; Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this.$addAllBtn); return this; } SelectTable.tag = 'SelectTable'.toLowerCase(); SelectTable.render = function () { return SelectTable_({ class: 'absol-select-table', extendEvent: ['change', 'addall', 'removeall', 'add', 'remove'], child: [ { class: 'absol-select-table-header', child: [ { class: 'absol-select-table-searchtextinput-container', child: 'searchtextinput' }, { class: 'absol-select-table-buttons-container', child: [ { tag: 'button', class: 'add-all', props: { innerHTML: 'Add All' } }, { tag: 'button', class: 'remove-all', props: { innerHTML: 'Remove All' } } ] } ] }, { class: 'absol-select-table-body', child: [ { tag: 'bscroller', attr: { id: 'nonselected' }, class: ['absol-select-table-items-scroller'], child: { child: ['.absol-select-table-nonselected-items-container', '.absol-select-table-nonselected-search-items-container'] } }, { tag: 'bscroller', attr: { id: 'selected' }, class: ['absol-select-table-items-scroller'], child: { child: ['.absol-select-table-selected-items-container', '.absol-select-table-selected-search-items-container'] } } ] } ] }); } SelectTable.prototype.updateButtonsContainerSize = function () { var rootBound = this.$buttonsContainer.getBoundingClientRect(); var containBound = this.$buttonsContainer.getBoundingRecursiveRect(); var fontSize = this.getFontSize(); this.$buttonsContainer.addStyle('width', (containBound.width + 1) / fontSize + 'em'); this.$searchContainer.addStyle('right', (containBound.width + 5) / fontSize + 'em'); }; SelectTable.prototype.addAll = function () { Array.apply(null, this.$nonselectedItemsContainer.childNodes).forEach(function (e) { e.addTo(this.$selectedItemsContainer); }.bind(this)); this.requestSort(); }; SelectTable.prototype.removeAll = function () { Array.apply(null, this.$selectedItemsContainer.childNodes).forEach(function (e) { e.addTo(this.$nonselectedItemsContainer); }.bind(this)) this.requestSort(); }; SelectTable.prototype.updateScroller = function () { var update = function () { if (this.style.height) { var height = parseFloat(this.getComputedStyleValue('height').replace('px', '')); var headerHeight = parseFloat(this.$header.getComputedStyleValue('height').replace('px', '')); var bodyMargin = parseFloat(this.$body.getComputedStyleValue('margin-top').replace('px', '')); var borderWidth = 1; var availableHeight = height - headerHeight - bodyMargin * 2 - borderWidth * 2; this.$vscrollerNonselected.addStyle('max-height', availableHeight + 'px'); this.$vscrollerSelected.addStyle('max-height', availableHeight + 'px'); } }.bind(this); setTimeout(update, 1); }; SelectTable.prototype.getAllItemElement = function () { var selectedItemElements = Array.apply(null, this.$selectedItemsContainer.childNodes); var nonselectedItemElements = Array.apply(null, this.$nonselectedItemsContainer.childNodes); return selectedItemElements.concat(nonselectedItemElements); }; SelectTable.prototype.init = function (props) { this.super(props); this.sync = this.sync.then(this.updateButtonsContainerSize.bind(this)); }; SelectTable.eventHandler = {}; SelectTable.eventHandler.addAllBtnClick = function (event) { this.addAll(); if (this.searching) { this.eventHandler.searchTextInputModify(event); } this.emit('addall', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, {}), this); this.updateScroller(); }; SelectTable.eventHandler.removeAllBtnClick = function (event) { this.removeAll(); if (this.searching) { this.eventHandler.searchTextInputModify(event); } this.emit('removeall', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, {}), this); this.updateScroller(); }; SelectTable.prototype._filter = function (items, filterText) { var result = []; if (filterText.length == 1) { result = items.map(function (item) { var res = { item: item, text: typeof item === 'string' ? item : item.text }; return res; }).map(function (it) { it.score = 0; var text = it.text.replace(/((\ )|(\s))+/g, ' ').trim(); it.score += text.toLowerCase().indexOf(filterText.toLowerCase()) >= 0 ? 100 : 0; text = (0,stringFormat.nonAccentVietnamese)(text); it.score += text.toLowerCase().indexOf(filterText.toLowerCase()) >= 0 ? 100 : 0; return it; }); result.sort(function (a, b) { if (b.score - a.score == 0) { if ((0,stringFormat.nonAccentVietnamese)(b.text) > (0,stringFormat.nonAccentVietnamese)(a.text)) return -1; return 1; } return b.score - a.score; }); result = result.filter(function (x) { return x.score > 0; }); } else { var its = items.map(function (item) { var res = { item: item, text: typeof item === 'string' ? item : item.text }; var text = res.text.replace(/((\ )|(\s))+/g, ' ').trim(); res.score = ((0,stringMatching.phraseMatch)(text, filterText) + (0,stringMatching.phraseMatch)((0,stringFormat.nonAccentVietnamese)(text), (0,stringFormat.nonAccentVietnamese)(filterText))) / 2; if ((0,stringFormat.nonAccentVietnamese)(text).replace(/s/g, '').toLowerCase().indexOf((0,stringFormat.nonAccentVietnamese)(filterText).toLowerCase().replace(/s/g, '')) > -1) res.score = 100; return res; }); if (its.length == 0) return; its.sort(function (a, b) { if (b.score - a.score == 0) { if ((0,stringFormat.nonAccentVietnamese)(b.text) > (0,stringFormat.nonAccentVietnamese)(a.text)) return -1; return 1; } return b.score - a.score; }); var result = its.filter(function (x) { return x.score > 0.5; }); if (result.length == 0) { var bestScore = its[0].score; result = its.filter(function (it) { return it.score + 0.001 >= bestScore; }); } if (result[0].score == 0) result = []; } result = result.map(function (e) { return e.item; }); return result; }; SelectTable.prototype._stringcmp = function (s0, s1) { if (s0 == s1) return 0; if (s0 > s1) return 1; return -1; }; SelectTable.prototype._getString = function (item) { if (typeof item == "string") return item; return item.text; }; SelectTable.prototype._equalArr = function (a, b) { if (a.length != b.length) return false; for (var i = 0; i < a.length; ++i) { if (a[i] != b[i] && a[i].text != b[i].text && a[i].value != b[i].value) return false; } return true; }; SelectTable.prototype._applySort = function (items, sortFlag) { var res = items.slice(); if (sortFlag == 1 || sortFlag === true) { res.sort(function (a, b) { return this._stringcmp(this._getString(a), this._getString(b)) }.bind(this)) } else if (sortFlag == -1) { res.sort(function (a, b) { return -this._stringcmp(this._getString(a), this._getString(b)) }.bind(this)) } else if (typeof sortFlag == 'function') { res.sort(function (a, b) { return sortFlag(a, b) }.bind(this)) } return res; }; SelectTable.prototype.requestSort = function () { if (!this.sorted || this.sorted == 0) return; var selectedItems = this.selectedItems; var selectedItemsNew = this._applySort(selectedItems, this.sorted); if (!this._equalArr(selectedItems, selectedItemsNew)) { this.selectedItems = selectedItemsNew; } var nonselectedItems = this.nonselectedItems; var nonselectedItemsNew = this._applySort(nonselectedItems, this.sorted); if (!this._equalArr(nonselectedItems, nonselectedItemsNew)) { this.nonselectedItems = nonselectedItemsNew; } }; SelectTable.eventHandler.searchTextInputModify = function (event) { var filterText = this.$searchTextInput.value.trim(); if (filterText.length > 0) { var selectedItems = this.selectedItems; var nonselectedItems = this.nonselectedItems; this.selectedSearchItems = selectedItems; this.nonselectedSearchItems = this._filter(nonselectedItems, filterText); this.selectedSearchItems = this._filter(selectedItems, filterText); } else { } this.searching = filterText.length > 0; }; SelectTable.property = {}; SelectTable.property.disableMoveAll = { set: function (value) { if (value) this.addClass('disable-move-all'); else this.removeClass('disable-move-all'); }, get: function () { return this.hasClass('disable-move-all'); } }; SelectTable.property.removeAllText = { set: function (text) { this._removeAllText = text; //todo: update remove all text if (!text) this.$removeAllBtn.addStyle('display', 'none'); else { this.$removeAllBtn.removeStyle('display'); this.$removeAllBtn.innerHTML = this.removeAllText; this.updateButtonsContainerSize(); } }, get: function () { return this._removeAllText || 'Remove All' } }; SelectTable.property.addAllText = { set: function (text) { this._addAllText = text; if (!text) this.$addAllBtn.addStyle('display', 'none'); else { this.$addAllBtn.removeStyle('display'); this.$addAllBtn.innerHTML = this.removeAllText; this.updateButtonsContainerSize(); } }, get: function () { return this._addAllText || 'Add All' } }; SelectTable.property.searching = { set: function (value) { if (value) { this.addClass('searching'); } else { this.removeClass('searching'); } this.updateScroller(); }, get: function () { return this.hasClass('searching'); } }; SelectTable.property.sorted = { set: function (value) { this._sort = value; this.requestSort(); }, get: function () { return this._sort; } }; SelectTable.property.selectedItems = { set: function (items) { this.$selectedItemsContainer.clearChild(); var $nonselectedItemsContainer = this.$nonselectedItemsContainer; var $selectedItemsContainer = this.$selectedItemsContainer; var self = this; if (items instanceof Array) { items.map(function (item) { return SelectTable_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedItemsContainer) { this.addTo($nonselectedItemsContainer); self.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } else { this.addTo($selectedItemsContainer); self.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } self.updateScroller(); self.requestSort(); } } }).addTo(this.$selectedItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); this.requestSort(); }, get: function () { return Array.prototype.map.call(this.$selectedItemsContainer.childNodes, function (e) { return e.data; }); } } SelectTable.property.nonselectedItems = { set: function (items) { this.$nonselectedItemsContainer.clearChild(); var $nonselectedItemsContainer = this.$nonselectedItemsContainer; var $selectedItemsContainer = this.$selectedItemsContainer; var self = this; if (items instanceof Array) { items.map(function (item) { return SelectTable_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedItemsContainer) { this.addTo($nonselectedItemsContainer); self.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } else { this.addTo($selectedItemsContainer); self.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } self.updateScroller(); self.requestSort(); } } }).addTo(this.$nonselectedItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); this.requestSort(); }, get: function () { return Array.prototype.map.call(this.$nonselectedItemsContainer.childNodes, function (e) { return e.data; }); } }; SelectTable.property.selectedSearchItems = { set: function (items) { this.$selectedSearchItemsContainer.clearChild(); var $nonselectedSearchItemsContainer = this.$nonselectedSearchItemsContainer; var $selectedSearchItemsContainer = this.$selectedSearchItemsContainer; var table = this; if (items instanceof Array) { items.map(function (item) { return SelectTable_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedSearchItemsContainer) { this.addTo($nonselectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$nonselectedItemsContainer); return true; } return false; }.bind(this)); table.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } else { this.addTo($selectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$selectedItemsContainer); return true; } return false; }.bind(this)); table.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } table.updateScroller(); table.requestSort(); } } }).addTo(this.$selectedSearchItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); }, get: function () { return Array.prototype.map.call(this.$selectedSearchItemsContainer.childNodes, function (e) { return e.data; }); } } SelectTable.property.nonselectedSearchItems = { set: function (items) { this.$nonselectedSearchItemsContainer.clearChild(); var $nonselectedSearchItemsContainer = this.$nonselectedSearchItemsContainer; var $selectedSearchItemsContainer = this.$selectedSearchItemsContainer; var table = this; if (items instanceof Array) { items.map(function (item) { return SelectTable_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedSearchItemsContainer) { this.addTo($nonselectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$nonselectedItemsContainer); return true; } return false; }.bind(this)); table.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } else { this.addTo($selectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$selectedItemsContainer); return true; } return false; }.bind(this)); table.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } table.updateScroller(); table.requestSort(); } } }).addTo(this.$nonselectedSearchItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); }, get: function () { return Array.prototype.map.call(this.$nonselectedSearchItemsContainer.childNodes, function (e) { return e.data; }); } }; /* namespace of selecttable */ function Item() { var res = SelectTable_({ extendEvent: ['requestmove'], class: 'absol-select-table-item', child: ['span.absol-select-table-item-text', { class: 'absol-select-table-item-right-container', child: { class: 'absol-select-table-item-right-container-table', child: { class: 'absol-select-table-item-right-container-cell', child: ['addicon', 'subicon'] } } } ] }); res.$text = SelectTable_$('span', res); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, Item.eventHandler); res.$rightBtn = SelectTable_$('.absol-select-table-item-right-container', res); res.on('dblclick', res.eventHandler.dblclick); res.$rightBtn.on('click', res.eventHandler.rightBtClick); return res; }; Item.eventHandler = {}; Item.eventHandler.dblclick = function (event) { event.preventDefault(); if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$rightBtn, event)) this.emit('requestmove', event, this); }; Item.eventHandler.rightBtClick = function (event) { this.emit('requestmove', event, this); }; Item.property = {}; Item.property.data = { set: function (value) { this._data = value; if (value) { var text; if (typeof value == "string") { text = value; } else { text = value.text; } this.$text.innerHTML = text; } }, get: function () { return this._data; } }; Item.property.text = { get: function () { return this._data ? (typeof this._data == 'string' ? this._data : this._data.text) : ''; } }; /** * * <svg width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"> <g transform="translate(0,-197)"> <path d="m39.873 198.21v38.668h-38.668v20.252h38.668v38.668h20.253v-38.668h38.668v-20.252h-38.668v-38.668z" style="fill-rule:evenodd;fill:#5fbbc2;stroke-linejoin:round;stroke-width:2.4109;stroke:#002eea"/> </g> </svg> */ function AddIcon() { return Svg/* default.ShareInstance.buildSvg */.ZP.ShareInstance.buildSvg( '<svg class="add-icon" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">' + '<g transform="translate(0,-197)">' + '<path d="m39.873 198.21v38.668h-38.668v20.252h38.668v38.668h20.253v-38.668h38.668v-20.252h-38.668v-38.668z" style="fill-rule:evenodd;stroke-linejoin:round;stroke-width:2.4109;" />' + '</g>' + '</svg>' ); }; function SubIcon() { return Svg/* default.ShareInstance.buildSvg */.ZP.ShareInstance.buildSvg( '<svg class="sub-icon" width="100mm" height="100mm" version="1.1" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">' + ' <g transform="translate(0,-197)">' + ' <path d="m98.795 236.87v20.253h-97.589v-20.253z" style="fill-rule:evenodd;stroke-linejoin:round;stroke-width:2.411;"/>' + ' </g>' + '</svg>' ); }; privateDom.install({ subicon: SubIcon, addicon: AddIcon, item: Item }); SelectTable.privateDom = privateDom; ACore/* default.install */.Z.install(SelectTable); /* harmony default export */ const js_SelectTable = (SelectTable); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTable2.js var SelectTable2_privateDom = new Dom/* default */.ZP().install(ACore/* default */.Z).install(js_SelectTable.privateDom); var SelectTable2_$ = SelectTable2_privateDom.$; var SelectTable2_ = SelectTable2_privateDom._; function SelectTable2() { var thisST = this; this.$attachhook = SelectTable2_('attachhook').addTo(this); this.sync = new Promise(function (rs) { thisST.$attachhook.on('error', rs); }); this.$buttonsContainer = SelectTable2_$('.absol-select-table-buttons-container', this); this.$searchContainer = SelectTable2_$('.absol-select-table-searchtextinput-container', this); this.$nonselectedItemsContainer = SelectTable2_$('.absol-select-table-nonselected-items-container', this); this.$selectedItemsContainer = SelectTable2_$('.absol-select-table-selected-items-container', this); this.$nonselectedSearchItemsContainer = SelectTable2_$('.absol-select-table-nonselected-search-items-container', this); this.$selectedSearchItemsContainer = SelectTable2_$('.absol-select-table-selected-search-items-container', this); this.$removeAllBtn = SelectTable2_$('button.remove-all', this).on('click', this.eventHandler.removeAllBtnClick); this.$addAllBtn = SelectTable2_$('button.add-all', this).on('click', this.eventHandler.addAllBtnClick); this.$vscrollerSelected = SelectTable2_$('vscroller#selected', this) this.$vscrollerNonselected = SelectTable2_$('vscroller#nonselected', this); this.$body = SelectTable2_$('.absol-select-table-body', this); this.$searchTextInput = SelectTable2_$('searchtextinput', this).on('stoptyping', this.eventHandler.searchTextInputModify); }; SelectTable2.tag = 'SelectTable2'.toLowerCase(); SelectTable2.render = function () { return SelectTable2_({ class: ['absol-select-table', 'exclude'], extendEvent: ['change', 'addall', 'removeall', 'add', 'remove'], child: [ { class: 'absol-select-table-header', child: [ { class: 'absol-select-table-searchtextinput-container', child: 'searchtextinput' }, { class: 'absol-select-table-buttons-container', child: [ { tag: 'button', class: 'add-all', props: { innerHTML: 'Add All' } }, { tag: 'button', class: 'remove-all', props: { innerHTML: 'Remove All' } } ] } ] }, { class: 'absol-select-table-body', child: [ { tag: 'vscroller', attr: { id: 'nonselected' }, class: 'absol-select-table-items-scroller', child: { child: ['.absol-select-table-nonselected-items-container', '.absol-select-table-nonselected-search-items-container'] } }, { tag: 'vscroller', attr: { id: 'selected' }, class: 'absol-select-table-items-scroller', child: { child: ['.absol-select-table-selected-items-container', '.absol-select-table-selected-search-items-container'] } } ] } ] }); }; SelectTable2.prototype.updateButtonsContainerSize = function () { var rootBound = this.$buttonsContainer.getBoundingClientRect(); var containBound = this.$buttonsContainer.getBoundingRecursiveRect(); var fontSize = this.getFontSize(); this.$buttonsContainer.addStyle('width', (containBound.width + 1) / fontSize + 'em'); this.$searchContainer.addStyle('right', (containBound.width + 5) / fontSize + 'em'); }; SelectTable2.prototype.addAll = function () { Array.apply(null, this.$nonselectedItemsContainer.childNodes).forEach(function (e) { e.addTo(this.$selectedItemsContainer); }.bind(this)); this.requestSort(); }; SelectTable2.prototype.removeAll = function () { Array.apply(null, this.$selectedItemsContainer.childNodes).forEach(function (e) { e.addTo(this.$nonselectedItemsContainer); }.bind(this)) this.requestSort(); }; SelectTable2.prototype.updateScroller = function () { var update = function () { if (this.style.height) { var bodyMargin = parseFloat(this.$body.getComputedStyleValue('margin-top').replace('px', '') || (0.14285714285 * 14 + '')); var bound = this.getBoundingClientRect(); var bodyBound = this.$body.getBoundingClientRect(); var bodyRBound = this.$body.getBoundingRecursiveRect(); var availableHeight = bound.bottom - bodyMargin - bodyBound.top; var isOverflowHeight = availableHeight < bodyRBound.height; if (isOverflowHeight) { this.$vscrollerNonselected.addStyle('max-height', availableHeight + 'px'); this.$vscrollerSelected.addStyle('max-height', availableHeight + 'px'); this.$vscrollerSelected.addClass('limited-height'); this.$vscrollerNonselected.addClass('limited-height'); } else { this.$vscrollerNonselected.removeStyle('max-height'); this.$vscrollerSelected.removeStyle('max-height'); this.$vscrollerSelected.removeClass('limited-height'); this.$vscrollerSelected.removeClass('limited-height'); this.$vscrollerNonselected.removeClass('limited-height'); } } requestAnimationFrame(this.$vscrollerNonselected.requestUpdateSize.bind(this.$vscrollerNonselected)); requestAnimationFrame(this.$vscrollerSelected.requestUpdateSize.bind(this.$vscrollerSelected)); }.bind(this); setTimeout(update, 1); }; SelectTable2.prototype.getAllItemElement = function () { var selectedItemElements = Array.apply(null, this.$selectedItemsContainer.childNodes); var nonselectedItemElements = Array.apply(null, this.$nonselectedItemsContainer.childNodes); return selectedItemElements.concat(nonselectedItemElements); }; SelectTable2.prototype.init = function (props) { this.super(props); this.sync = this.sync.then(this.updateButtonsContainerSize.bind(this)); }; SelectTable2.eventHandler = {}; SelectTable2.eventHandler.addAllBtnClick = function (event) { this.addAll(); if (this.searching) { this.eventHandler.searchTextInputModify(event); } this.emit('addall', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, {}), this); this.updateScroller(); }; SelectTable2.eventHandler.removeAllBtnClick = function (event) { this.removeAll(); if (this.searching) { this.eventHandler.searchTextInputModify(event); } this.emit('removeall', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, {}), this); this.updateScroller(); }; SelectTable2.prototype._filter = function (items, filterText) { var result = []; if (filterText.length == 1) { result = items.map(function (item) { var res = { item: item, text: typeof item === 'string' ? item : item.text }; return res; }).map(function (it) { it.score = 0; var text = it.text.replace(/((\ )|(\s))+/g, ' ').trim(); it.score += text.toLowerCase().indexOf(filterText.toLowerCase()) >= 0 ? 100 : 0; text = (0,stringFormat.nonAccentVietnamese)(text); it.score += text.toLowerCase().indexOf(filterText.toLowerCase()) >= 0 ? 100 : 0; return it; }); result.sort(function (a, b) { if (b.score - a.score == 0) { if ((0,stringFormat.nonAccentVietnamese)(b.text) > (0,stringFormat.nonAccentVietnamese)(a.text)) return -1; return 1; } return b.score - a.score; }); result = result.filter(function (x) { return x.score > 0; }); } else { var its = items.map(function (item) { var res = { item: item, text: typeof item === 'string' ? item : item.text }; var text = res.text.replace(/((\ )|(\s))+/g, ' ').trim(); res.score = ((0,stringMatching.phraseMatch)(text, filterText) + (0,stringMatching.phraseMatch)((0,stringFormat.nonAccentVietnamese)(text), (0,stringFormat.nonAccentVietnamese)(filterText))) / 2; if ((0,stringFormat.nonAccentVietnamese)(text).replace(/s/g, '').toLowerCase().indexOf((0,stringFormat.nonAccentVietnamese)(filterText).toLowerCase().replace(/s/g, '')) > -1) res.score = 100; return res; }); if (its.length == 0) return; its.sort(function (a, b) { if (b.score - a.score == 0) { if ((0,stringFormat.nonAccentVietnamese)(b.text) > (0,stringFormat.nonAccentVietnamese)(a.text)) return -1; return 1; } return b.score - a.score; }); var result = its.filter(function (x) { return x.score > 0.5; }); if (result.length == 0) { var bestScore = its[0].score; result = its.filter(function (it) { return it.score + 0.001 >= bestScore; }); } if (result[0].score == 0) result = []; } result = result.map(function (e) { return e.item; }); return result; }; SelectTable2.prototype._stringcmp = function (s0, s1) { if (s0 == s1) return 0; if (s0 > s1) return 1; return -1; }; SelectTable2.prototype._getString = function (item) { if (typeof item == "string") return item; return item.text; }; SelectTable2.prototype._equalArr = function (a, b) { if (a.length != b.length) return false; for (var i = 0; i < a.length; ++i) { if (a[i] != b[i]) return false; } return true; }; SelectTable2.prototype._applySort = function (items, sortFlag) { var res = items.slice(); if (sortFlag == 1 || sortFlag === true) { res.sort(function (a, b) { return this._stringcmp(this._getString(a), this._getString(b)) }.bind(this)) } else if (sortFlag == -1) { res.sort(function (a, b) { return -this._stringcmp(this._getString(a), this._getString(b)) }.bind(this)) } else if (typeof sortFlag == 'function') { res.sort(function (a, b) { return sortFlag(a, b) }.bind(this)) } return res; }; SelectTable2.prototype.requestSort = function () { if (!this.sorted || this.sorted == 0) return; var selectedItems = this.selectedItems; var selectedItemsNew = this._applySort(selectedItems, this.sorted); if (!this._equalArr(selectedItems, selectedItemsNew)) { this.selectedItems = selectedItemsNew; } var nonselectedItems = this.nonselectedItems; var nonselectedItemsNew = this._applySort(nonselectedItems, this.sorted); if (!this._equalArr(nonselectedItems, nonselectedItemsNew)) { this.nonselectedItems = nonselectedItemsNew; } }; SelectTable2.eventHandler.searchTextInputModify = function (event) { var filterText = this.$searchTextInput.value.trim(); if (filterText.length > 0) { var selectedItems = this.selectedItems; var nonselectedItems = this.nonselectedItems; this.selectedSearchItems = selectedItems; this.nonselectedSearchItems = this._filter(nonselectedItems, filterText); this.selectedSearchItems = this._filter(selectedItems, filterText); } else { } this.searching = filterText.length > 0; }; SelectTable2.property = {}; SelectTable2.property.disableMoveAll = { set: function (value) { if (value) this.addClass('disable-move-all'); else this.removeClass('disable-move-all'); }, get: function () { return this.hasClass('disable-move-all'); } }; SelectTable2.property.removeAllText = { set: function (text) { this._removeAllText = text; //todo: update remove all text if (!text) this.$removeAllBtn.addStyle('display', 'none'); else { this.$removeAllBtn.removeStyle('display'); this.$removeAllBtn.innerHTML = this.removeAllText; this.updateButtonsContainerSize(); } }, get: function () { return this._removeAllText || 'Remove All' } }; SelectTable2.property.addAllText = { set: function (text) { this._addAllText = text; if (!text) this.$addAllBtn.addStyle('display', 'none'); else { this.$addAllBtn.removeStyle('display'); this.$addAllBtn.innerHTML = this.removeAllText; this.updateButtonsContainerSize(); } }, get: function () { return this._addAllText || 'Add All' } }; SelectTable2.property.searching = { set: function (value) { if (value) { this.addClass('searching'); } else { this.removeClass('searching'); } this.updateScroller(); }, get: function () { return this.hasClass('searching'); } }; SelectTable2.property.sorted = { set: function (value) { this._sort = value; this.requestSort(); }, get: function () { return this._sort; } }; SelectTable2.property.selectedItems = { set: function (items) { this.$selectedItemsContainer.clearChild(); var $nonselectedItemsContainer = this.$nonselectedItemsContainer; var $selectedItemsContainer = this.$selectedItemsContainer; var self = this; if (items instanceof Array) { items.map(function (item) { return SelectTable2_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedItemsContainer) { this.addTo($nonselectedItemsContainer); self.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } else { this.addTo($selectedItemsContainer); self.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } self.updateScroller(); self.requestSort(); } } }).addTo(this.$selectedItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); this.requestSort(); }, get: function () { return Array.prototype.map.call(this.$selectedItemsContainer.childNodes, function (e) { return e.data; }); } } SelectTable2.property.nonselectedItems = { set: function (items) { this.$nonselectedItemsContainer.clearChild(); var $nonselectedItemsContainer = this.$nonselectedItemsContainer; var $selectedItemsContainer = this.$selectedItemsContainer; var self = this; if (items instanceof Array) { items.map(function (item) { return SelectTable2_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedItemsContainer) { this.addTo($nonselectedItemsContainer); self.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } else { this.addTo($selectedItemsContainer); self.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), self); } self.updateScroller(); self.requestSort(); } } }).addTo(this.$nonselectedItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); this.requestSort(); }, get: function () { return Array.prototype.map.call(this.$nonselectedItemsContainer.childNodes, function (e) { return e.data; }); } }; SelectTable2.property.selectedSearchItems = { set: function (items) { this.$selectedSearchItemsContainer.clearChild(); var $nonselectedSearchItemsContainer = this.$nonselectedSearchItemsContainer; var $selectedSearchItemsContainer = this.$selectedSearchItemsContainer; var table = this; if (items instanceof Array) { items.map(function (item) { return SelectTable2_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedSearchItemsContainer) { this.addTo($nonselectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$nonselectedItemsContainer); return true; } return false; }.bind(this)); table.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } else { this.addTo($selectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$selectedItemsContainer); return true; } return false; }.bind(this)); table.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } table.updateScroller(); table.requestSort(); } } }).addTo(this.$selectedSearchItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); }, get: function () { return Array.prototype.map.call(this.$selectedSearchItemsContainer.childNodes, function (e) { return e.data; }); } } SelectTable2.property.nonselectedSearchItems = { set: function (items) { this.$nonselectedSearchItemsContainer.clearChild(); var $nonselectedSearchItemsContainer = this.$nonselectedSearchItemsContainer; var $selectedSearchItemsContainer = this.$selectedSearchItemsContainer; var table = this; if (items instanceof Array) { items.map(function (item) { return SelectTable2_({ tag: 'item', props: { data: item }, on: { requestmove: function (event) { if (this.parentElement == $selectedSearchItemsContainer) { this.addTo($nonselectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$nonselectedItemsContainer); return true; } return false; }.bind(this)); table.emit('remove', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } else { this.addTo($selectedSearchItemsContainer); table.getAllItemElement().filter(function (itemElement) { if (itemElement.data == this.data) { itemElement.addTo(table.$selectedItemsContainer); return true; } return false; }.bind(this)); table.emit('add', EventEmitter/* default.copyEvent */.ZP.copyEvent(event, { item: item }), table); } table.updateScroller(); table.requestSort(); } } }).addTo(this.$nonselectedSearchItemsContainer); }.bind(this)) } else { // error } this.updateScroller(); }, get: function () { return Array.prototype.map.call(this.$nonselectedSearchItemsContainer.childNodes, function (e) { return e.data; }); } }; /* namespace of selecttable */ function SelectTable2_Item() { var res = SelectTable2_({ extendEvent: ['requestmove', 'clickadd', 'clickremove', 'clickexclude'], class: 'absol-select-table-item', child: ['span.absol-select-table-item-text', { class: 'absol-select-table-item-right-container', child: { class: 'absol-select-table-item-right-container-table', child: { class: 'absol-select-table-item-right-container-row', child: [ { attr: { title: 'Add' }, class: ['absol-select-table-item-right-container-cell', 'add'], child: 'addicon' }, { attr: { title: 'Remove' }, class: ['absol-select-table-item-right-container-cell', 'remove'], child: 'subicon' }, { attr: { title: 'Exclude' }, class: ['absol-select-table-item-right-container-cell', 'exclude'], child: 'excludeico' }, ] } } } ] }); res.$text = SelectTable2_$('span', res); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, SelectTable2_Item.eventHandler); res.$rightBtn = SelectTable2_$('.absol-select-table-item-right-container', res); res.on('dblclick', res.eventHandler.dblclick); res.$addBtn = SelectTable2_$('.absol-select-table-item-right-container-cell.add', res).on('click', res.eventHandler.addBtClick); res.$removeBtn = SelectTable2_$('.absol-select-table-item-right-container-cell.remove', res).on('click', res.eventHandler.removeBtClick); res.$excludeBtn = SelectTable2_$('.absol-select-table-item-right-container-cell.exclude', res).on('click', res.eventHandler.excludeBtClick); return res; }; SelectTable2_Item.eventHandler = {}; SelectTable2_Item.eventHandler.dblclick = function (event) { event.preventDefault(); if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$rightBtn, event)) this.emit('requestmove', event, this); }; SelectTable2_Item.eventHandler.rightBtClick = function (event) { this.emit('requestmove', event, this); }; SelectTable2_Item.eventHandler.removeBtClick = function (event) { this.emit('clickremove', event, this); }; SelectTable2_Item.eventHandler.addBtClick = function (event) { this.emit('clickadd', event, this); }; SelectTable2_Item.eventHandler.excludeBtClick = function (event) { this.emit('clickexclude', event, this); }; SelectTable2_Item.property = {}; SelectTable2_Item.property.data = { set: function (value) { this._data = value; if (value) { var text; if (typeof value == "string") { text = value; } else { text = value.text; } this.$text.innerHTML = text; } }, get: function () { return this._data; } }; SelectTable2_Item.property.text = { get: function () { return this._data ? (typeof this._data == 'string' ? this._data : this._data.text) : ''; } }; function ExcludeIco() { return SelectTable2_( '<svg class="exclude-icon" width="24" height="24" viewBox="0 0 24 24">\ <path d="M8.27,3L3,8.27V15.73L8.27,21H15.73C17.5,19.24 21,15.73 21,15.73V8.27L15.73,3M9.1,5H14.9L19,9.1V14.9L14.9,19H9.1L5,14.9V9.1M11,15H13V17H11V15M11,7H13V13H11V7" />\ </svg>'); } SelectTable2_privateDom.install({ item: SelectTable2_Item, excludeico: ExcludeIco }); // not completed yet ACore/* default.install */.Z.install('selecttable2', SelectTable2); /* harmony default export */ const js_SelectTable2 = (SelectTable2); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/spaninput.css var spaninput = __webpack_require__(5351); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SpanInput.js var SpanInput_ = ACore/* default._ */.Z._; var SpanInput_$ = ACore/* default.$ */.Z.$; function SpanInput() { this.defineEvent(['change']); this._inputType = 0; this._lastValue = null; this.on('paste', this.eventHandler.paste) .on('keyup', this.eventHandler.keyup) .on('keydown', this.eventHandler.keydown) .on('blur', this.eventHandler.blur); } SpanInput.prototype.notifyValueChange = function (event) { var cValue = this.value; if (this._lastValue != cValue && (this._inputType != 1 || !isNaN(this._lastValue) || !isNaN(cValue))) { this._lastValue = cValue; this.emit('change', { type: 'change', value: cValue, originEvent: event }, this); } } SpanInput.eventHandler = {}; SpanInput.eventHandler.keyup = function (event) { if (this._inputType == 0) { this.notifyValueChange(event); } else if (this._inputType == 1) { this.eventHandler.numberKeyup(event) } }; SpanInput.eventHandler.keydown = function (event) { if (this._inputType == 0) { } else if (this._inputType == 1) { this.eventHandler.numberKeydown(event) } }; SpanInput.eventHandler.numberBlur = function (value) { this.notifyValueChange(event); }; SpanInput.eventHandler.textBlur = function (event) { this.notifyValueChange(event); }; SpanInput.eventHandler.blur = function (event) { if (this._inputType == 0) { this.eventHandler.textBlur(event); } else if (this._inputType == 1) { this.eventHandler.numberKeydown(event) } } SpanInput.eventHandler.numberKeyup = function (event) { this.notifyValueChange(); }; SpanInput.eventHandler.numberKeydown = function (event) { var key = event.key; if (key == 'Enter') { event.preventDefault(); this.blur(); this.notifyValueChange(); return; } if (key && key.length == 1 && !event.ctrlKey && !event.altKey) { if (key.match(/[0-9.\-\+]/)) { if (key == '.' && this.text.indexOf('.') >= 0) event.preventDefault(); if ((key == '+' || key == '-') && (this.text.indexOf('+') >= 0 || this.text.indexOf('-') >= 0 || getCaretPosition(this) > 0)) event.preventDefault(); } else event.preventDefault(); } }; SpanInput.eventHandler.paste = function (event) { event.preventDefault(); if (event.clipboardData && event.clipboardData.getData) { var text = event.clipboardData.getData("text/plain"); if (this._inputType == 1) text = text.replace(/[^0-9.\-+]/g, ''); document.execCommand("insertHTML", false, text); if (this._inputType == 1) { if (isNaN(this.value)) { this.value = NaN; } } } else if (window.clipboardData && window.clipboardData.getData) { var text = window.clipboardData.getData("Text"); if (this._inputType == 1) text = text.replace(/[^0-9.\-+]/g, ''); (0,utils.insertTextAtCursor)(text); if (this._inputType == 1) { if (isNaN(this.value)) { this.value = NaN; } } } }; SpanInput.property = {}; SpanInput.property.value = { set: function (value) { if (this._inputType == 1 && isNaN(value)) value = null; this.clearChild(); if (value !== null) this.addChild(SpanInput_({ text: value + '' })); }, get: function () { if (this._inputType == 1) { return parseFloat(this.text); } else { return this.text; } } }; SpanInput.property.type = { set: function (value) { var index = ['text', 'number'].indexOf(value); if (index < 0) index = 0; this._inputType = index; if (index == 1) { this.addClass('absol-span-input-empty-minus'); } else { this.removeClass('absol-span-input-empty-minus'); } }, get: function () { return ['text', 'number'][this._inputType]; } }; SpanInput.property.text = { get: function () { return (0,Text.getTextIn)(this); } } SpanInput.tag = 'spaninput'; SpanInput.render = function () { return SpanInput_('span.absol-span-input[contenteditable="true"]'); }; ACore/* default.install */.Z.install(SpanInput); /* harmony default export */ const js_SpanInput = (SpanInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/statictabbar.css var statictabbar = __webpack_require__(4322); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/StaticTabbar.js var StaticTabbar_$ = ACore/* default.$ */.Z.$; var StaticTabbar_ = ACore/* default._ */.Z._; function StaticTabbar() { var thisST = this; this.$activeBox = StaticTabbar_$('.absol-static-tabbar-active-box', this) this.$hline = StaticTabbar_$('.absol-static-tabbar-hline', this); this.$buttons = []; this._btDict = {}; this._activedButton = undefined; this.sync = new Promise(function (resolve) { StaticTabbar_('attachhook').on('error', function () { this.remove(); resolve(); }).addTo(thisST); }); return this; } StaticTabbar.tag = 'StaticTabbar'.toLowerCase(); StaticTabbar.render = function () { return StaticTabbar_({ class: 'absol-static-tabbar', extendEvent: 'change', child: [ { class: 'absol-static-tabbar-active-box', child: '.absol-static-tabbar-hline' } ] }); }; StaticTabbar.prototype.fireChange = function (data) { this.emit('change', { target: this, data, value: this.value }, self); } StaticTabbar.property = {}; StaticTabbar.property.items = { set: function (value) { this.$buttons.forEach(function (e) { e.remove() }); this._items = value; var self = this; this.$buttons = this.items.map(function (tab) { var ident = (tab.value || (0,stringGenerate.randomIdent)()); var button = StaticTabbar_({ tag: 'button', class: 'absol-static-tabbar-button', id: 'tab-' + ident, child: { tag: 'span', child: { text: tab.text } }, on: { click: function (event) { if (self.value != tab.value) { self.value = ident; self.fireChange(tab); } } } }).addTo(self); self._btDict[ident] = button; return button; }); if (this.value !== undefined) { this.sync.then(this.activeTab.bind(this, this.value)); } }, get: function () { return this._items || []; } }; StaticTabbar.property.value = { set: function (value) { this._value = value; if (this.$buttons.length > 0) { this.sync.then(this.activeTab.bind(this, value)); } }, get: function () { return this._value; } }; StaticTabbar.prototype.activeTab = function (ident) { if (this._activedButton) this._activedButton.removeClass('active'); var button = this._btDict[ident]; this._activedButton = button; if (button) { button.addClass('active'); var bound = this.getBoundingClientRect(); var buttonBound = button.getBoundingClientRect(); var dx = buttonBound.left - bound.left; var fontSize = this.getFontSize(); this.$activeBox.addStyle({ left: dx / fontSize + 'em', width: buttonBound.width / fontSize + 'em' }); } else { this.$activeBox.addStyle({ left: '0', width: '0' }); } }; ACore/* default.install */.Z.install('statictabbar', StaticTabbar); /* harmony default export */ const js_StaticTabbar = (StaticTabbar); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/switch.css var css_switch = __webpack_require__(8252); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/Switch.js var Switch_ = ACore/* default._ */.Z._; var Switch_$ = ACore/* default.$ */.Z.$; function Switch() { var thisS = this; this.$input = Switch_$('input', this); this.$input.on('click', function (event) { thisS.emit('change', event, thisS); }); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, 'checked'); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$input, 'isOn', 'checked'); this.on('click', function (event){ if (this.readOnly) event.preventDefault(); }, true); } Switch.tag = 'switch'; Switch.render = function () { return Switch_({ tag: 'label', class: 'absol-switch', extendEvent: 'change', child: [ 'input[type="checkbox"]', 'span.absol-switch-slider' ] }); }; Switch.attribute = { checked: { set: function (value) { if (value == 'false' || value == null) { this.checked = false; } else { this.checked = true; } }, get: function () { return this.checked ? 'true' : 'false' }, remove: function () { this.checked = false; } }, disabled: { set: function (value) { if (value == 'false' || value == null) { this.disabled = false; } else { this.disabled = true; } }, get: function () { return this.disabled ? 'true' : 'false' }, remove: function () { this.disabled = false; } } }; Switch.property = { disabled: { set: function (value) { this.$input.disabled = !!value; if (value) { this.addClass('disabled'); } else { this.removeClass('disabled'); } }, get: function () { return this.$input.disabled; } }, readOnly: CheckBoxInput/* default.property.readOnly */.Z.property.readOnly }; ACore/* default.install */.Z.install('switch', Switch); /* harmony default export */ const js_Switch = (Switch); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/CheckboxButton.js var CheckboxButton = __webpack_require__(4654); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tablescroller.css var tablescroller = __webpack_require__(5436); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/tablescroller/TSLMoveTool.js /*** * * @param {TableScroller} elt * @constructor */ function TSLMoveTool(elt) { this.elt = elt; this.$table = null; Object.keys(TSLMoveTool.prototype).forEach((key) => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this.init(); } TSLMoveTool.prototype.init = function () { this.elt = (0,ACore._)({ tag: Hanger/* default */.Z, elt: this.elt, on: { predrag: this.ev_preDrag, dragstart: this.ev_dragStart, drag: this.ev_drag, dragend: this.ev_dragEnd } }); }; TSLMoveTool.prototype.onAttachTable = function () { }; TSLMoveTool.prototype.ev_preDrag = function (event) { var e = event.target; var isOK = false; while (e && e.tagName !== 'TABLE') { if (e.classList && e.classList.contains('as-drag-zone')) { isOK = true; break; } e = e.parentElement; } if (isOK) { event.preventDefault(); } else { event.cancel(); } }; TSLMoveTool.prototype._findRowIdx = function (y) { var newY = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.$originTableBody.getBoundingClientRect()).y; var oldY = this.dragData.bodyBound.y; var dy = newY - oldY; var yArr = this.dragData.rowBounds.map((rect) => rect.y + dy + rect.height / 2); if (this.dragData.rowBounds.length === 0) yArr.push(0); var low = 0; var high = yArr.length - 1; var mid0, mid1; while (low < high) { mid0 = (low + high) >> 1; mid1 = mid0 + 1; if (Math.abs(y - yArr[mid0]) < Math.abs(y - yArr[mid1])) { high = mid0; } else { low = mid1; } } return low; }; TSLMoveTool.prototype.ev_dragStart = function (event) { var t = this.findRow(event.target); if (!t) return; this.elt.addClass('as-dragging'); this.dragData = Object.assign({}, t); this.dragData.copy.addClass('as-dragging'); this.dragData.original.addClass('as-dragging'); var rowBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.dragData.original.getBoundingClientRect()); var bodyBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.$originTableBody.getBoundingClientRect()); this.dragData.mouseOffset = event.currentPoint .sub(rowBound.A()); this.dragData.rowIdx = Array.prototype.indexOf.call(this.elt.$originTableBody.childNodes, this.dragData.original); this.dragData.newRowIdx = this.dragData.rowIdx; this.dragData.rowBound = rowBound; this.dragData.bodyBound = bodyBound; this.dragData.rowOffset = rowBound.A().sub(bodyBound.A()); this.dragData.rowBounds = Array.prototype.map.call(this.elt.$originTableBody.childNodes, elt => Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect())); }; TSLMoveTool.prototype.ev_drag = function (event) { if (!this.dragData) return; var bodyBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.$originTableBody.getBoundingClientRect()); var rowA = bodyBound.A().add(this.dragData.rowOffset); var rowTransformed = event.currentPoint.sub(this.dragData.mouseOffset); var transform = rowTransformed.sub(rowA); var originalRow = this.dragData.original; originalRow.addStyle('transform', `translate(0, ${transform.y}px )`); this.dragData.copy.addStyle('transform', `translate(0, ${transform.y}px )`); this.dragData.hiddenCells = Array.prototype.filter.call(this.dragData.original.childNodes, e => e.tagName === 'TD') .slice(0, this.elt.fixedCol); this.dragData.hiddenCells.forEach(e => (0,ACore.$)(e).addClass('as-transparent-fix')); var newIdx = this._findRowIdx(rowTransformed.y + this.dragData.rowBound.height / 2); this.dragData.newRowIdx = newIdx; var rows = this.elt.$originTableBody.childNodes; var curIdx = this.dragData.rowIdx; // var copyRows = this.elt.$f var rowBound = this.dragData.rowBound; rows.forEach((elt, i) => { if (elt === originalRow) return; var copyElt = this.elt.leftCopyRows[elt.getAttribute('data-id')]; var dy = 0; if (i >= Math.min(newIdx, curIdx) && i <= Math.max(newIdx, curIdx)) { if (i > curIdx && i <= newIdx) { dy = -rowBound.height; } else if (i >= newIdx && i < curIdx) { dy = rowBound.height; } } elt.addStyle('transform', `translate(0, ${dy}px)`); copyElt.addStyle('transform', `translate(0, ${dy}px)`); }); }; TSLMoveTool.prototype.ev_dragEnd = function (event) { this.dragData.original.removeStyle('transform'); this.dragData.copy.removeStyle('transform'); this.dragData.copy.removeClass('as-dragging'); this.dragData.original.removeClass('as-dragging'); this.elt.removeClass('as-dragging'); this.elt.removeClass('as-has-new-pos'); this.dragData.hiddenCells.forEach(e => e.removeClass('as-transparent-fix')); var rows = this.elt.$originTableBody.childNodes; rows.forEach(elt => { var copyElt = this.elt.leftCopyRows[elt.getAttribute('data-id')]; elt.addStyle('transform', 'translate(0, 0)'); copyElt.addStyle('transform', 'translate(0, 0)'); }); var at, copyAt; if (this.dragData.newRowIdx !== this.dragData.rowIdx) { at = rows[this.dragData.newRowIdx]; copyAt = this.elt.leftCopyRows[at.attr('data-id')]; if (this.dragData.rowIdx < this.dragData.newRowIdx) { (0,ACore.$)(at.parentElement).addChildAfter(this.dragData.original, at); (0,ACore.$)(copyAt.parentElement).addChildAfter(this.dragData.copy, copyAt); } else { (0,ACore.$)(at.parentElement).addChildBefore(this.dragData.original, at); (0,ACore.$)(copyAt.parentElement).addChildBefore(this.dragData.copy, copyAt); } this.elt.reindexRows(); this.elt.emit('orderchange', { target: this.elt, from: this.dragData.rowIdx, to: this.dragData.newRowIdx }, this.elt); } }; TSLMoveTool.prototype.findRow = function (fromElt) { var e = fromElt; var rowElt; while (e) { if (e.tagName === 'TR') { rowElt = e; break; } e = e.parentElement; } if (!rowElt) return null; var id = rowElt.getAttribute('data-id'); return { original: (0,ACore.$)(this.elt.originalRows[id]), copy: (0,ACore.$)(this.elt.leftCopyRows[id]) } }; /* harmony default export */ const tablescroller_TSLMoveTool = (TSLMoveTool); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/tablescroller/TableScroller.js var TableScroller_$ = ACore/* default.$ */.Z.$; var TableScroller_ = ACore/* default._ */.Z._; var sliceCellArray = (cells, start, end) => { if (typeof start !== "number") start = 0; if (typeof end !== "number") end = Infinity; var res = []; cells = cells.slice(); var cell, colSpan; var n = 0; while (cells.length > 0) { cell = cells.shift(); colSpan = parseInt(cell.getAttribute('colspan') || '1') || 1; n += colSpan; if (n > start && n <= end) res.push(cell); } return res; } /*** * @extends {AElement} * @constructor */ function TableScroller() { this.$originCtn = TableScroller_$('.as-table-scroller-origin-table-ctn', this); this.$originTable = undefined; this.$originContent = undefined; this.$fixedYHeaderScroller = TableScroller_$('.as-table-scroller-fixed-y-header-scroller', this); this.$fixedYHeader = TableScroller_$('.as-table-scroller-fixed-y-header', this); this.$fixedXYHeader = TableScroller_$('.as-table-scroller-fixed-xy-header', this); this.$fixXCol = TableScroller_$('.as-table-scroller-fixed-x-col', this); this.$attachHook = TableScroller_$('attachhook', this); this.$attachHook.requestUpdateSize = this.updateContentSize.bind(this); this.requestUpdateSize = this.updateContentSize.bind(this); this.$attachHook.on('attached', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); }); this.$domSignal = TableScroller_('attachhook'); this.appendChild(this.$domSignal); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); this.domSignal.on('requestUpdateContent', this.updateContent.bind(this)); this.$vscrollbar = TableScroller_$('.absol-table-scroller-vscrollbar-container vscrollbar', this); this.$hscrollbar = TableScroller_$('.absol-table-scroller-hscrollbar-container hscrollbar', this); this.$vscroller = TableScroller_$('.as-table-scroller-vertical-scroller', this); this.$hscroller = TableScroller_$('.as-table-scroller-horizontal-scroller', this); this.$leftLine = TableScroller_$('.absol-table-scroller-left-line', this).addStyle('display', 'none'); this.$headLine = TableScroller_$('.absol-table-scroller-head-line', this); this.scrollCtr = new ScrollController(this); this.moveTool = new tablescroller_TSLMoveTool(this); this._swappedPairs = []; this.originalRows = {}; this.leftCopyRows = {}; /*** * @name fixedCol * @type {number} * @memberOf TableScroller# */ } TableScroller.tag = 'TableScroller'.toLowerCase(); TableScroller.render = function () { return TableScroller_({ class: 'absol-table-scroller', extendEvent: ['orderchange', 'preupdatesize', 'sizeupdated'], child: [ { class: 'absol-table-scroller-content', child: [ { class: 'as-table-scroller-vertical-scroller', child: [ { class: 'as-table-scroller-horizontal-scroller-viewport', child: [ { class: 'as-table-scroller-fixed-x-col-ctn', child: { tag: 'table', class: 'as-table-scroller-fixed-x-col', } }, { class: 'as-table-scroller-horizontal-scroller', child: [ { class: 'as-table-scroller-origin-table-ctn' } ] } ] } ] }, { class: 'as-table-scroller-fixed-y-header-ctn', child: { class: 'as-table-scroller-fixed-y-header-scroller', child: { tag: 'table', class: 'as-table-scroller-fixed-y-header', } } }, { class: 'as-table-scroller-fixed-xy-header-ctn', child: { tag: 'table', class: 'as-table-scroller-fixed-xy-header' } }, '.absol-table-scroller-viewport', '.absol-table-scroller-fixed-viewport',//place holder { class: 'absol-table-scroller-header-hscroller', child: '.absol-table-scroller-header-hscroller-viewport' }, { class: 'absol-table-scroller-left-vscroller', child: '.absol-table-scroller-left-vscroller-viewport' }, '.absol-table-scroller-head-line', '.absol-table-scroller-left-line' ] }, { class: 'absol-table-scroller-vscrollbar-container', child: { tag: 'vscrollbar' } }, { class: 'absol-table-scroller-hscrollbar-container', child: { tag: 'hscrollbar' } }, 'attachhook' ] }); }; TableScroller.scrollSize = 17;//default Dom/* default.getScrollSize */.ZP.getScrollSize().then(function (size) { TableScroller.scrollSize = size.width;//default scroller TableScroller.$style = TableScroller_('style[id="table-scroller-css"]').addTo(document.head); TableScroller.$style.innerHTML = [ 'body .absol-table-scroller {', ' --scrollbar-width: ' + (size.width + 0) + 'px', '}', ].join('\n'); Dom/* default.updateResizeSystem */.ZP.updateResizeSystem(); setTimeout(Dom/* default.updateResizeSystem.bind */.ZP.updateResizeSystem.bind(Dom/* default */.ZP), 30);// css load delay }); TableScroller.eventHandler = {}; TableScroller.prototype.clearChild = function () { this.$fixXCol.clearChild(); this.$fixedYHeader.clearChild(); this.$fixedXYHeader.clearChild(); if (this.$originTable) this.$originTable.remove(); this.$originTable = null; return this; }; TableScroller.prototype.addChild = function (elt) { if (this.$originTable) { throw new Error('Only one table is accepted!'); } this.$originContent = elt; this.$originTable = TableScroller_$('table', this.$originContent); this.$originCtn.addChild(this.$originTable); this.requestUpdateContent(); }; TableScroller.prototype._revertWrapped = function () { var pair; while (this._swappedPairs.length > 0) { pair = this._swappedPairs.pop(); (0,utils.swapChildrenInElt)(pair[0], pair[1]); } }; TableScroller.prototype._makeDataIdent = function () { this.originalRows = {}; Array.prototype.slice.call(this.$originTableBody.childNodes).forEach((elt, i) => { var id; if (elt.tagName === 'TR') { id = elt.getAttribute('data-id') || (0,stringGenerate.randomIdent)(12) + '_' + i; elt.setAttribute('data-id', id); this.originalRows[id] = TableScroller_$(elt); } else { elt.remove(); } }); }; TableScroller.prototype._updateFixedYHeader = function () { var head = TableScroller_$(this.$originTableThead.cloneNode(false)); var headRows = Array.prototype.filter.call(this.$originTableThead.childNodes, elt => elt.tagName === 'TR') .map(tr => { var copyTr = TableScroller_$(tr.cloneNode(false)); copyTr.$origin = tr; var cells = Array.prototype.filter.call(tr.childNodes, elt => elt.tagName === 'TH' || elt.tagName === 'TD') .map(td => TableScroller_$(Object.assign(td.cloneNode(true), { $origin: td }))); copyTr.addChild(cells); sliceCellArray(cells, this.fixedCol).forEach(elt => { (0,utils.swapChildrenInElt)(elt, elt.$origin); this._swappedPairs.push([elt, elt.$origin]); }); return copyTr; }); head.addChild(headRows); this.$fixedYHeader.clearChild().addChild(head); this.$fixedYHeader.attr('class', this.$originTable.attr('class')).addClass('as-table-scroller-fixed-y-header'); }; TableScroller.prototype._updateFixedYHeaderSize = function () { var bound = this.$originTable.getBoundingClientRect(); this.$fixedYHeader.addStyle('width', bound.width + 'px'); if (this.$fixedYHeader.firstChild && this.$fixedYHeader.firstChild.firstChild) Array.prototype.forEach.call(this.$fixedYHeader.firstChild.firstChild.childNodes, elt => { var bound = elt.$origin.getBoundingClientRect(); elt.addStyle('width', bound.width + 'px'); if (bound.width + bound.height === 0) { elt.addStyle('display', 'none'); } else { elt.removeStyle('display'); } }); var headBound = this.$originTableThead.getBoundingClientRect(); this.$fixedYHeader.addStyle('height', headBound.height + 'px'); // this.$fixedYHeader this.$headLine.addStyle('top',headBound.height - 1 + 'px') .addStyle('max-width', bound.width + 'px'); }; TableScroller.prototype._updateFixedXCol = function () { this.$fixXCol.clearChild(); var head = TableScroller_$(this.$originTableThead.cloneNode(false)); var headRows = Array.prototype.filter.call(this.$originTableThead.childNodes, elt => elt.tagName === 'TR') .map(tr => { var copyTr = TableScroller_$(tr.cloneNode(false)); copyTr.$origin = tr; var cells = Array.prototype.filter.call(tr.childNodes, elt => elt.tagName === 'TH' || elt.tagName === 'TD'); cells = sliceCellArray(cells, 0, this.fixedCol) .map(td => TableScroller_$(Object.assign(td.cloneNode(true), { $origin: td }))); copyTr.addChild(cells); return copyTr; }); head.addChild(headRows); var body = TableScroller_$(this.$originTableBody.cloneNode()); var rows = Array.prototype.filter.call(this.$originTableBody.childNodes, elt => elt.tagName === 'TR') .map(tr => { var copyTr = TableScroller_$(tr.cloneNode(false)); copyTr.$origin = tr; var id = copyTr.attr('data-id'); this.leftCopyRows[id] = copyTr; var cells = Array.prototype.filter.call(tr.childNodes, elt => elt.tagName === 'TH' || elt.tagName === 'TD'); cells = sliceCellArray(cells, 0, this.fixedCol) .map(td => TableScroller_$(Object.assign(td.cloneNode(true), { $origin: td }))); cells.forEach(elt => { (0,utils.swapChildrenInElt)(elt, elt.$origin); this._swappedPairs.push([elt, elt.$origin]); }); copyTr.addChild(cells); return copyTr; }); body.addChild(rows); this.$fixXCol.addChild(head) .addChild(body); this.$fixXCol.attr('class', this.$originTable.attr('class')).addClass('as-table-scroller-fixed-x-col'); }; TableScroller.prototype._updateFixedXColSize = function () { if (this.fixedCol === 0) return; var bound = this.$originTable.getBoundingClientRect(); // this.$fixXCol.addStyle('height', bound.height + 'px'); var width = 0; Array.prototype.forEach.call(this.$fixXCol.firstChild.childNodes, elt => { elt.addStyle('height', elt.$origin.getBoundingClientRect().height + 'px'); }); Array.prototype.forEach.call(this.$fixXCol.firstChild.firstChild.childNodes, elt => { var bound = elt.$origin.getBoundingClientRect(); width += bound.width + 1;//1 is border elt.addStyle('width', bound.width + 'px'); }); Array.prototype.forEach.call(this.$fixXCol.lastChild.childNodes, elt => { elt.addStyle('height', elt.$origin.getBoundingClientRect().height + 'px'); }); this.$fixXCol.addStyle('width', width + 'px'); this.$fixedXYHeader.addStyle('width', width + 'px'); }; TableScroller.prototype._updateFixedXYHeader = function () { var head = TableScroller_$(this.$originTableThead.cloneNode(false)); var headRows = Array.prototype.filter.call(this.$originTableThead.childNodes, elt => elt.tagName === 'TR') .map(tr => { var copyTr = TableScroller_('tr'); copyTr.$origin = tr; var cells = Array.prototype.filter.call(tr.childNodes, elt => elt.tagName === 'TH' || elt.tagName === 'TD'); cells = sliceCellArray(cells, 0, this.fixedCol) .map(td => TableScroller_$(Object.assign(td.cloneNode(true), { $origin: td }))); copyTr.addChild(cells); cells.forEach(cell => { (0,utils.swapChildrenInElt)(cell, cell.$origin); this._swappedPairs.push([cell, cell.$origin]); }) return copyTr; }); head.addChild(headRows); this.$fixedXYHeader.clearChild().addChild(head); this.$fixedXYHeader.attr('class', this.$originTable.attr('class')).addClass('as-table-scroller-fixed-xy-header'); }; TableScroller.prototype._updateFixedXYHeaderSize = function () { if (this.$fixedXYHeader.firstChild) { Array.prototype.forEach.call(this.$fixedXYHeader.firstChild.childNodes, elt => { elt.addStyle('height', elt.$origin.getBoundingClientRect().height + 'px'); }); } if (this.$fixedXYHeader.firstChild && this.$fixedXYHeader.firstChild.firstChild) Array.prototype.forEach.call(this.$fixedXYHeader.firstChild.firstChild.childNodes, elt => { elt.addStyle('width', elt.$origin.getBoundingClientRect().width + 'px'); }); this.$leftLine.addStyle('left', this.$fixedXYHeader.getBoundingClientRect().width - 1 + 'px'); }; TableScroller.prototype.updateContent = function () { if (!this.$originTable) return; this._revertWrapped(); this.$originTableThead = TableScroller_$('thead', this.$originTable); this.$originTableBody = TableScroller_$('tbody', this.$originTable); this._makeDataIdent(); this._updateFixedYHeader(); this._updateFixedXCol(); this._updateFixedXYHeader(); this.reindexRows(); this.updateContentSize(); requestAnimationFrame(() => { this.updateContentSize(); }); }; TableScroller.prototype._updateScrollStatus = function () { var bound = this.getBoundingClientRect(); var tableBound = this.$originTable.getBoundingClientRect(); if (bound.width < tableBound.width) { this.addClass('as-scroll-horizontal'); this.$vscrollbar.outerHeight = bound.height - 17; } else { this.$vscrollbar.outerHeight = bound.height; this.removeClass('as-scroll-horizontal'); } if (bound.height < tableBound.height) { this.addClass('as-scroll-vertical'); this.$hscrollbar.outerWidth = bound.width - 17; } else { this.$hscrollbar.outerWidth = bound.width; this.removeClass('as-scroll-vertical'); } var paddingBottom = this.getComputedStyleValue('--tvs-scroll-padding-bottom'); paddingBottom = parseFloat((paddingBottom || '0px').replace('px', '')); this.$vscrollbar.innerHeight = tableBound.height + paddingBottom; this.$hscrollbar.innerWidth = tableBound.width; if (this.style.maxHeight) { this.addStyle('height', tableBound.height + 17 + 'px'); } }; TableScroller.prototype.updateContentSize = function () { if (!this.$originTable) return; this._updateScrollStatus(); this._updateFixedYHeaderSize(); this._updateFixedXColSize(); this._updateFixedXYHeaderSize(); }; TableScroller.prototype.reindexRows = function () { if (!this.$originTableBody) return; Array.prototype.filter.call(this.$originTableBody.childNodes, elt => elt.tagName === 'TR') .forEach((elt, i) => { if (elt.$idx === null) return; elt.$idx = elt.$idx || TableScroller_$('.as-table-scroller-row-index', elt) || null; if (elt.$idx) elt.$idx.attr('data-idx', i + 1); }); Array.prototype.forEach.call(this.$fixXCol.lastChild.childNodes, (elt, i) => { if (elt.$idx === null) return; elt.$idx = elt.$idx || TableScroller_$('.as-table-scroller-row-index', elt) || null; if (elt.$idx) elt.$idx.attr('data-idx', i + 1); }); }; TableScroller.prototype.removeRow = function (row) { if (TableScroller_$(row).isDescendantOf(this)) { row.remove(); this.requestUpdateContent(); } return this; }; TableScroller.prototype.addRowBefore = function (row, bf) { if (!this.$originTableBody) return this; this.$originTableBody.addChildBefore(row, bf); this.requestUpdateContent(); return this; }; TableScroller.prototype.addRowAfter = function (row, at) { if (!this.$originTableBody) return this; this.$originTableBody.addChildAfter(row, at); this.requestUpdateContent(); return this; }; TableScroller.prototype.requestUpdateContent = function () { this.domSignal.emit('requestUpdateContent'); }; TableScroller.property = {}; TableScroller.property.fixedCol = { set: function (value) { value = value || 0; this._fixedCol = value; if (value === 0) this.$leftLine.addStyle('display', 'none'); else this.$leftLine.removeStyle('display'); this.requestUpdateContent(); // this.$domSignal.emit('requestUpdateContent'); }, get: function () { return this._fixedCol || 0; } }; ACore/* default.install */.Z.install(TableScroller); /* harmony default export */ const tablescroller_TableScroller = (TableScroller); /*** * * @param {TableScroller} elt * @constructor */ function ScrollController(elt) { this.elt = elt; Object.keys(this.constructor.prototype).filter(k => k.startsWith('ev_')) .forEach(k => this[k] = this[k].bind(this)); this.vscrollTarget = null; this.hscrollTarget = null; this.elt.$vscroller.on('scroll', this.ev_vScrollerScroll); this.elt.$vscrollbar.on('scroll', this.ev_vScrollbarScroll); this.elt.$hscroller.on('scroll', this.ev_hScrollerScroll); this.elt.$hscrollbar.on('scroll', this.ev_hScrollbarScroll); this.elt.$fixedYHeaderScroller.on('scroll', this.ev_fixedYHeaderScroll); } ScrollController.prototype.ev_vScrollerScroll = function (event) { var now = new Date().getTime(); if (this.vscrollTarget && now - this.vscrollTarget.time < 100 && this.vscrollTarget.elt !== this.elt.$vscroller) return; this.elt.$vscrollbar.innerOffset = this.elt.$vscroller.scrollTop; this.vscrollTarget = { time: now, elt: this.elt.$vscroller }; }; ScrollController.prototype.ev_vScrollbarScroll = function (event) { var now = new Date().getTime(); if (this.vscrollTarget && now - this.vscrollTarget.time < 100 && this.vscrollTarget.elt !== this.elt.$vscrollbar) return; this.elt.$vscroller.scrollTop = this.elt.$vscrollbar.innerOffset; this.vscrollTarget = { time: now, elt: this.elt.$vscrollbar }; }; ScrollController.prototype.ev_hScrollerScroll = function (event) { var now = new Date().getTime(); if (this.hscrollTarget && now - this.hscrollTarget.time < 100 && this.hscrollTarget.elt !== this.elt.$hscroller) return; this.elt.$hscrollbar.innerOffset = this.elt.$hscroller.scrollLeft; this.elt.$fixedYHeaderScroller.scrollLeft = this.elt.$hscroller.scrollLeft; this.hscrollTarget = { time: now, elt: this.elt.$hscroller }; }; ScrollController.prototype.ev_fixedYHeaderScroll = function (event) { var now = new Date().getTime(); if (this.hscrollTarget && now - this.hscrollTarget.time < 100 && this.hscrollTarget.elt !== this.elt.$fixedYHeaderScroller) return; this.elt.$hscrollbar.innerOffset = this.elt.$fixedYHeaderScroller.scrollLeft; this.elt.$hscroller.scrollLeft = this.elt.$fixedYHeaderScroller.scrollLeft; this.hscrollTarget = { time: now, elt: this.elt.$fixedYHeaderScroller }; }; ScrollController.prototype.ev_hScrollbarScroll = function (event) { var now = new Date().getTime(); if (this.hscrollTarget && now - this.hscrollTarget.time < 100 && this.hscrollTarget.elt !== this.elt.$hscrollbar) return; this.elt.$hscroller.scrollLeft = this.elt.$hscrollbar.innerOffset >> 0; this.vscrollTarget = { time: now, elt: this.elt.$hscrollbar }; }; // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tablevscroller.css var tablevscroller = __webpack_require__(2908); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TableVScroller.js var TableVScroller_ = ACore/* default._ */.Z._; var TableVScroller_$ = ACore/* default.$ */.Z.$; function TableVScroller() { var thisTS = this; this.$attachHook = TableVScroller_$('attachhook', this); this.$attachHook.updateSize = () => { this.updateStyle(); this.updateSize(); }; this.sync = new Promise(function (rs) { thisTS.$attachHook.on('attached', rs) }); this.$viewport = TableVScroller_$('.absol-table-vscroller-viewport', this); this.$attachHook.on('attached', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(thisTS.$attachHook); this.updateSize(); }); this.$topTable = TableVScroller_$('.absol-table-vscroller-head', this); this.$headLine = TableVScroller_$('.absol-table-vscroller-head-line', this); this.swappedContentPairs = []; } TableVScroller.tag = 'TableVScroller'.toLowerCase(); TableVScroller.render = function () { return TableVScroller_( { class: 'absol-table-vscroller', child: [ '.absol-table-vscroller-viewport', 'table.absol-table-vscroller-head', '.absol-table-vscroller-head-line', 'attachhook' ] } ); }; TableVScroller.prototype.clearChild = function () { this.$viewport.clearChild(); this.$topTable.clearChild(); }; TableVScroller.prototype.addChild = function (elt) { if (this.$viewport.childNodes.length == 0) { this.$table = elt.$table || TableVScroller_$('table',elt); if (this.$table) { this.$viewport.addChild(elt); this.update(); } else { throw new Error('Element must be a table!'); } } else { throw new Error("Only 1 table accepted!"); } }; TableVScroller.prototype._trackBackgroundColor = function (element) { var current = this.$thead; var res; while (current && !res && res != 'rgba(0, 0, 0, 0)') { res = window.getComputedStyle(element).getPropertyValue('background-color'); current = current.parentNode; } if (res == 'rgba(0, 0, 0, 0)') return 'white'; return res; } TableVScroller.prototype.updateStyle = function () { if (!this.$thead) return; var clazz = this.$table.attr('class'); if (clazz) { clazz = clazz.trim().split(/\s+/); for (var i = 0; i < clazz.length; ++i) { this.$topTable.addClass(clazz[i]); } } var bgColor = this._trackBackgroundColor(this.$thead); this.$topTable.addStyle('background-color', bgColor); }; TableVScroller.prototype.updateSize = function () { if (!this.$thead) return; var theadBound = this.$thead.getBoundingClientRect(); var tableBound = this.$table.getBoundingClientRect(); this.$topTable.addStyle({ width: tableBound.width + 'px', height: theadBound.height + 'px' }); this.$headLine.addStyle({ top: theadBound.height + 'px', maxWidth: tableBound.width + 'px' }); if (this.$viewport.clientHeight < this.$viewport.scrollHeight) { this.addClass('scroll-v'); } else { this.removeClass('scroll-v'); } var realNodes = this.$tr.childNodes; var topNodes = this.$topTr.childNodes; var widthStyle; var displayStyle; for (var i = 0; i < realNodes.length; ++i) { if (!realNodes[i].tagName) continue; widthStyle = TableVScroller_$(realNodes[i]).getComputedStyleValue('width'); displayStyle = realNodes[i].getComputedStyleValue('display'); if (!widthStyle) { widthStyle = realNodes[i].getBoundingClientRect().width; if (!widthStyle) { displayStyle = 'none'; } widthStyle += 'px'; } // console.trace(getAncestorElementOf(realNodes[i]), widthStyle, displayStyle) TableVScroller_$(topNodes[i]).attr('style', realNodes[i].attr('style')).addStyle('width', widthStyle).addStyle('display', displayStyle); } this.$topTable.removeStyle('display'); }; TableVScroller.prototype.updateContent = function () { this.swappedContentPairs.forEach((originElt, copyElt) => { this.swappedContentPairs.push([originElt, copyElt]) }); this.swappedContentPairs = []; var elt = this.$table; this.$thead = TableVScroller_$('thead', elt); this.$tr = TableVScroller_$('tr', this.$thead); this.$topThead = (0,Dom/* depthClone */.qE)(this.$thead, (originElt, copyElt) => { if (originElt.tagName === 'TH') { (0,utils.swapChildrenInElt)(originElt, copyElt); this.swappedContentPairs.push([originElt, copyElt]) } }); this.$topTr = TableVScroller_$('tr', this.$topThead); this.$topTable.clearChild().addChild(this.$topThead).addStyle('display', 'none'); }; TableVScroller.prototype.update = function () { if (!this.$table) return; this.updateContent(); this.updateStyle(); this.updateSize(); }; ACore/* default.install */.Z.install(TableVScroller); /* harmony default export */ const js_TableVScroller = (TableVScroller); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextArea2.js var TextArea2 = __webpack_require__(5789); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/textclipboard.css var textclipboard = __webpack_require__(2568); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TextClipboard.js var TextClipboard_ = ACore/* default._ */.Z._; var TextClipboard_$ = ACore/* default.$ */.Z.$; function TextClipboard() { this.$textarea = TextClipboard_('<textarea class="absol-text-clipboard" wrap="off" autocorrect="off"' + ' autocapitalize="off" spellcheck="false"></textarea>').addTo(this); } TextClipboard.tag = 'TextClipboard'.toLowerCase(); TextClipboard.render = function () { return TextClipboard_({ style: { positon: 'fixed', opacity: 0, width: '1px', height: '1px', top: 0, left: 0 } }); }; TextClipboard.prototype.copy = function (text) { this.$textarea.value = text; this.$textarea.select(); document.execCommand('copy'); }; TextClipboard.prototype.paste = function () { this.$textarea.select(); document.execCommand('paste'); }; ACore/* default.install */.Z.install(TextClipboard); /* harmony default export */ const js_TextClipboard = (TextClipboard); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/timeinput.css var timeinput = __webpack_require__(9392); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TimeInput.js var TimeInput_STATE_NEW = 1; var TimeInput_STATE_EDITED = 2; var TimeInput_STATE_NONE = 0; var TimeInput_ = ACore/* default._ */.Z._; var TimeInput_$ = ACore/* default.$ */.Z.$; /*** * @extends {AElement} * @constructor */ function TimeInput() { this._editingData = {}; this._isOpenPicker = false; this._lastEmitValue = null; this._min = 0; this._hour = null; this._minute = null; this._format = 'HH:mm'; this.$clockBtn = TimeInput_$('.as-time-input-icon-btn', this) .on('click', this.eventHandler.clickClockBtn); this.$text = TimeInput_$('input', this) .on('mousedown', this.eventHandler.mouseDownInput) .on('mouseup', this.eventHandler.mouseUpInput) .on('dblclick', this.eventHandler.dblclickInput) .on('keydown', this.eventHandler.keydown) .on('blur', this.eventHandler.inputBlur) .on('contextmenu', function (event) { event.preventDefault(); }); this.$clearBtn = TimeInput_$('button.as-time-input-clear-btn', this) .on('click', this.clear.bind(this)); this.$domSignal = TimeInput_('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); this.domSignal.on('request_auto_select', this._autoSelect.bind(this)); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'dayOffset', 'value'); this.dayOffset = null; this.hour = null; this.minute = null; this.disabled = false; this.notNull = true; /*** * @memberOf TimeInput# * @name min * @type {number} */ /*** * @memberOf TimeInput# * @name s24 * @type {boolean} * @readonly */ } TimeInput.tag = 'timeinput'; TimeInput.render = function () { return TimeInput_({ class: 'ac-time-input', extendEvent: ['change'], child: [ { tag: 'input', class: 'as-time-input-text', attr: { type: 'text' } }, { tag: 'button', class: 'as-time-input-clear-btn', child: 'span.mdi.mdi-close-circle' }, { tag: 'button', class: 'as-time-input-icon-btn', child: 'span.mdi.mdi-clock-outline' } ] }); }; TimeInput.prototype._autoSelect = js_DateTimeInput.prototype._autoSelect; TimeInput.prototype.tokenMap = { h: 'h', H: 'H', HH: 'H', hh: 'h', m: 'm', mm: 'm', a: 'a' }; TimeInput.prototype.tokenRegex = js_DateTimeInput.prototype.tokenRegex; TimeInput.prototype._tokenAt = js_DateTimeInput.prototype._tokenAt; TimeInput.prototype._editNextToken = js_DateTimeInput.prototype._editNextToken; TimeInput.prototype._editPrevToken = js_DateTimeInput.prototype._editPrevToken; TimeInput.prototype._makeTokenDict = js_DateTimeInput.prototype._makeTokenDict; TimeInput.prototype._makeValueDict = function (hour, minute) { var res = {}; if (typeof hour == 'number' && hour >= 0 && hour < 24) { res.h = { value: 1 + (hour - 1) % 12 }; res.H = { value: hour }; res.a = { value: hour >= 12 ? 'PM' : 'AM' }; } else { res.h = { value: NaN }; res.H = { value: NaN }; res.a = { value: 'a' }; } if (typeof minute === "number" && minute >= 0 && minute < 60) { res.m = { value: minute }; } else { res.m = { value: NaN }; } return res; }; TimeInput.prototype._applyValue = function (hour, minute) { this._hour = hour; this._minute = minute; this.$text.value = this._applyTokenDict(this._format, this._makeValueDict(hour, minute)); this._updateNullClass(); }; TimeInput.prototype._updateNullClass = function () { if (this._hour == null && this._minute == null) { this.addClass('as-value-null'); } else { this.removeClass('as-value-null'); } }; TimeInput.prototype._applyTokenDict = function (format, dict) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var tokenMap = this.tokenMap; return format.replace(rgx, function (full, g1, g2, sourceText) { if (g1 && g1 === 'a') { return dict[g1].value; } else if (g1 && tokenMap[g1]) { var ident = tokenMap[g1]; if (dict[ident] && !isNaN(dict[ident].value)) { return (0,utils.zeroPadding)(dict[ident].value, g1.length); } else { return full; } } else return full; }); }; TimeInput.prototype._correctingInput = function () { var tkDict = this._makeTokenDict(this.$text.value); // TODO: check min, max, }; TimeInput.prototype._correctingCurrentToken = function () { var token = this._tokenAt(this.$text.selectionStart); if (!token) return; var value; if (token.ident === 'a') { if (token.text !== 'a' && token.text !== 'AM' && token.text !== 'PM') { token.replace('a', false); } } else { value = parseInt(token.text); var rqMin = { h: 1, hh: 1, m: 0, mm: 0, H: 0, HH: 0 }[token.ident]; var rqMax = { H: 23, HH: 23, h: 12, hh: 12, m: 59, mm: 59 }[token.ident]; if (rqMin !== undefined) { if (!isNaN(value)) { if ((value < rqMin || value > rqMin)) { value = Math.max(rqMin, Math.min(rqMax, value)); token.replace((0,utils.zeroPadding)(value, token.ident.length), false); this._editingData[this.tokenMap[token.ident]] = value; } } else if (token.text !== token.ident) { token.replace(token.ident, false); } } } }; TimeInput.prototype._loadValueFromInput = function () { var tkDick = this._makeTokenDict(this.$text.value); var hour = NaN; var minute = NaN; if (tkDick.H) { hour = Math.min(23, Math.max(0, tkDick.H.value)); } else if (tkDick.h) { hour = Math.min(12, Math.max(1, tkDick.h.value)); if (tkDick.a && tkDick.a.value === 'PM') { hour += 12; } } if (tkDick.m) { minute = Math.min(59, Math.max(0, tkDick.m.value)); } this._hour = isNaN(hour) ? null : hour; this._minute = isNaN(minute) ? null : minute; this._updateNullClass(); }; TimeInput.prototype.clear = function (event) { this._applyValue(null, null); this._notifyIfChange(event); } TimeInput.prototype._notifyIfChange = function (event) { if (this._lastEmitValue === this.dayOffset) return; this.emit('change', { type: 'change', target: this, dayOffset: this.dayOffset, hour: this.hour, minute: this.minute, originEvent: event }, this); this._lastEmitValue = this.dayOffset; }; TimeInput.property = {}; TimeInput.property.hour = { set: function (value) { if (typeof value == "number") { value = (value % 24) || 0; } else { value = null; } this._applyValue(value, this._minute); this._lastEmitValue = this.dayOffset; }, get: function () { return this._hour; } }; TimeInput.property.minute = { set: function (value) { if (typeof value == "number") { value = (value % 60) || 0; } else { value = null; } this._applyValue(this._hour, value); this._lastEmitValue = this.dayOffset; }, get: function () { return this._minute; } }; TimeInput.property.value = { set: function (value) { if (typeof value == "number" || (value && value.getTime)) { value = value || 0; if (value.getTime) value = value.getTime() - (0,datetime.beginOfDay)(value).getTime(); else { value = value % datetime.MILLIS_PER_DAY; } this.hour = Math.floor(value / datetime.MILLIS_PER_HOUR); this.minute = Math.floor((value % datetime.MILLIS_PER_HOUR) / datetime.MILLIS_PER_MINUTE); } else { this.hour = null; this.minute = null; } }, get: function () { if (this._hour === null || this._minute === null) return null; return this._hour * datetime.MILLIS_PER_HOUR + this._minute * datetime.MILLIS_PER_MINUTE; } } TimeInput.property.disabled = { set: function (value) { value = !!value; this._disabled = value; if (value) this.addClass('as-disabled'); else this.removeClass('as-disabled'); this.$text.disabled = value; }, get: function () { return this._disabled; } }; TimeInput.property.format = { enumerable: true, configurable: true, set: function (value) { if (typeof value !== "string") value = "HH:mm"; value = value || 'HH:mm'; this._format = value; this.dayOffset = this['dayOffset']; }, get: function () { return this._format; } }; TimeInput.property.s24 = { get: function () { var t = this.format.match(new RegExp(this.tokenRegex.source, 'g')); return !t || t.indexOf('a') < 0; } }; TimeInput.property.notNull = { set: function (value) { if (value) { if (this.dayOffset === null) { this.dayOffset = 0; } this.addClass('as-must-not-null'); } else { this.removeClass('as-must-not-null'); } }, get: function () { return this.hasClass('as-must-not-null'); } }; TimeInput.property.readOnly = { set: function (value) { value = !!value; if (value) this.addClass('as-read-only'); else this.removeClass('as-read-only'); }, get: function () { return this.hasClass('as-read-only'); } }; TimeInput.property.min = { set: function (value) { if (!(0,utils.isRealNumber)(value)) value = 0; value = Math.floor(value); value = Math.max(0, Math.min(datetime.MILLIS_PER_DAY, value)); this._min = value; }, get: function () { return this._min; } }; TimeInput.eventHandler = {}; TimeInput.eventHandler.clickClockBtn = function () { this._attachPicker(this); }; TimeInput.eventHandler.mouseUpInput = js_DateTimeInput.eventHandler.mouseUpInput; TimeInput.eventHandler.mouseDownInput = js_DateTimeInput.eventHandler.mouseDownInput; TimeInput.eventHandler.dblclickInput = js_DateTimeInput.eventHandler.dblclickInput; TimeInput.eventHandler.inputBlur = js_DateTimeInput.eventHandler.inputBlur; TimeInput.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$picker, event) && !(0,EventEmitter/* hitElement */.EY)(this.share.$closeBtn, event)) return; this._releasePicker(); }; TimeInput.eventHandler.pickerChange = function (event) { this._applyValue(event.hour, event.minute); this._notifyIfChange(event); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }; /*** * * @param {KeyboardEvent} event */ TimeInput.eventHandler.keydown = function (event) { var token = this._tokenAt(this.$text.selectionStart); var endToken = this._tokenAt(this.$text.selectionEnd); if (!token) { if (event.key === 'Enter') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } return; } var newTokenText; var value; if (event.key.startsWith('Arrow')) { event.preventDefault(); switch (event.key) { case 'ArrowLeft': this._editPrevToken(); break; case 'ArrowRight': this._editNextToken(); break; case 'ArrowUp': case 'ArrowDown': switch (token.ident) { case "H": case "HH": value = parseInt(token.text); if (isNaN(value)) { this._editingData.H = event.key === 'ArrowUp' ? 0 : 23; } else { this._editingData.H = (value + (event.key === 'ArrowUp' ? 1 : 23)) % 24; } newTokenText = (0,utils.zeroPadding)(this._editingData.H, token.ident.length); token.replace(newTokenText, true); break; case "hh": case 'h': value = parseInt(token.text); if (isNaN(value)) { this._editingData.h = event.key === 'ArrowUp' ? 1 : 12; } else { this._editingData.h = 1 + (value + (event.key === 'ArrowUp' ? 0 : 10)) % 12; } newTokenText = this._editingData.h + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case "mm": case 'm': value = parseInt(token.text); if (isNaN(value)) { this._editingData.m = event.key === 'ArrowUp' ? 0 : 59; } else { this._editingData.m = (value + (event.key === 'ArrowUp' ? 1 : 59)) % 60; } newTokenText = this._editingData.m + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'a': value = token.text; this._editingData.a = value === 'PM' ? "AM" : "PM"; newTokenText = this._editingData.a; token.replace(newTokenText, true); break; } break; } } else if (event.key === "Delete" || event.key === 'Backspace') { event.preventDefault(); if (endToken.idx !== token.idx) { if (this.notNull) { this.$text.value = (0,datetime.formatDateTime)((0,datetime.beginOfDay)(new Date()), this.format); } else { this.$text.value = this._format; } this.$text.select(); } else { if (this.notNull) { token.replace(token.ident === 'a' ? 'AM' : (0,utils.zeroPadding)((token.ident === 'hh' || token.ident === 'h') ? 12 : 0, token.ident.length), true); } else { token.replace(token.ident, true); } if (event.key === "Delete") this._editNextToken(); else this._editPrevToken(); } } else if (event.key === "Enter" || event.key === 'Tab') { this._correctingInput(); this._loadValueFromInput(); this._notifyIfChange(event); } else if (event.ctrlKey) { switch (event.key) { case 'a': case 'A': break; case 'c': case 'C': break; case 'x': case 'X': this.domSignal.once('clear_value', function () { this.$text.value = this._format; this.$text.select(); }.bind(this)); this.domSignal.emit('clear_value'); break; default: event.preventDefault(); } } else if (event.key.match(/^[0-9]$/g)) { event.preventDefault(); var dVal = parseInt(event.key); if (this._editingData.state === TimeInput_STATE_NEW) { switch (token.ident) { case 'm': case 'mm': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = TimeInput_STATE_EDITED; if (dVal > 5) { this._editNextToken(); } break; case 'h': case 'hh': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = TimeInput_STATE_EDITED; if (dVal > 1) { this._editNextToken(); } break; case 'H': case 'HH': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editingData.state = TimeInput_STATE_EDITED; if (dVal > 2) { this._editNextToken(); } break; } } else { switch (token.ident) { case 'm': case 'mm': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(59, dVal)); this._editingData.m = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'h': case 'hh': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(12, dVal)); this._editingData.h = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; case 'H': case 'HH': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(23, dVal)); this._editingData.H = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this._editNextToken(); break; } } } else if (event.key.match(/^[aApPSCsc]$/) && token.ident === 'a') { event.preventDefault(); if (event.key.match(/^[aAsS]$/)) { token.replace('AM', true); this._editingData.a = "AM"; } else { token.replace('PM', true); this._editingData.a = "PM"; } this._editNextToken(); } else { event.preventDefault(); } }; TimeInput.prototype.share = { $picker: null, $holdingInput: null, $follower: null, $closeBtn: null }; TimeInput.prototype._preparePicker = function () { if (this.share.$picker) return; this.share.$picker = TimeInput_({ tag: js_ChromeTimePicker.tag, class: ['as-time-input-picker'] }); this.share.$follower = TimeInput_({ tag: 'follower', class: ['as-time-input-follower', 'as-dropdown-box-common-style'], child: [ this.share.$picker, { class: 'as-dropdown-box-footer', child: [ { class: 'as-dropdown-box-footer-right', child: ['<a data-ml-key="txt_close" class="as-select-list-box-close-btn"></a>'] } ] }] }); }; TimeInput.prototype._attachPicker = function () { this._preparePicker(); if (this.share.$holdingInput) this.share.$holdingInput._releasePicker(); this.share.$holdingInput = this; this.share.$follower.addTo(document.body); this.share.$follower.followTarget = this; this.share.$follower.sponsorElement = this; this.share.$follower.addStyle('visibility', 'hidden'); this.share.$picker.hour = this.hour || 0; this.share.$picker.minute = this.minute || 0; this.share.$picker.s24 = this.s24; this.share.$picker.min = this.min; this.share.$picker.domSignal.emit('request_scroll_into_selected') this.$clockBtn.off('click', this.eventHandler.clickClockBtn); this.share.$picker.on('change', this.eventHandler.pickerChange); setTimeout(function () { document.addEventListener('click', this.eventHandler.clickOut); this.share.$follower.removeStyle('visibility'); }.bind(this), 5); }; TimeInput.prototype._releasePicker = function () { if (this.share.$holdingInput !== this) return; // this.share.$calendar.off('pick', this.eventHandler.calendarPick); this.share.$follower.remove(); document.removeEventListener('click', this.eventHandler.clickOut); this.share.$picker.off('change', this.eventHandler.pickerChange); setTimeout(function () { this.$clockBtn.on('click', this.eventHandler.clickClockBtn); }.bind(this), 5) this.share.$holdingInput = null; }; ACore/* default.install */.Z.install(TimeInput); /* harmony default export */ const js_TimeInput = (TimeInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/timepicker.css var timepicker = __webpack_require__(9099); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TimePicker.js //todo: add this to absol var isTouchDevice = BrowserDetector/* default.hasTouch */.Z.hasTouch && !BrowserDetector/* default.os.type.match */.Z.os.type.match(/windows|X11|Ubuntu|Linux/); //todo: re select text after click var TimePicker_ = ACore/* default._ */.Z._; var TimePicker_$ = ACore/* default.$ */.Z.$; var TimePicker_$g = Svg/* default.ShareInstance.$ */.ZP.ShareInstance.$; var TimePicker_g = Svg/* default.ShareInstance._ */.ZP.ShareInstance._; function TimePicker() { this._hour = 0; this._minute = 0; this._lastDayOffset = 0; this._state = 'none'; this._mode = 'CLOCK'; this._latBound = { width: 0, height: 0 }; var thisPicker = this; if (isTouchDevice) this.addClass('ac-time-picker-touch'); this.$attachook = TimePicker_('attachhook').addTo(this).on('error', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.requestUpdateSize(); thisPicker.addStyle('font-size', thisPicker.getComputedStyleValue('font-size')); }); this.$attachook.requestUpdateSize = this.updateSize.bind(this); /*** * * @type {NumberSpanInput} */ this.$hour = TimePicker_$('.ac-time-picker-hour', this) .on({ focus: this.eventHandler.focusHour, keydown: this.eventHandler.keydownHour, blur: this.eventHandler.blurHour }); /*** * * @type {NumberSpanInput} */ this.$minute = TimePicker_$('.ac-time-picker-minute', this) .on({ keydown: this.eventHandler.keydownMinute, focus: this.eventHandler.focusMinute, blur: this.eventHandler.blurMinute, }); this.$hourInput = TimePicker_$('.ac-time-picker-hour-input', this) .on({ click: this.eventHandler.clickHourInput, keydown: this.eventHandler.keydownHourInput, blur: this.eventHandler.blurHourInput }); this.$minuteInput = TimePicker_$('.ac-time-picker-minute-input', this) .on({ click: this.eventHandler.clickMinuteInput, keydown: this.eventHandler.keydownMinuteInput, blur: this.eventHandler.blurMinuteInput }); //only support if is none touch device if (isTouchDevice) { this.$hour.readOnly = true; this.$hour.on('click', this._editHourState.bind(this)); this.$minute.readOnly = true; this.$minute.on('click', this._editMinuteState.bind(this)); } this.$clock = TimePicker_$g('.ac-time-picker-clock', this) .on(isTouchDevice ? 'touchstart' : 'mousedown', this.eventHandler.mousedownClock ); this._clockWidth = 400; this._clockHeight = 400; this._clockRadius = 150; this._clockRadiusInner = 100; this.$clockContent = TimePicker_$g('.ac-time-picker-clock-content', this); this.$clockHourCtn = TimePicker_$g('.ac-time-picker-clock-hour-ctn', this); this.$clockMinuteCtn = TimePicker_$g('.ac-time-picker-clock-minute-ctn', this); this.$hourNumbers = Array(24).fill(0).map(function (u, i) { var h = i; if (h == 0) h = 12; else if (h == 12) h = '00'; return TimePicker_g({ tag: 'text', attr: { 'text-anchor': 'middle' }, class: 'ac-time-picker-clock-hour-' + (i < 12 ? 'am' : 'pm'), child: { text: h + '' } }).addTo(thisPicker.$clockHourCtn); }); this.$minuteNumbers = Array(12).fill(0).map(function (u, i) { return TimePicker_g({ tag: 'text', attr: { 'text-anchor': 'middle' }, class: 'ac-time-picker-clock-minute', child: { text: i * 5 + '' } }).addTo(thisPicker.$clockMinuteCtn); }); this.$selectCtn = TimePicker_$g('.ac-time-picker-clock-select-ctn', this); this.$clockCenter = TimePicker_g({ tag: 'circle', class: 'ac-time-picker-clock-center', attr: { cx: "0", cy: '0' } }).addTo(this.$selectCtn); this.$clockSelectLine = TimePicker_g({ tag: 'path', class: 'ac-time-picker-clock-select-line' }).addTo(this.$selectCtn); this.$clockSelectCicle = TimePicker_g({ tag: 'circle', class: 'ac-time-picker-clock-select-circle', attr: { cx: 0, cy: 0 } }).addTo(this.$selectCtn); this.$clockSelectCenter = TimePicker_g({ tag: 'circle', class: 'ac-time-picker-clock-select-center' }).addTo(this.$selectCtn); this.$finishBtn = TimePicker_$('.ac-time-picker-finish-btn', this) .on('click', this.finishSelect.bind(this)); this.$cancelBtn = TimePicker_$('.ac-time-picker-cancel-btn', this) .on('click', this.cancelSelect.bind(this)); this.$keyboardBtn = TimePicker_$('.ac-time-picker-keyboard-btn', this) .on('click', this.timeMode.bind(this)); this.$clockBtn = TimePicker_$('.ac-time-picker-clock-btn', this) .on('click', this.clockMode.bind(this)); }; TimePicker.prototype.updateSize = function () { // var this._fontSize = this.getFontSize(); var cBound = this.$clock.getBoundingClientRect(); this._clockWidth = cBound.width; this._clockHeight = cBound.height; this.$clock.attr({ width: this._clockWidth, height: this._clockHeight, viewBox: '0 0 ' + this._clockWidth + ' ' + this._clockHeight }); this.$clockContent.attr('transform', 'translate(' + (this._clockWidth / 2) + ',' + (this._clockHeight / 2) + ')'); var clockRadius = this._clockWidth / 2 - this._fontSize; var clockRadiusInner = clockRadius - this._fontSize * 1.5; this._clockRadius = clockRadius; this._clockRadiusInner = clockRadiusInner; this.$clockCenter.attr('r', this._fontSize / 5); this.$clockSelectCicle.attr({ r: this._fontSize * 0.7, cx: clockRadius }); this.$clockSelectCenter.attr({ r: this._fontSize / 10, cx: clockRadius }); this.$hourNumbers.forEach(function (elt, i) { var angle = Math.PI * (i - 3) / 6; var r = i < 12 ? clockRadius : clockRadiusInner; var box = elt.getBBox(); var x = r * Math.cos(angle); var y = r * Math.sin(angle) + box.height / 2; elt.attr({ x: x, y: y }); }); this.$minuteNumbers.forEach(function (elt, i) { var angle = Math.PI * (i - 3) / 6; var box = elt.getBBox(); var x = clockRadius * Math.cos(angle); var y = clockRadius * Math.sin(angle) + box.height / 3; elt.attr({ x: x, y: y }); }); this.updateSelectPosition(); this.notifySizeChange(); }; TimePicker.prototype.updateSelectPosition = function () { var angle, radius; if (this._state == "EDIT_MINUTE") { angle = Math.PI * (this._minute - 15) / 30; radius = this._clockRadius } else if (this._state == "EDIT_HOUR") { angle = Math.PI * (this._hour - 3) / 6; if (this._hour > 0 && this._hour <= 12) { radius = this._clockRadius; } else { radius = this._clockRadiusInner; } } else { return; } this._drawSelect(radius, angle); }; TimePicker.prototype.editHour = function () { this.clockMode(); if (this.$hour.readOnly) { this._editHourState(); } else { this.$hour.focus(); } } TimePicker.prototype._drawSelect = function (radius, angle) { var x = radius * Math.cos(angle); var y = radius * Math.sin(angle); this.$clockSelectCicle.attr({ cx: x, cy: y }); this.$clockSelectCenter.attr({ cx: x, cy: y }); this.$clockSelectLine.attr('d', 'M0,0L' + x + ',' + y); }; TimePicker.prototype.notifyChange = function (force) { if (this._lastDayOffset != this.dayOffset || force) { this.emit('change', { target: this, hour: this.hour, minute: this.minute, dayOffset: this.dayOffset, name: 'change' }, this); this._lastDayOffset = this.dayOffset; } }; TimePicker.prototype.notifySizeChange = function () { var bound = this.getBoundingClientRect(); if (this._latBound.width != bound.width || this._latBound.height != bound.height) { this._latBound.width = bound.width; this._latBound.height = bound.height; this.emit('sizechange', { name: 'sizechange', bound: bound, target: this }, this); } }; TimePicker.tag = 'TimePicker'; TimePicker.render = function () { return TimePicker_({ extendEvent: ['change', 'finish', 'cancel', 'sizechange'], class: ['ac-time-picker', 'ac-time-picker-clock-mode'],//clock mode is default child: [ { class: 'ac-time-picker-set-clock', child: [{ class: 'ac-time-picker-set-clock-header', child: [ { tag: 'numberspaninput', class: 'ac-time-picker-hour', props: { value: 0, zeroInt: 2 } }, { tag: 'span', text: ':' }, { tag: 'numberspaninput', class: 'ac-time-picker-minute', props: { value: 0, zeroInt: 2 } } ] }, TimePicker_g( { tag: 'svg', class: 'ac-time-picker-clock', child: [ { class: 'ac-time-picker-clock-content', child: ['.ac-time-picker-clock-select-ctn', '.ac-time-picker-clock-hour-ctn', '.ac-time-picker-clock-minute-ctn'] } ] } )] }, { class: 'ac-time-picker-set-time', child: [ { class: 'ac-time-picker-set-time-header', child: { text: 'Set time' } }, { class: 'ac-time-picker-set-time-label', child: { text: 'Type in time' } }, { class: 'ac-time-picker-set-time-input-group', child: [ { class: 'ac-time-picker-set-time-input-hm', child: [ { tag: 'input', class: 'ac-time-picker-hour-input', attr: { type: 'number', placeHolder: '00', tabindex: '2', } }, { tag: 'span', child: { text: ':' } }, { tag: 'input', class: 'ac-time-picker-minute-input', attr: { type: 'number', placeHolder: '00', tabindex: '3' } } ] }, { class: 'ac-time-picker-set-time-input-label-hm', child: [ { tag: 'span', child: { text: 'hour' } }, { tag: 'span', style: { visibility: 'hidden' }, child: { text: ':' } }, { tag: 'span', child: { text: 'minute' } } ] } ] } ] }, { class: 'ac-time-picker-footer', child: [ { tag: 'button', class: 'ac-time-picker-keyboard-btn', child: 'span.mdi.mdi-keyboard-outline' }, { tag: 'button', class: 'ac-time-picker-clock-btn', child: 'span.mdi.mdi-clock-outline' }, { class: 'ac-time-picker-footer-right', child: [ { tag: 'button', class: 'ac-time-picker-cancel-btn', attr: { tabindex: '4' }, child: { text: 'CANCEL' } }, { tag: 'button', attr: { tabindex: '4' }, class: 'ac-time-picker-finish-btn', child: { text: 'OK' } } ] }] } ] }); }; TimePicker.prototype.clockMode = function () { if (this._mode == "CLOCK") return; this._mode = 'CLOCK'; this.removeClass('ac-time-picker-time-mode') .addClass('ac-time-picker-clock-mode'); this.$hour.value = this._hour < 10 ? '0' + this._hour : this._hour; this.$minute.value = this._minute < 10 ? '0' + this._minute : this._minute; this._editHourState(); this.updateSize(); this._showSelectHour(this._hour); }; TimePicker.prototype.timeMode = function () { if (this._mode == "TIME") return; this._mode = 'TIME'; this.addClass('ac-time-picker-time-mode') .removeClass('ac-time-picker-clock-mode'); this.$hourInput.value = this._hour < 10 ? '0' + this._hour : this._hour; this.$minuteInput.value = this._minute < 10 ? '0' + this._minute : this._minute; this.editHourInput(); this.updateSize(); }; TimePicker.prototype._editHourState = function () { this._state = "EDIT_HOUR"; this._preHour = this._hour; this.removeClass('ac-time-picker-edit-minute') .addClass('ac-time-picker-edit-hour') .removeClass('ac-time-picker-edit-hour-input') .removeClass('ac-time-picker-edit-minute-input'); this.updateSize(); }; TimePicker.prototype._editMinuteState = function () { this._state = "EDIT_MINUTE"; this._preMinute = this._minute; this.addClass('ac-time-picker-edit-minute') .removeClass('ac-time-picker-edit-hour') .removeClass('ac-time-picker-edit-hour-input') .removeClass('ac-time-picker-edit-minute-input'); this.updateSize(); }; TimePicker.prototype.editHourInput = function () { var thisPicker = this; this._state = "EDIT_HOUR_INPUT"; this._preHour = this._hour; this.removeClass('ac-time-picker-edit-minute') .removeClass('ac-time-picker-edit-hour') .addClass('ac-time-picker-edit-hour-input') .removeClass('ac-time-picker-edit-minute-input'); this.updateSize(); setTimeout(function () { thisPicker.$hourInput.focus(); thisPicker.$hourInput.select(); }, 10); }; TimePicker.prototype.editMinuteInput = function () { var thisPicker = this; this._state = "EDIT_MINUTE_INPUT"; this._preMinute = this._minute; this.removeClass('ac-time-picker-edit-minute') .removeClass('ac-time-picker-edit-hour') .removeClass('ac-time-picker-edit-hour-input') .addClass('ac-time-picker-edit-minute-input'); this.updateSize(); setTimeout(function () { thisPicker.$minuteInput.focus(); thisPicker.$minuteInput.select(); }, 1) }; TimePicker.prototype.finishSelect = function () { this.emit('finish', { target: this, hour: this.hour, minute: this.minute, dayOffset: this.dayOffset, name: 'finish' }, this); }; TimePicker.prototype.cancelSelect = function () { this.emit('cancel', { target: this, name: 'cancel' }, this); }; TimePicker.eventHandler = {}; TimePicker.eventHandler.focusHour = function () { this._editHourState(); this.$hour.selectAll(); }; TimePicker.eventHandler.blurHour = function () { var newText = this.$hour.value; var hour = parseFloat(newText) || 0; if (hour < 0 || hour >= 24) hour = this._preHour; this.$hour.value = hour < 10 ? '0' + hour : hour; this._hour = hour; this._showSelectHour(hour); this.notifyChange(); }; TimePicker.eventHandler.focusMinute = function () { this._editMinuteState(); this.$minute.selectAll(); }; TimePicker.eventHandler.blurMinute = function () { var newText = this.$minute.innerHTML; var minute = parseFloat(newText) || 0; if (minute < 0 || minute >= 60) minute = this._preMinute; this.$minute.value = minute < 10 ? '0' + minute : minute; this._minute = minute; this._showSelectByMinuteText(); this.notifyChange(); }; TimePicker.eventHandler.clickHourInput = function () { if (this._state != 'EDIT_HOUR') this.editHourInput(); else { this.$hourInput.focus(); this.$hourInput.select(); } }; TimePicker.eventHandler.clickMinuteInput = function () { if (this._state != 'EDIT_MINUTE_INPUT') this.editMinuteInput(); else { this.$minuteInput.focus(); this.$minuteInput.select(); } }; TimePicker.eventHandler.blurHourInput = function () { var hour = parseFloat(this.$hourInput.value) || 0; if (hour < 0 || hour >= 24) hour = this._preHour; this.hour = hour; }; TimePicker.eventHandler.blurMinuteInput = function () { var minute = parseFloat(this.$minuteInput.value) || 0; if (minute < 0 || minute >= 60) minute = this._preMinute; this.minute = minute; }; TimePicker.property = {}; TimePicker.property.hour = { set: function (value) { value = (value % 24) || 0; this._hour = value; var text = (value < 10 ? '0' : '') + value + ''; this.$hour.clearChild().addChild(TimePicker_({ text: text })); this.$hourInput.value = text; this.updateSelectPosition(); }, get: function () { return this._hour; } }; TimePicker.property.minute = { set: function (value) { value = (value % 60) || 0; this._minute = value; var text = (value < 10 ? '0' : '') + value + ''; this.$minute.value = text; this.$minuteInput.value = text; this.updateSelectPosition(); }, get: function () { return this._minute; } }; TimePicker.property.dayOffset = { set: function (value) { value = value || 0; if (value.getTime) value = value.getTime() - (0,datetime.beginOfDay)(value).getTime(); else { value = value % datetime.MILLIS_PER_DAY; } this.hour = Math.floor(value / datetime.MILLIS_PER_HOUR); this.minute = Math.floor((value % datetime.MILLIS_PER_HOUR) / datetime.MILLIS_PER_MINUTE); }, get: function () { return this._hour * datetime.MILLIS_PER_HOUR + this._minute * datetime.MILLIS_PER_MINUTE; } }; TimePicker.prototype._showSelectHour = function (hour) { var radius; var angle = Math.PI * (hour - 3) / 6; if ((hour < 24 && hour > 12) || hour == 0) { radius = this._clockRadiusInner; } else if (hour <= 12) { radius = this._clockRadius; } else { return; } this._drawSelect(radius, angle); }; TimePicker.prototype._showSelectByHourText = function () { var hour = parseFloat(this.$hour.innerHTML) || 0; if (hour < 0 || hour >= 24) return; this._showSelectHour(hour); }; TimePicker.prototype._showSelectMinute = function (minute) { var angle = Math.PI * (minute - 15) / 30; this._drawSelect(this._clockRadius, angle); } TimePicker.prototype._showSelectByMinuteText = function () { var minute = parseFloat(this.$minute.innerHTML) || 0; if (minute < 0 || minute >= 60) return; this._showSelectMinute(minute); }; /*** * * @param {KeyboardEvent} event */ TimePicker.eventHandler.keydownHour = function (event) { var thisPicker = this; if (event.key == 'Enter' || event.key == 'Tab') { event.preventDefault(); this.$hour.blur(); this._editMinuteState(); setTimeout(function () { thisPicker.$minute.focus(); thisPicker.$minute.selectAll(); }, 30); } else { setTimeout(function () { var newText = thisPicker.$hour.value; var hour = parseFloat(newText) || 0; if (hour < 0 || hour >= 24) hour = thisPicker._preHour; else { thisPicker._hour = hour; thisPicker._showSelectHour(hour); } }, 30); } }; TimePicker.eventHandler.keydownMinute = function (event) { var thisPicker = this; if (event.key == 'Enter') { this.$minute.blur(); event.preventDefault(); setTimeout(this.finishSelect.bind(this), 30); } else if (event.key == 'Tab') { this.$minute.selectNone(); this.$finishBtn.focus(); event.preventDefault(); } else { setTimeout(function () { var newText = thisPicker.$minute.value; var minute = parseFloat(newText) || 0; if (minute < 0 || minute >= 60) minute = thisPicker._preMinute; else { thisPicker._minute = minute; thisPicker._showSelectMinute(minute); } }, 30); } }; TimePicker.eventHandler.keydownHourInput = function (event) { var thisPicker = this; if ((isTouchDevice && event.key == "Unidentified") || (event.key && event.key.length == 1 && !event.ctrlKey && !event.altKey)) { if (event.key.match(/[0-9]/)) { setTimeout(this.notifyChange.bind(this), 2); } else { event.preventDefault(); } } else if (event.key == 'Enter') { event.preventDefault(); this.$hourInput.blur(); this.editMinuteInput(); } else if (!event.key && !event.key.toLowerCase().match(/arrow|back/)) { var cText = this.$hourInput.value; setTimeout(function () { var newText = thisPicker.$hourInput.value; if (cText != newText) { var hour = parseFloat(newText) || 0; if (hour < 0 || hour >= 24) hour = thisPicker._preHour; thisPicker.hour = hour; thisPicker.$hourInput.blur(); thisPicker.editMinuteInput(); thisPicker.notifyChange(); } }, 1); } }; TimePicker.eventHandler.keydownMinuteInput = function (event) { var thisPicker = this; if ((isTouchDevice && event.key == "Unidentified") || event.key.length == 1 && !event.ctrlKey && !event.altKey) { if ((isTouchDevice && event.key == "Unidentified") || event.key.match(/[0-9]/)) { setTimeout(this.notifyChange.bind(this), 2); } else { event.preventDefault(); } } else if (event.key == 'Enter') { this.$minute.blur(); this.eventHandler.blurMinuteInput(); event.preventDefault(); setTimeout(this.finishSelect.bind(this), 100); } else if (event.key == "Backspace") { } else if (event.key != 'Enter') { var cText = this.$minuteInput.value; setTimeout(function () { var newText = thisPicker.$minuteInput.value; if (cText != newText) { var minute = parseFloat(newText) || 0; if (minute < 0 || minute >= 60) minute = thisPicker._preMinute; thisPicker.minute = minute; thisPicker.$minuteInput.focus(); thisPicker.$minuteInput.select(); thisPicker.notifyChange(); } }, 1); } }; TimePicker.eventHandler.dragOnClock = function (event) { event = (event.changedTouches && event.changedTouches[0]) || event; var cBound = this.$clock.getBoundingClientRect(); var cx = (cBound.left + cBound.right) / 2; var cy = (cBound.top + cBound.bottom) / 2; var x = event.clientX - cx; var y = event.clientY - cy; var angle = Math.atan2(y, x); var radius = Math.sqrt(x * x + y * y); var index; if (this._state == "EDIT_HOUR") { angle += Math.PI * 2; index = Math.round(angle / (Math.PI / 6)); var hour = (index + (12 + 3)) % 12; if (radius < (this._clockRadiusInner + this._clockRadius) / 2) { if (hour != 0) hour += 12; } else { if (hour == 0) hour = 12; } this._hour = hour; this._showSelectHour(hour); this.$hour.value = hour < 10 ? '0' + hour : hour; this.$hour.selectEnd(); } else if (this._state == "EDIT_MINUTE") { radius = this._clockRadius; angle += Math.PI * 2; index = Math.round(angle / (Math.PI / 30)); angle = index * (Math.PI / 30); var minute = (index + (60 + 15)) % 60; this._minute = minute; this.$minute.value = minute < 10 ? '0' + minute : minute; this._showSelectMinute(minute); this.$minute.selectEnd(); this.notifyChange(); } else { return; } }; TimePicker.eventHandler.mousedownClock = function (event) { event.preventDefault(); this.eventHandler.dragOnClock(event); document.body.addEventListener(isTouchDevice ? 'touchmove' : 'mousemove', this.eventHandler.mousemoveClock); document.body.addEventListener(isTouchDevice ? 'touchend' : 'mouseup', this.eventHandler.mousefinishClock); if (!isTouchDevice) document.body.addEventListener('mouseleave', this.eventHandler.mousefinishClock); }; TimePicker.eventHandler.mousemoveClock = function (event) { event.preventDefault(); this.eventHandler.dragOnClock(event); }; TimePicker.eventHandler.mousefinishClock = function () { document.body.removeEventListener('mousemove', this.eventHandler.mousemoveClock); document.body.removeEventListener('mouseup', this.eventHandler.mousefinishClock); document.body.removeEventListener('mouseleave', this.eventHandler.mousefinishClock); if (this._state == 'EDIT_HOUR') { if (this.$minute.readOnly) { this._editMinuteState(); } else { this.$minute.focus(); } } else if (this._state == 'EDIT_MINUTE') { this.$minute.selectAll();// refocus } }; ACore/* default.install */.Z.install('timepicker', TimePicker); /* harmony default export */ const js_TimePicker = (TimePicker); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Tooltip.js var Tooltip = __webpack_require__(5194); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/treelist.css var treelist = __webpack_require__(7009); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TreeListItem.js var TreeListItem_ = ACore/* default._ */.Z._; var TreeListItem_$ = ACore/* default.$ */.Z.$; function TreeListItem() { var thisTI = this; this.$list = TreeListItem_$('treelist', this).on('press', function (event, sender) { thisTI.emit('press', event, this); }); this.$parent = TreeListItem_$('.absol-tree-list-item-parent', this).on('mousedown', this.eventHandler.clickParent); this.$text = TreeListItem_$('span.absol-tree-list-item-text', this); this.$desc = TreeListItem_$('span.absol-tree-list-item-desc', this); this.$descCtn = TreeListItem_$('.absol-tree-list-item-desc-container', this); this.$list.level = 1; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$list, 'items'); } TreeListItem.tag = 'TreeListItem'.toLowerCase(); TreeListItem.render = function () { return TreeListItem_({ extendEvent: ['press', 'clickparent'], class: 'absol-tree-list-item', child: [ { class: 'absol-tree-list-item-parent', child: ['span.absol-tree-list-item-text', { class: 'absol-tree-list-item-desc-container', child: 'span.absol-tree-list-item-desc' } ] }, 'treelist' ] }); }; TreeListItem.eventHandler = {}; TreeListItem.eventHandler.clickParent = function (event) { event.preventDefault(); var prevented = false; var self = this; this.emit('press', { target: self, preventDefault: function () { prevented = true; }, isPrevented: function () { return prevented; }, data: this.data }, this); if (!prevented) { var top = self.getTopLevelElt(); TreeListItem_$('treelistitem', top, function (e) { if (e != self) e.active = false; }) self.active = true; } }; TreeListItem.prototype.getTopLevelElt = function () { var current = this; while (current) { var parent = current.parentNode; if (!parent || (!parent.classList.contains('absol-tree-list') && !parent.classList.contains('absol-tree-list-item'))) break; current = current.parentNode; } return current; }; TreeListItem.property = { text: { set: function (value) { value = value + ''; this.$text.innerHTML = value; }, get: function () { return this.$text.innerHTML; } }, desc: { set: function (value) { value = value + ''; this.$desc.innerHTML = value; }, get: function () { return this.$desc.innerHTML } }, level: { set: function (value) { value = value || 0; if (value == this.level) return; this._level = value; this.$parent.addStyle('padding-left', this._level * 0.4 * 3 + 'em'); this.$list.level = value + 1; }, get: function () { return this._level || 0; } }, active: { set: function (value) { if (value) { this.addClass('active'); } else { this.removeClass('active'); } }, get: function () { return this.hasClass('active'); } }, data: { set: function (value) { this._data = value; }, get: function () { return this._data; } }, value: { get: function () { var data = this.data; if (typeof data == 'string') return data; if (typeof data.value == "undefined") { return data.text; } else { return data.value; } } } }; TreeListItem.property.extendClasses = { set: function (value) { var self = this; this.extendClasses.forEach(function (className) { self.$parent.removeClass(className); }); this._extendClass = []; if (!value) return; if (typeof value == 'string') { value = value.split(/\s+/).filter(function (c) { return c.length > 0 }); } if (value instanceof Array) { this._extendClass = value; this._extendClass.forEach(function (className) { self.$parent.addClass(className); }); } else { throw new Error('Invalid extendClasses'); } }, get: function () { return this._extendClass || []; } }; TreeListItem.property.extendStyle = { set: function (value) { this.$parent.removeStyle(this._extendStyle || {}); this._extendStyle = value || {}; this.$parent.addStyle(this.extendStyle); }, get: function () { return this._extendStyle || {}; } }; ACore/* default.install */.Z.install(TreeListItem); /* harmony default export */ const js_TreeListItem = (TreeListItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TreeList.js var TreeList_ = ACore/* default._ */.Z._; var TreeList_$ = ACore/* default.$ */.Z.$; function TreeList() { } TreeList.tag = 'treelist'; TreeList.render = function () { return TreeList_({ class: 'absol-tree-list', extendEvent: 'press' }); }; TreeList.prototype.realignDescription = function (extMarginLeft) { extMarginLeft = extMarginLeft || 0; var maxWidth = 0; var ctns = []; TreeList_$('.absol-tree-list-item-desc-container', this, function (elt) { ctns.push(elt); var bound = elt.getBoundingClientRect(); maxWidth = Math.max(maxWidth, bound.width); }); var fontSize = this.getFontSize(); var cntWidth = maxWidth / fontSize + 'em'; var extMarginRight = maxWidth / fontSize + extMarginLeft + 'em'; ctns.forEach(function (e) { e.addStyle('width', cntWidth); }); TreeList_$('span.absol-tree-list-item-text', this, function (elt) { elt.addStyle('margin-right', extMarginRight); }); return this; }; TreeList.prototype.clearItems = function () { this._items = []; this.clearChild(); }; TreeList.prototype.getAllItem = function () { return this._items || []; }; TreeList.prototype.getAllItemElement = function () { return Array.apply(null, this.childNodes); } TreeList.prototype.addItem = function (item) { var self = this; var props = { level: this.level, data: item }; if (typeof item == 'string') { props.text = item; } else { props.text = item.text; if (item.items) { props.items = item.items; } if (item.desc) { props.desc = item.desc; } if (item.extendClasses) { props.extendClasses = item.extendClasses; } if (item.extendStyle) { props.extendStyle = item.extendStyle; } } var elt = TreeList_({ tag: 'treelistitem', props: props, on: { press: function (event) { self.emit('press', event, this); } } }); this.addChild(elt); this._items.push(item); return this; }; TreeList.property = {}; TreeList.property.items = { set: function (value) { this.clearItems(); (value || []).forEach(this.addItem.bind(this)); }, get: function () { return this.getAllItem(); } }; TreeList.property.level = { set: function (value) { value = value || 0; if (this.level == value) return; this._level = value; this.getAllItemElement().forEach(function (e) { e.level = value; }); }, get: function () { return this._level || 0; } }; ACore/* default.install */.Z.install(TreeList); /* harmony default export */ const js_TreeList = (TreeList); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selecttreemenu.css var selecttreemenu = __webpack_require__(7665); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/list/treeListToList.js /*** * * @param {Array<SelectionItem>} items * @returns {Array<SelectionItem>} */ function treeListToList(items) { var arr = []; function visit(level, node) { Object.defineProperty(node, 'level', { configurable: true, writable: true, value: level }); arr.push(node); if (Array.isArray(node.items) && node.items.length > 0) node.items.forEach(visit.bind(null, level + 1)); } if (items && items.forEach) items.forEach(visit.bind(null, 0)); return arr; } ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTreeBox.js var SelectTreeBox_ = ACore/* default._ */.Z._; var SelectTreeBox_$ = ACore/* default.$ */.Z.$; var SelectTreeBox_$$ = ACore/* default.$$ */.Z.$$; /*** * @extends SelectListBox * @constructor */ function SelectTreeBox() { js_SelectListBox.call(this); } SelectTreeBox.tag = 'SelectTreeBox'.toLowerCase(); SelectTreeBox.render = function () { return js_SelectListBox.render().addClass('as-select-tree-box'); }; Object.assign(SelectTreeBox.prototype, js_SelectListBox.prototype); SelectTreeBox.property = Object.assign({}, js_SelectListBox.property); SelectTreeBox.eventHandler = Object.assign({}, js_SelectListBox.eventHandler); SelectTreeBox.prototype._itemsToNodeList = function (items) { return treeListToList(items); }; ACore/* default.install */.Z.install(SelectTreeBox); /* harmony default export */ const js_SelectTreeBox = (SelectTreeBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTreeMenu.js var SelectTreeMenu_ = ACore/* default._ */.Z._; var SelectTreeMenu_$ = ACore/* default.$ */.Z.$; /*** * @extends SelectMenu * @constructor */ function SelectTreeMenu() { this._items = []; this._value = null; this._lastValue = null; this.$holderItem = SelectTreeMenu_$('.absol-selectmenu-holder-item', this); this.$viewItem = SelectTreeMenu_$('.absol-selectmenu-holder-item selectlistitem', this); /*** * * @type {SelectTreeBox} */ this.$selectlistBox = SelectTreeMenu_({ tag: 'selecttreebox', props: { anchor: [1, 6, 2, 5] }, on: { preupdateposition: this.eventHandler.preUpdateListPosition } }); this.$selectlistBox.on('pressitem', this.eventHandler.selectListBoxPressItem); this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectlistBox, 'enableSearch'); this._lastValue = "NOTHING_VALUE"; this._isFocus = false; this.isFocus = false; this.on('mousedown', this.eventHandler.click, true); } SelectTreeMenu.tag = 'SelectTreeMenu'.toLowerCase(); SelectTreeMenu.render = function () { return SelectMenu2.render().addClass('as-select-tree-menu'); }; SelectTreeMenu.eventHandler = Object.assign({}, SelectMenu2.eventHandler); SelectTreeMenu.property = Object.assign({}, SelectMenu2.property); Object.assign(SelectTreeMenu.prototype, SelectMenu2.prototype); ACore/* default.install */.Z.install(SelectTreeMenu); /* harmony default export */ const js_SelectTreeMenu = (SelectTreeMenu); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/widthheightresizer.css var widthheightresizer = __webpack_require__(9360); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Draggable.js var Draggable = __webpack_require__(5611); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/WidthHeightSizer.js //can replace with other module var WidthHeightSizer_ = ACore/* default._ */.Z._; var WidthHeightSizer_$ = ACore/* default.$ */.Z.$; function WidthHeightResizer() { var res = WidthHeightSizer_({ extendEvent: 'sizechange', class: 'absol-width-height-resizer', child: ['.absol-width-height-resizer-content', '.absol-width-height-resizer-anchor-bot-right', '.absol-width-height-resizer-anchor-bot-left', '.absol-width-height-resizer-anchor-top-right', '.absol-width-height-resizer-anchor-top-left' ] }); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, WidthHeightResizer.eventHandler); res.$anchorBotRight = WidthHeightSizer_$('.absol-width-height-resizer-anchor-bot-right', res); res.$anchorTopRight = WidthHeightSizer_$('.absol-width-height-resizer-anchor-top-right', res); res.$anchorBotLeft = WidthHeightSizer_$('.absol-width-height-resizer-anchor-bot-left', res); res.$anchorTopLeft = WidthHeightSizer_$('.absol-width-height-resizer-anchor-top-left', res); res.$content = WidthHeightSizer_$('.absol-width-height-resizer-content', res); (0,Draggable/* default */.Z)(res.$anchorBotRight).on('drag', res.eventHandler.dragBotRight).on('predrag', res.eventHandler.preDrag); (0,Draggable/* default */.Z)(res.$anchorTopRight).on('drag', res.eventHandler.dragTopRight).on('predrag', res.eventHandler.preDrag); (0,Draggable/* default */.Z)(res.$anchorBotLeft).on('drag', res.eventHandler.dragBotLeft).on('predrag', res.eventHandler.preDrag); (0,Draggable/* default */.Z)(res.$anchorTopLeft).on('drag', res.eventHandler.dragTopLeft).on('predrag', res.eventHandler.preDrag); return res; } ['addChild', 'addChildBefore', 'addChildAfter', 'clearChild'].forEach(function (key) { WidthHeightResizer.prototype[key] = function () { return this.$content[key].apply(this.$content, arguments); } }); WidthHeightResizer.tag = 'WidthHeightResizer'.toLowerCase(); WidthHeightResizer.eventHandler = {}; WidthHeightResizer.eventHandler.preDrag = function (event) { this._whrWidth = parseFloat(this.getComputedStyleValue('width').replace('px', '')); this._whrHeight = parseFloat(this.getComputedStyleValue('height').replace('px', '')); }; WidthHeightResizer.eventHandler.dragBotRight = function (event) { var newEvent = { target: this, data: {} }; if (event.moveDX != 0) { this.addStyle('width', this._whrWidth + event.moveDX + 'px'); newEvent.data.changeWidth = true; } if (event.moveDY != 0) { this.addStyle('height', this._whrHeight + event.moveDY + 'px'); newEvent.data.changeHeight = true; } newEvent.data.height = this.getComputedStyleValue('height'); newEvent.data.width = this.getComputedStyleValue('width'); this.emit('sizechange', newEvent); }; WidthHeightResizer.eventHandler.dragTopRight = function (event) { var newEvent = { target: this, data: {} }; if (event.moveDX != 0) { this.addStyle('width', this._whrWidth + event.moveDX + 'px'); newEvent.data.changeWidth = true; } if (event.moveDY != 0) { this.addStyle('height', this._whrHeight - event.moveDY + 'px'); newEvent.data.changeHeight = true; } newEvent.data.height = this.getComputedStyleValue('height'); newEvent.data.width = this.getComputedStyleValue('width'); this.emit('sizechange', newEvent); }; WidthHeightResizer.eventHandler.dragBotLeft = function (event) { var newEvent = { target: this, data: {} }; if (event.moveDX != 0) { this.addStyle('width', this._whrWidth - event.moveDX + 'px'); newEvent.data.changeWidth = true; } if (event.moveDY != 0) { this.addStyle('height', this._whrHeight + event.moveDY + 'px'); newEvent.data.changeHeight = true; } newEvent.data.height = this.getComputedStyleValue('height'); newEvent.data.width = this.getComputedStyleValue('width'); this.emit('sizechange', newEvent); }; WidthHeightResizer.eventHandler.dragTopLeft = function (event) { var newEvent = { target: this, data: {} }; if (event.moveDX != 0) { this.addStyle('width', this._whrWidth - event.moveDX + 'px'); newEvent.data.changeWidth = true; } if (event.moveDY != 0) { this.addStyle('height', this._whrHeight - event.moveDY + 'px'); newEvent.data.changeHeight = true; } newEvent.data.height = this.getComputedStyleValue('height'); newEvent.data.width = this.getComputedStyleValue('width'); this.emit('sizechange', newEvent); }; ACore/* default.creator.widthheightresizer */.Z.creator.widthheightresizer = WidthHeightResizer; /* harmony default export */ const WidthHeightSizer = (WidthHeightResizer); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Modal.js var Modal = __webpack_require__(9826); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/trackbar.css var trackbar = __webpack_require__(5220); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TrackBar.js var TrackBar_ = ACore/* default._ */.Z._; var TrackBar_$ = ACore/* default.$ */.Z.$; /*** * @extends Hanger * @constructor */ function TrackBar() { this.$bar = TrackBar_$('.absol-trackbar', this); this.$button = TrackBar_$('.absol-trackbar-button', this); this.$line = TrackBar_$('.absol-trackbar-line', this); this.on('predrag', this.eventHandler.predrag) .on('drag', this.eventHandler.drag); this.leftValue = 0; this.rightValue = 1; this._dragValue = 0; } TrackBar.tag = 'trackbar'; TrackBar.render = function () { return TrackBar_({ tag: 'hanger', extendEvent: 'change', class: 'absol-trackbar', child: [{ class: 'absol-trackbar-line', child: '.absol-trackbar-button' }, 'attachhook'], }); }; TrackBar.prototype._updateValue = function () { var left = (0,Math_int.map)(this.value, this.leftValue, this.rightValue, 0, 100); this.$button.addStyle('left', left + '%'); } TrackBar.eventHandler = {}; TrackBar.eventHandler.predrag = function (event) { if (event.target === this || this.readOnly) { event.cancel(); } else { event.preventDefault(); var lineBound = this.$line.getBoundingClientRect(); var newValue = this.leftValue + (this.rightValue - this.leftValue) * (event.clientX - lineBound.left) / lineBound.width; newValue = Math.max(this.leftValue, Math.min(this.rightValue, newValue)); if (newValue !== this.value) { this.value = newValue; event.trackbarValue = this.value; this._dragValue = this.value; this.emit('change', event); } } }; TrackBar.eventHandler.drag = function (event) { var lineWidth = this.$line.getBoundingClientRect().width; var d = event.currentPoint.sub(event.startingPoint); var delta = d.x / lineWidth * (this.rightValue - this.leftValue); var newValue = Math.max(this.leftValue, Math.min(this.rightValue, this._dragValue + delta)); if (newValue != this.value) { this.value = newValue; event.trackbarValue = this.value; this.emit('change', event); } }; TrackBar.property = {}; TrackBar.property.value = { set: function (value) { value = parseFloat(value + ''); if (isNaN(value)) value = 0; this._value = value; this._updateValue(); }, get: function () { return Math.max(this.leftValue, Math.min(this.rightValue, this._value)); } }; TrackBar.property.leftValue = { set: function (value) { value = parseFloat(value + ''); if (isNaN(value)) value = 0; this._leftValue = value; this._updateValue(); }, get: function () { return this._leftValue || 0; } }; TrackBar.property.rightValue = { set: function (value) { value = parseFloat(value + ''); if (isNaN(value)) value = 1; this._rightValue = value; this._updateValue(); }, get: function () { return this._rightValue || 1; } }; TrackBar.property.disabled = { get: function () { return this.hasClass('as-disabled'); }, set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } } }; TrackBar.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; ACore/* default.install */.Z.install(TrackBar); /* harmony default export */ const js_TrackBar = (TrackBar); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/trackbarinput.css var trackbarinput = __webpack_require__(502); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TrackBarInput.js var TrackBarInput_ = ACore/* default._ */.Z._; var TrackBarInput_$ = ACore/* default.$ */.Z.$; /*** * * @extends {AElement} * @constructor */ function TrackBarInput() { var thisTI = this; this.$trackbar = TrackBarInput_$('trackbar', this); this.$input = TrackBarInput_$('flexiconinput', this); absol.OOP.drillProperty(this, this.$input, ['unit', 'icon']); this.$trackbar.on('change', function () { thisTI.$input.value = thisTI.value + ''; thisTI.emit('change', thisTI.value); }); this.$input.on('keyup', this.eventHandler.inputChange); this.inputTextWidth = 2; this.valueFixed = undefined; return this; } TrackBarInput.tag = 'TrackBarInput'.toLowerCase(); TrackBarInput.render = function () { return TrackBarInput_({ class: 'absol-trackbar-input', extendEvent: 'change', child: [ 'trackbar', 'flexiconinput' ] }); }; TrackBarInput.prototype.init = function (props) { props = props || {}; props.leftValue = props.leftValue || 0; props.value = props.value || props.leftValue; Object.assign(this, props); this.value = props.value; }; TrackBarInput.prototype._calInputTextWidth = function () { var l = Math.max(this.leftValue.toFixed(this.valueFixed || 0).length, this.rightValue.toFixed(this.valueFixed || 0).length, 2); if (this.valueFixed > 0) { l -= 0.8; } this.inputTextWidth = l; }; TrackBarInput.prototype.addStyle = function (arg0, arg1) { if (arg0 === 'textAlign' || arg0 === 'text-align') { this.$input.addStyle('text-align', arg1); return this; } else { AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); return this; } }; // absol.OOP.drillProperty(this, this.$trackbar, ['leftValue', 'rightValue']); TrackBarInput.property = {}; TrackBarInput.property.leftValue = { set: function (value) { this.$trackbar.leftValue = value; this._calInputTextWidth(); }, get: function () { return this.$trackbar.leftValue; } }; TrackBarInput.property.rightValue = { set: function (value) { this.$trackbar.rightValue = value; this._calInputTextWidth(); }, get: function () { return this.$trackbar.rightValue; } }; TrackBarInput.property.value = { set: function (value) { this.$trackbar.value = value || 0; this.$input.value = this.value + ''; }, get: function () { return parseFloat((this.valueFixed === undefined ? this.$trackbar.value : this.$trackbar.value.toFixed(this.valueFixed)) + ''); } }; TrackBarInput.property.valueFixed = { set: function (value) { if (value === undefined || value === null) value = undefined; this._valueFixed = value; this.$input.value = this.value + ''; this._calInputTextWidth(); }, get: function () { return this._valueFixed; } }; TrackBarInput.property.inputTextWidth = { set: function (value) { if (typeof value == 'number') { this._inputTextWidth = value; this.addStyle('--input-width', 3 + (value - 2) * 0.42 + 0.3 + 'em'); } else { this._inputTextWidth = value; this.addStyle('--input-width', value); } }, get: function () { return this._inputTextWidth; } }; TrackBarInput.property.disabled = { get: function () { return this.hasClass('as-disabled'); }, set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } this.$input.disabled = !!value; this.$trackbar.disabled = !!value; } }; TrackBarInput.property.readOnly = { set: function (value) { value = !!value; if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } this.$input.readOnly = value; this.$trackbar.readOnly = value; }, get: function () { return this.hasClass('as-read-only'); } } TrackBarInput.eventHandler = {}; TrackBarInput.eventHandler.inputChange = function (event) { var newValue = parseFloat(this.$input.value); if (!isNaN(newValue)) { newValue = Math.max(this.leftValue, Math.min(this.rightValue, newValue)); this.$trackbar.value = newValue; this.emit('change', this.value); } }; /* harmony default export */ const js_TrackBarInput = (TrackBarInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/buttonrange.css var buttonrange = __webpack_require__(9872); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ButtonRange.js var ButtonRange_ = ACore/* default._ */.Z._; var ButtonRange_$ = ACore/* default.$ */.Z.$; var ChevronLeft = '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" id="Layer_1" x="0px" y="0px" viewBox="0 0 410.258 410.258" style="enable-background:new 0 0 410.258 410.258;" xml:space="preserve">\n' + '<polygon points="298.052,24 266.052,0 112.206,205.129 266.052,410.258 298.052,386.258 162.206,205.129 "/>\n' + '</svg>'; var ChevronRight = '<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"\n' + '\t viewBox="0 0 410.258 410.258" style="enable-background:new 0 0 410.258 410.258;" xml:space="preserve">\n' + '<polygon points="144.206,0 112.206,24 248.052,205.129 112.206,386.258 144.206,410.258 298.052,205.129 "/>\n' + '</svg>' /*** * @extends AElement * @constructor */ function ButtonRange() { this._dict = {}; this._pool = []; this._items = []; this.$lastActiveBtn = null; this._value = undefined; this._lastValue = this._value; this.$scroller = ButtonRange_$('.as-button-range-scroller', this) .on('wheel', this.eventHandler.wheel); this.$prevBtn = ButtonRange_$('.as-button-range-left-btn', this) .on('click', this.prevValue.bind(this)); this.$nextBtn = ButtonRange_$('.as-button-range-right-btn', this) .on('click', this.nextValue.bind(this)); this._scrollTimeout = -1; this._scrollToSelected = this._scrollToSelected.bind(this); this.$attachhook = ButtonRange_$('attachhook', this).on('error', this.eventHandler.attached); this.autoWidth = false; } ButtonRange.tag = 'buttonrange'; ButtonRange.render = function () { return ButtonRange_({ extendEvent: ['change'], class: 'as-button-range', child: [ { class: 'as-button-range-scroller', }, { class: 'as-button-range-left-ctn', child: { tag: 'button', class: 'as-button-range-left-btn', child: ChevronLeft } }, { class: 'as-button-range-right-ctn', child: { tag: 'button', class: 'as-button-range-right-btn', child: ChevronRight } }, 'attachhook' ] }); }; ButtonRange.prototype._updateUnderlinePosition = function () { if (!this.$lastActiveBtn) return; var scrollerFirstBound = this.$scroller.firstChild.getBoundingClientRect(); if (scrollerFirstBound.width === 0) return; var activeBound = this.$lastActiveBtn.getBoundingClientRect(); this.addStyle({ '--underline-left': activeBound.left - scrollerFirstBound.left + 'px', '--underline-width': activeBound.width + 'px' }); }; ButtonRange.prototype.updateSize = function () { if (this.autoWidth) { if (this.$scroller.childNodes.length > 0) { var left = this.$scroller.firstChild.getBoundingClientRect().left; var right = this.$scroller.lastChild.getBoundingClientRect().right; if (left < right) { var fontSize = this.getFontSize() || 14; this.addStyle('width', (right - left + 2) / fontSize + 2 + 'em') } } } this._updateUnderlinePosition(); this._scrollToSelected(); }; ButtonRange.prototype._newButton = function () { var button = ButtonRange_({ tag: 'button', class: 'as-button-range-item', child: { text: 'null' } }); button.on('click', this.eventHandler.clickItem.bind(this, button)); return button; }; ButtonRange.prototype._requestButton = function (items) { var button; if (this._pool.length > 0) { button = this._pool.pop(); } else { button = this._newButton(); } return button; }; ButtonRange.prototype._assignButton = function (button, data) { button._data = data; button.childNodes[0].data = data.text; }; ButtonRange.prototype._releaseButton = function (button) { this._pool.push(button); }; ButtonRange.prototype._requireButton = function (n) { var child; while (this.$scroller.childNodes.length > n) { child = this.$scroller.lastChild; this._releaseButton(child); this.$scroller.removeChild(child); } while (this.$scroller.childNodes.length < n) { this.$scroller.addChild(this._requestButton()); } }; ButtonRange.prototype._assignButtonList = function (items) { var item; for (var i = 0; i < items.length; ++i) { item = this._getFullFormat(items[i]); this._assignButton(this.$scroller.childNodes[i], item); this._dict[item.ident] = { elt: this.$scroller.childNodes[i], data: item } } }; ButtonRange.prototype._scrollToSelected = function () { if (this._scrollTimeout >= 0) return; if (!this.$lastActiveBtn) return; var scrollerBound = this.$scroller.getBoundingClientRect(); if (scrollerBound.width === 0) return; var activeBound = this.$lastActiveBtn.getBoundingClientRect(); var dx, speed; if (activeBound.left < scrollerBound.left - 1) { dx = activeBound.left - scrollerBound.left; if (dx < -500) dx = -500; speed = Math.sqrt(-dx * 2 + 4); this.$scroller.scrollLeft -= speed; } else if (activeBound.right - 1 > scrollerBound.right) { dx = activeBound.right - scrollerBound.right; if (dx > 500) dx = 500; speed = Math.sqrt(dx * 2 + 4); this.$scroller.scrollLeft += speed; } else { return; } var thisBR = this; this._scrollTimeout = setTimeout(function () { thisBR._scrollTimeout = -1; thisBR._scrollToSelected(); }, 20); }; ButtonRange.prototype.nextValue = function (userAction) { var currentIndex = this._findActiveIndex(); var nextIndex; var nextValue; if (currentIndex < 0) { nextIndex = 0; } else { nextIndex = Math.min(this._items.length - 1, currentIndex + 1); } if (nextIndex >= 0) { nextValue = this._getFullFormat(this._items[nextIndex]).value; this.value = nextValue; if (userAction) this.notifyChange(); } }; ButtonRange.prototype.prevValue = function (userAction) { var currentIndex = this._findActiveIndex(); var prevIndex; var prevValue; if (currentIndex < 0) { prevIndex = 0; } else { prevIndex = Math.max(0, currentIndex - 1); } if (prevIndex >= 0 && prevIndex < this._items.length && prevIndex != currentIndex) { prevValue = this._getFullFormat(this._items[prevIndex]).value; this.value = prevValue; if (userAction) this.notifyChange(); } }; ButtonRange.prototype._findActiveIndex = function () { var item; var value = this._value; for (var i = 0; i < this._items.length; ++i) { item = this._items[i]; if (item === value || (item && item.value === value)) return i; } return -1; } ButtonRange.prototype._getFullFormat = function (item) { var res = {}; if ((typeof item == 'string') || (typeof item == 'number') || (typeof item == 'boolean') || (item === null) || (item === undefined)) { res.ident = item + ''; res.value = item; res.text = item + ''; } else if (item && (typeof item == 'object')) { res.value = item.value; res.ident = res.value + ''; res.text = item.text; } return res; }; ButtonRange.prototype.notifyChange = function () { this.emit('change', { target: this, value: this.value, type: 'change' }, this); } ButtonRange.property = {}; /** * @type {ButtonRange} */ ButtonRange.property.items = { set: function (items) { items = items || []; this._items = items; this._requireButton(items.length); this._assignButtonList(items); if (items.length > 0) { if (!this._dict[this._value + '']) { this._value = this._getFullFormat(items[0]).value; } } this.value = this._value; this.updateSize(); }, get: function () { return this._items; } }; ButtonRange.property.value = { set: function (value) { this._value = value; this._lastValue = this._value; if (this.$lastActiveBtn) { this.$lastActiveBtn.removeClass('as-active'); this.$lastActiveBtn = null; } var hodler = this._dict[value + '']; if (hodler) { hodler.elt.addClass('as-active'); this.$lastActiveBtn = hodler.elt; } var activeIndex = this._findActiveIndex(); this.$prevBtn.disabled = activeIndex === 0; this.$nextBtn.disabled = activeIndex === this._items.length - 1; this._updateUnderlinePosition(); this._scrollToSelected(); }, get: function () { return this._value; } }; ButtonRange.eventHandler = {}; ButtonRange.eventHandler.clickItem = function (item, event) { if (this._lastValue != item._data.value) { this.value = item._data.value; this.notifyChange(); } }; ButtonRange.eventHandler.attached = function () { if (this.style.width === 'auto') this.autoWidth = true; Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this.$attachHook); this.updateSize(); }; ButtonRange.eventHandler.wheel = function (event) { var prevLeft = this.$scroller.scrollLeft; if (event.deltaY < 0) { this.$scroller.scrollLeft -= 100; } else if (event.deltaY > 0) { this.$scroller.scrollLeft += 100; } if (prevLeft !== this.$scroller.scrollLeft) event.preventDefault(); }; ACore/* default.install */.Z.install(ButtonRange); /* harmony default export */ const js_ButtonRange = (ButtonRange); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/DropZone.js var DropZone = __webpack_require__(1577); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/radioinput.css var radioinput = __webpack_require__(1646); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/RadioInput.js //new tech, not working version var RadioInput_ = ACore/* default._ */.Z._; var RadioInput_$ = ACore/* default.$ */.Z.$; /*** * @extends Element * @constructor */ function RadioInput() { this.$input = RadioInput_$('input', this) .on('change', this.notifyChange.bind(this)); this.checked = false; this.disabled = false; this.on('click', this.eventHandler.click); this.onchange = null; } RadioInput.tag = "RadioInput".toLowerCase(); RadioInput.render = function (data) { return RadioInput_({ tag: 'label', extendEvent: 'change', class: 'as-radio-input', child: [ { elt: data && data.$input, tag: 'input', class: 'as-radio-input-value', attr: { type: 'radio' } }, { class: ['as-radio-input-check-mark'] } ] } ) }; /*** * as normal, change event will be fired when radio change by system */ RadioInput.prototype.notifyChange = function () { var event = { checked: this.checked }; this.emit('change', event, this); }; RadioInput.prototype._updateCheckedClass = function () { if (this.checked) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } }; RadioInput.property = {}; RadioInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } this.$input.disabled = !!value; }, get: function () { this.$input.disabled; } }; /*** * * @type {RadioInput} */ RadioInput.property.checked = { set: function (value) { this.$input.checked = !!value; this._updateCheckedClass(); }, get: function () { return this.$input.checked; } } RadioInput.attribute = { checked: { set: function (value) { if (value === 'false' || value === null) { this.checked = false; } else { this.checked = true; } }, get: function () { return this.checked ? 'true' : 'false' }, remove: function () { this.checked = false; } }, disabled: { set: function (value) { if (value === 'false' || value === null) { this.disabled = false; } else { this.disabled = true; } }, get: function () { return this.disabled ? 'true' : 'false' }, remove: function () { this.disabled = false; } } }; /*** * * @type {RadioInput} */ RadioInput.eventHandler = {}; RadioInput.eventHandler.click = function () { this._updateCheckedClass(); }; ACore/* default.install */.Z.install(RadioInput); RadioInput.autoReplace = function () { var placeHolders = Array.prototype.slice.call(document.getElementsByTagName(this.tag)); var ph; var attOfPH; var attrs; var style; var classList; var attNode; var attrName, attrValue; var props; for (var i = 0; i < placeHolders.length; ++i) { ph = placeHolders[i]; attOfPH = ph.attributes; classList = []; style = {}; attrs = {}; props = {}; for (var j = 0; j < attOfPH.length; ++j) { attNode = attOfPH[j]; attrName = attNode.nodeName; attrValue = attNode.nodeValue; if (attrName == 'style') { attrValue.trim().split(';').reduce(function (style, prop) { var p = prop.split(':'); if (p.length == 2) { style[p[0].trim()] = p[1].trim(); } return style; }, style); } else if (attrName == 'class') { classList = attrValue.trim().split(/\s+/); } else if (attrName == 'onchange') { props.onchange = new Function('event', 'sender', attrValue); } else { attrs[attrName] = attrValue; } } var newElt = RadioInput_({ tag: this.tag, attr: attrs, class: classList, style: style, props: props }); RadioInput_$(ph).selfReplace(newElt); } }; RadioInput.initAfterLoad = function (){ Dom/* default.documentReady.then */.ZP.documentReady.then(function (){ RadioInput.autoReplace(); }) }; /* harmony default export */ const js_RadioInput = (RadioInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/OnScreenWidget.js var OnScreenWidget = __webpack_require__(7315); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/RibbonSplitButton.js var RibbonSplitButton = __webpack_require__(6455); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/RibbonButton.js var RibbonButton = __webpack_require__(9664); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/timeselectinput.css var timeselectinput = __webpack_require__(7931); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TimeSelectInput.js var TimeSelectInput_ = ACore/* default._ */.Z._; var TimeSelectInput_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function TimeSelectInput() { /*** * * @type {SelectListBox} */ this.$selectlistBox = TimeSelectInput_({ tag: 'selectlistbox', props: { anchor: [1, 6, 2, 5] }, on: { preupdateposition: this.eventHandler.preUpdateListPosition } }); this.$text = TimeSelectInput_$('.as-time-select-input-text', this) .on('change', this.eventHandler.textChange) .on('keyup', this.eventHandler.textKeyUp) .on('keydown', this.eventHandler.textKeyDown); this.$toggleBtn = TimeSelectInput_$('absol-selectmenu-btn', this); this.$selectlistBox.on('pressitem', this.eventHandler.selectListBoxPressItem); this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; this._makeTimeList(0, datetime.MILLIS_PER_DAY, datetime.MILLIS_PER_MINUTE * 15); this._hour = 0; this._minute = 0; this._lastDayOffset = 0; this.dayOffset = 0; this.on('click', this.eventHandler.click); } TimeSelectInput.tag = 'TimeSelectInput'.toLowerCase(); TimeSelectInput.render = function () { return TimeSelectInput_({ class: 'as-time-select-input', extendEvent: 'change', attr: { tabindex: 0 }, child: [ { tag: 'input', class: 'as-time-select-input-text', attr: { type: 'text' } }, { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] } ] }); }; TimeSelectInput.prototype._makeTimeList = function (start, end, step) { var items = []; for (var t = 0; t < end; t += step) { items.push({ text: this._mil2Text(t), value: t }); } this.$selectlistBox.items = items; this.addStyle('--list-min-width', this.$selectlistBox._estimateWidth/14 + 'em'); }; TimeSelectInput.prototype.textRegx = /^((1[0-2])|[1-9]):([0-5][0-9]) (AM|PM)$/; TimeSelectInput.prototype._mil2Text = function (mil) { if (mil < 0) { mil = mil + Math.ceil(-mil / datetime.MILLIS_PER_DAY) * datetime.MILLIS_PER_DAY; } var min = Math.floor(mil / (datetime.MILLIS_PER_MINUTE)); var hour = Math.floor(min / 60) % 24; min = min % 60; return (hour % 12 == 0 ? 12 : (hour % 12)) + ':' + (min < 10 ? '0' : '') + min + ' ' + (hour < 12 ? 'AM' : 'PM'); }; /*** * * @param {string} s * @private */ TimeSelectInput.prototype._text2mil = function (s) { s = s.toLowerCase(); var nums = s.match(/[0-9]+/g) || [0, 0]; while (nums.length < 2) { nums.push(0); } var h = (0,utils.positiveIntMod)(parseInt(nums[0]), 24); var m = (0,utils.positiveIntMod)(parseInt(nums[1]), 60); var pm = s.indexOf('pm') > 0 || h > 12; if (pm) { if (h < 12) h += 12; } else { if (h == 12) h = 0; } return h * datetime.MILLIS_PER_HOUR + m * datetime.MILLIS_PER_MINUTE; }; TimeSelectInput.prototype.isActive = function () { return document.activeElement == this || AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(document.activeElement, this) || AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(document.activeElement, this.$selectlistBox); }; TimeSelectInput.prototype._updateValueText = function () { this.$text.value = this._mil2Text(this.dayOffset); }; TimeSelectInput.prototype.notifyCanBeChange = function () { var dayOffset = this.dayOffset; if (this._lastDayOffset !== dayOffset) { this.emit('change', { type: 'change', lastDayOffset: this._lastDayOffset, dayOffset: dayOffset, target: this }, this); this._lastDayOffset = dayOffset; } }; TimeSelectInput.property = {}; TimeSelectInput.property.isFocus = { get: function () { return this.hasClass('as-focus'); }, set: function (value) { value = !!value; if (value && (this.disabled || this.readOnly)) return; if (this.isFocus == value) return; if (value) { this.addClass('as-focus'); } else { this.removeClass('as-focus'); } var thisI = this; if (value) { this.$selectlistBox.addTo(document.body) var bound = this.getBoundingClientRect(); this.$selectlistBox.addStyle('min-width', bound.width + 'px'); this.$selectlistBox.refollow(); this.$selectlistBox.updatePosition(); setTimeout(function () { if (thisI.enableSearch) { thisI.$selectlistBox.$searchInput.focus(); } TimeSelectInput_$(document.body).on('click', thisI.eventHandler.bodyClick); }, 1); this.$selectlistBox.viewListAtFirstSelected(); } else { TimeSelectInput_$(document.body).off('click', thisI.eventHandler.bodyClick); this.$selectlistBox.selfRemove(); this.$selectlistBox.unfollow(); this.$selectlistBox.resetSearchState(); } } }; TimeSelectInput.property.hour = { set: function (value) { this._hour = (0,utils.positiveIntMod)(value, 24); this._lastDayOffset = this.dayOffset; this._updateValueText(); }, get: function () { return this._hour; } }; TimeSelectInput.property.minute = { set: function (value) { this._minute = (0,utils.positiveIntMod)(value, 60); this._lastDayOffset = this.dayOffset; this._updateValueText(); }, get: function () { return this._minute; } }; TimeSelectInput.property.dayOffset = js_TimeInput.property.dayOffset; TimeSelectInput.property.disabled = { set: function (value) { this.$text.disabled = !!value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } } , get: function () { return this.hasClass('as-disabled'); } }; /*** * * @type {{}|TimeSelectInput} */ TimeSelectInput.eventHandler = {}; TimeSelectInput.eventHandler.selectListBoxPressItem = function (event) { var lastValue = this._lastDayOffset; var value = event.value; var text = this._mil2Text(value); this.dayOffset = value; this.$selectlistBox.values = [value]; this.focus(); setTimeout(function () { this.isFocus = false; }.bind(this), 100); this._lastDayOffset = lastValue;// restore last value after set dayOffset this.notifyCanBeChange(); }; TimeSelectInput.eventHandler.preUpdateListPosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$selectlistBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { this.isFocus = false; } }; TimeSelectInput.eventHandler.textChange = function () { setTimeout(function () { if (!this.textRegx.test(this.$text.value)) { this.$text.value = this._mil2Text(this.dayOffset); } }.bind(this), 10); }; /*** * * @param {KeyboardEvent} event */ TimeSelectInput.eventHandler.textKeyDown = function (event) { if (event.key == 'Enter') { this.isFocus = false; this.$text.blur(); this.notifyCanBeChange(); } }; TimeSelectInput.eventHandler.textKeyUp = function (event) { var s = this.$text.value; var mil = this._text2mil(s); this._hour = Math.floor(mil / datetime.MILLIS_PER_HOUR); this._minute = Math.floor(mil / datetime.MILLIS_PER_MINUTE) % 60; this.$selectlistBox.values = [mil]; this.$selectlistBox.viewListAtFirstSelected(); }; TimeSelectInput.eventHandler.click = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$text, event)) { this.isFocus = !this.isFocus; setTimeout(function () { if (this.isFocus && this.$text != document.activeElement) { this.$text.select(); } }.bind(this), 1) } else { if (!this.isFocus) this.isFocus = true; } }; TimeSelectInput.eventHandler.bodyClick = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this, event) || EventEmitter/* default.hitElement */.ZP.hitElement(this.$selectlistBox, event)) return; this.isFocus = false; }; ACore/* default.install */.Z.install(TimeSelectInput); /* harmony default export */ const js_TimeSelectInput = (TimeSelectInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/snackbar.css var snackbar = __webpack_require__(3007); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/Snackbar.js var Snackbar_ = ACore/* default._ */.Z._; var Snackbar_$ = ACore/* default.$ */.Z.$; var t = document.createElement; /*** * @extends AElement * @constructor */ function SnackBar() { // OOP.drillProperty(this, this.firstChild, 'message', 'data'); /*** * * @type {*} */ this._message = null; this.message = null; } SnackBar.tag = 'SnackBar'.toLowerCase(); SnackBar.render = function () { return Snackbar_({ class: 'as-snackbar' }) }; SnackBar.property = {}; SnackBar.property.message = { set: function (value) { this._message = value; if (value instanceof Array) { this.clearChild(); this.addChild(value.map(function (item) { return Snackbar_(item); })); } else if (typeof value === 'string') { this.innerHTML = value; } else if ((0,Dom/* isDomNode */.mV)(value)) { this.clearChild() .addChild(value); } else if (value && typeof value === 'object' && (value.text || value.props || value.tag || value.attr || value.style || value.child || (value.child && value.child instanceof Array))) { this.clearChild() .addChild(Snackbar_(value)); } else { this.clearChild(); this._message = null; } }, get: function () { return this._message; } } ACore/* default.install */.Z.install(SnackBar); SnackBar.$instance = Snackbar_('snackbar'); SnackBar._removeTimeout = -1; SnackBar.show = function (message) { if (SnackBar._removeTimeout > 0) { clearTimeout(SnackBar._removeTimeout); } if (!SnackBar.$instance.parentElement) document.body.appendChild(SnackBar.$instance); SnackBar.$instance.removeClass('as-hiding'); SnackBar._removeTimeout = setTimeout(function () { SnackBar.$instance.addClass('as-show'); SnackBar.$instance.message = message; SnackBar._removeTimeout = setTimeout(function () { SnackBar.$instance.removeClass('as-show').addClass('as-hiding'); SnackBar._removeTimeout = setTimeout(function () { SnackBar.$instance.remove(); SnackBar._removeTimeout = -1; SnackBar.$instance.removeClass('as-hiding'); }, 500); }, 3000); }, 1); } /* harmony default export */ const Snackbar = (SnackBar); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/multiselectmenu.css var multiselectmenu = __webpack_require__(3010); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/LanguageSystem.js var LanguageSystem = __webpack_require__(6013); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiSelectMenu.js var MultiSelectMenu_ = ACore/* default._ */.Z._; var MultiSelectMenu_$ = ACore/* default.$ */.Z.$; /*** * @augments SelectBox * @augments PositionTracker * @constructor */ function MultiSelectMenu() { this.on('click', this.eventHandler.click); /*** * * @type {SelectListBox} */ this.$selectlistBox = MultiSelectMenu_({ tag: 'selectlistbox', props: { anchor: [1, 6, 2, 5], displayValue: VALUE_HIDDEN }, on: { preupdateposition: this.eventHandler.preUpdateListPosition, pressitem: this.eventHandler.selectListBoxPressItem } }); this.$itemCtn = MultiSelectMenu_$('.as-multi-select-menu-item-ctn', this); this.$attachhook = MultiSelectMenu_$('attachhook', this) .on('attached', this.eventHandler.attached); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectlistBox, 'enableSearch'); this.$items = []; this._values = []; this.items = []; this.values = []; this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; this.disableClickToFocus = false; this.orderly = true; this.itemFocusable = false; this._activeValue = undefined; this.strictValue = true; } MultiSelectMenu.tag = 'MultiSelectMenu'.toLowerCase(); MultiSelectMenu.render = function () { return MultiSelectMenu_({ class: ['as-multi-select-menu'], extendEvent: ['change', 'add', 'remove', 'activevaluechange'], attr: { tabindex: '1' }, child: [ { attr:{ 'data-ml-key': 'txt_select_value' }, class: ['as-multi-select-menu-item-ctn', 'as-bscroller'] }, { tag: 'button', class: 'as-multi-select-menu-toggle-btn', child: 'dropdown-ico' }, 'attachhook' ] }); }; MultiSelectMenu.prototype._requireItem = function (n) { var itemElt; while (this.$items.length < n) { itemElt = requireItem(this); this.$itemCtn.addChild(itemElt); this.$items.push(itemElt); } while (this.$items.length > n) { itemElt = this.$items.pop(); this.$itemCtn.removeChild(itemElt); releaseItem(itemElt); } }; MultiSelectMenu.prototype._assignItems = function (items) { for (var i = 0; i < this.$items.length && i < items.length; ++i) { this.$items[i].data = items[i]; } }; /*** * * @param {string[] | number[]} values * @private */ MultiSelectMenu.prototype._getItemsByValues = function (values) { var selectListBoxElt = this.$selectlistBox; var itemHolders = values.reduce(function (ac, cr) { ac.push.apply(ac, selectListBoxElt.findItemsByValue(cr)); return ac; }, []); if (this.orderly) { if (typeof this.orderly === 'function') { itemHolders.sort(this.orderly); } else { itemHolders.sort(function (a, b) { return a.idx - b.idx; }); } } return itemHolders.map(function (holder) { return holder.item; }) }; MultiSelectMenu.prototype._updateItems = function () { this.viewItemsByValues(this._values); }; MultiSelectMenu.prototype.viewItemsByValues = function (values) { var cBound = this.getBoundingClientRect(); var items = this._getItemsByValues(values); this._requireItem(items.length); this._assignItems(items); if (this.itemFocusable) { this._updateFocusItem(); } var nBound = this.getBoundingClientRect(); if (nBound.width != cBound.width || nBound.height != cBound.height) { ResizeSystem/* default.updateUp */.Z.updateUp(this); } }; MultiSelectMenu.property = {}; MultiSelectMenu.property.disabled = SelectMenu2.property.disabled; MultiSelectMenu.property.hidden = SelectMenu2.property.hidden; MultiSelectMenu.property.isFocus = SelectMenu2.property.isFocus; MultiSelectMenu.property.readOnly = SelectMenu2.property.readOnly; MultiSelectMenu.prototype.init = function (props) { props = props || []; Object.keys(props).forEach(function (key) { if (props[key] === undefined) delete props[key]; }); this.super(props); }; MultiSelectMenu.prototype._updateFocusItem = function () { for (var i = 0; i < this.$items.length; ++i) { this.$items[i].active = this.$items[i].value == this._activeValue; } }; MultiSelectMenu.prototype.init = SelectMenu2.prototype.init; MultiSelectMenu.prototype._implicit = function (values) { if (values === null || values === undefined) values = []; if (!(values instanceof Array)) { values = [values]; } values = values.filter(function (value) { var type = typeof value; return type === 'string' || type === 'number' || type === "boolean" || value === null || value === undefined; }).reduce(function (ac, cr) { if (!ac.dict[cr]) { ac.dict[cr] = true; ac.result.push(cr); } return ac; }, { result: [], dict: {} }).result; return values; }; MultiSelectMenu.prototype._explicit = function (values) { var selectListBoxElt = this.$selectlistBox; var strictValue = this.strictValue; values = values.filter(function (value) { if (!strictValue) return true; var cts = selectListBoxElt.findItemsByValue(value); if (cts && cts.length > 0) return true; return false; }) return values; }; MultiSelectMenu.property.items = { set: function (items) { items = items || []; this.$selectlistBox.items = items; this.addStyle('--list-min-width', this.$selectlistBox._estimateWidth + 'px'); this._updateItems(); }, get: function () { return this.$selectlistBox.items } }; MultiSelectMenu.property.values = { set: function (values) { values = this._implicit(values); this._values = values; this.$selectlistBox.values = values; this._updateItems(); }, get: function () { return this._explicit(this._values); } }; MultiSelectMenu.property.orderly = { set: function (value) { var needUpdate = this._orderly === this._orderly; if (typeof value === 'function') { this._orderly; } else this._orderly = !!value; if (needUpdate) { this.values = this.values; } }, get: function () { return !!this._orderly; } }; MultiSelectMenu.property.disableClickToFocus = { set: function (value) { if (value) { this.addClass('as-disable-click-to-focus'); } else { this.removeClass('as-disable-click-to-focus'); } }, get: function () { return this.hasClass('as-disable-click-to-focus'); } }; MultiSelectMenu.property.itemFocusable = { set: function (value) { if (value) { this.addClass('as-item-focusable'); } else { this.removeClass('as-item-focusable'); } this._updateFocusItem(); }, get: function () { return this.hasClass('as-item-focusable'); } }; MultiSelectMenu.property.activeValue = { set: function (value) { this._activeValue = value; if (this.itemFocusable) { this._updateFocusItem(); //todo } }, get: function () { return this._activeValue; } }; MultiSelectMenu.property.strictValue = { set: function (value) { if (value){ this.attr('data-strict-value', null); } else { this.attr('data-strict-value', 'false'); } }, get: function () { var data = this.attr('data-strict-value'); return !data || (data != 'false' && data !== '0'); } }; MultiSelectMenu.eventHandler = Object.assign({}, SelectMenu2.eventHandler); MultiSelectMenu.eventHandler.attached = function () { var maxHeightStyle = this.getComputedStyleValue('max-height') || 'none'; if (maxHeightStyle.match(/[0-9-]+px/)) { this.addStyle('--multi-select-menu-max-height', maxHeightStyle); this.addStyle('max-height', 'unset'); } else if (maxHeightStyle !== 'none') { console.warn('Can not adapt max-height:', maxHeightStyle); } }; MultiSelectMenu.eventHandler.click = function (event) { if (this.disabled) return; if ((event.target === this || event.target === this.$itemCtn) && !this.disableClickToFocus && !this.readOnly) { this.isFocus = !this.isFocus; } }; MultiSelectMenu.eventHandler.bodyClick = function (event) { if (!EventEmitter/* default.hitElement */.ZP.hitElement(this.$selectlistBox, event) && event.target !== this && event.target !== this.$itemCtn) { this.isFocus = false; } }; MultiSelectMenu.eventHandler.selectListBoxPressItem = function (event) { var data = event.data; var currentValues = this.$selectlistBox.values; currentValues.push(data.value); this.$selectlistBox.values = currentValues; this.$selectlistBox.updatePosition(); this._values = currentValues.slice(); this._activeValue = data.value; this._updateItems(); this.isFocus = false; this.emit('add', Object.assign({}, event, { type: 'add', target: this, value: data.value, data: data, itemData: data }), this); this.emit('change', Object.assign({}, event, { type: 'change', action: 'add', target: this, value: data.value, data: data, values: this.values }), this); }; MultiSelectMenu.eventHandler.pressItem = function (item, event) { var value = item.value; if (this.itemFocusable) { var prevActiveValue = this.activeValue; if (value !== prevActiveValue) { this.activeValue = value; this.emit('activevaluechange', { target: this, originEvent: event, prevActiveValue: prevActiveValue, activeValue: value }, this); } } }; MultiSelectMenu.eventHandler.pressCloseItem = function (item, event) { var value = item.value; var data = item.data; var index; index = this._values.indexOf(value); if (index >= 0) { this._values.splice(index, 1); this._updateItems(); this.$selectlistBox.values = this._values; this.emit('remove', Object.assign({}, event, { type: 'change', target: this, data: data, value: value, itemData: data }), this); this.emit('change', Object.assign({}, event, { type: 'change', action: 'remove', target: this, data: data, value: value, itemData: data }), this); } }; ACore/* default.install */.Z.install(MultiSelectMenu); /* harmony default export */ const js_MultiSelectMenu = (MultiSelectMenu); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/countdownclock.css var countdownclock = __webpack_require__(5197); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CountdownClock.js var CountdownClock_ = ACore/* default._ */.Z._; var CountdownClock_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function CountdownClock() { var thisC = this; this.$attachhook = CountdownClock_('attachhook').addTo(this) .on('attached', function () { ResizeSystem/* default.add */.Z.add(this); this.requestUpdateSize(); if (thisC.autoStart) { thisC.start(); } }); this.$attachhook.requestUpdateSize = this._updateBorder.bind(this); this._tick = this._tick.bind(this); this.$border = CountdownClock_$(".as-countdown-clock-border", this); this.$min = CountdownClock_$(".as-countdown-clock-min", this); this.$sec = CountdownClock_$(".as-countdown-clock-sec", this); this._prevText = -1; this._startTime = new Date().getTime(); this._totalSecond = 60; this._remainSecond = 0; this.totalSecond = 60; this.remainSecond = 0; this._intvId = -1; } CountdownClock.tag = 'CountdownClock'.toLowerCase(); CountdownClock.render = function () { return CountdownClock_({ extendEvent: ['finish', 'update'], class: 'as-countdown-clock', child: [ { class: 'as-countdown-clock-text', child: [ { tag: 'span', class: 'as-countdown-clock-min', child: { text: 0 } }, { text: ':' }, { tag: 'span', class: 'as-countdown-clock-sec', child: { text: '60' } } ] }, { class: 'as-countdown-clock-border-wrapper', child: { class: 'as-countdown-clock-border' } } ] }); }; CountdownClock.prototype._makePolygon = function (end) { var n = Math.ceil(Math.max(end / 0.2, 2)); var fan = Array(n).fill(0).map(function (u, i) { var angle = -Math.PI / 2 + end * i / n; return [(0,Math_int.numberAutoFixed)(50 + 60 * Math.cos(angle), 5) + '%', (0,Math_int.numberAutoFixed)(50 + 60 * Math.sin(angle), 5) + '%'].join(' ') }); fan.push('50% 50%'); return 'polygon('+fan.join(', ')+')'; }; CountdownClock.prototype._setBorderValue = function (val) { if (val >= 1 || !isFinite(val)) { this.$border.removeStyle("clip-path"); return; } var bound = this.$border.getBoundingClientRect(); var angle = val * Math.PI * 2; this.$border.addStyle("-webkit-clip-path", this._makePolygon(angle)); this.$border.addStyle("clip-path", this._makePolygon(angle)); }; CountdownClock.prototype._updateBorder = function () { this._setBorderValue(this._remainSecond / Math.max(0.001, this._totalSecond)); }; CountdownClock.prototype._updateText = function () { if (this._prevText === this.remainSecond) return; var remainSecond = this.remainSecond; var min = Math.floor(remainSecond / 60); var sec = remainSecond % 60; this.$sec.innerHTML = (sec < 10 ? "0" : "") + sec; this.$min.innerHTML = min; } CountdownClock.prototype._tick = function () { var now = new Date().getTime(); var prevSec = this.remainSecond; this.remainSecond = Math.max(0, Math.ceil(this.totalSecond - (now - this._startTime) / 1000)); if (prevSec !== this.remainSecond) { this._updateText(); this.emit('update', { target: this, type: 'update' }, this); if (this.remainSecond === 0) { clearInterval(this._intvId); this._intvId = -1; this.emit('finish', { target: this, type: 'finish' }, this); } } }; CountdownClock.prototype.start = function () { if (this.remainSecond == 0) this.remainSecond = this.totalSecond; this._startTime = new Date().getTime() - (this.totalSecond - this.remainSecond) * 1000; this.resume(); }; CountdownClock.prototype.resume = function () { if (this._intvId > 0) return; this._intvId = setInterval(this._tick, 200); }; CountdownClock.prototype.pause = function () { if (this._intvId > 0) { clearInterval(this._intvId); this._intvId = -1; } }; CountdownClock.prototype.stop = function () { this.pause(); this.remainSecond = 0; }; CountdownClock.prototype.reset = function () { this.remainSecond = this.totalSecond; this._startTime = new Date().getTime(); } CountdownClock.property = {}; CountdownClock.property.totalSecond = { set: function (value) { if (!(value >= 0)) { value = 0; } this._totalSecond = value; this._updateBorder(); }, get: function () { return this._totalSecond; } }; CountdownClock.property.remainSecond = { set: function (value) { if (!(value >= 0)) { value = 0; } this._remainSecond = value; this._updateBorder(); this._updateText(); }, get: function () { return this._remainSecond; } } ACore/* default.install */.Z.install(CountdownClock); /* harmony default export */ const js_CountdownClock = (CountdownClock); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Toast.js var Toast = __webpack_require__(1376); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Icons.js + 22 modules var Icons = __webpack_require__(2380); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/emojipickertooltip.css var emojipickertooltip = __webpack_require__(1158); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiAnims.js var EmojiAnims = __webpack_require__(4670); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/pageindicator.css var pageindicator = __webpack_require__(8895); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PageIndicator.js var PageIndicator_ = ACore/* default._ */.Z._; var PageIndicator_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function PageIndicator() { this._idx = -1; this.length = 0; this.idx = -1; } PageIndicator.tag = 'PageIndicator'.toLowerCase(); PageIndicator.render = function () { return PageIndicator_({ class: 'as-page-indicator', child: [] }); }; PageIndicator.property = {}; PageIndicator.property.length = { set: function (value) { value = value || 0; value = Math.max(0, value); while (this.childNodes.length < value) { this.addChild(PageIndicator_('button.as-page-indicator-item')); } while (this.childNodes.length > value) { this.removeChild(this.childNodes[this.childNodes.length - 1]); } this.idx = this._idx;//update }, get: function () { return this.childNodes.length; } }; PageIndicator.property.idx = { set: function (value) { var activeElt = this.childNodes[this._idx]; if (activeElt) activeElt.removeClass('as-active'); this._idx = value; activeElt = this.childNodes[this._idx]; if (activeElt) activeElt.addClass('as-active'); }, get: function () { return this._idx; } }; ACore/* default.install */.Z.install(PageIndicator); /* harmony default export */ const js_PageIndicator = (PageIndicator); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EmojiPickerTooltip.js var EmojiPickerTooltip_ = ACore/* default._ */.Z._; var EmojiPickerTooltip_$ = ACore/* default.$ */.Z.$; var isMobile = BrowserDetector/* default.isMobile */.Z.isMobile; /*** * @augments Tooltip * @augments AElement * @augments Hanger * @constructor */ function EmojiPickerTooltip() { if (isMobile) { EmojiPickerTooltip_({ tag: Hanger/* default.tag */.Z.tag, elt: this, on: { predrag: this.eventHandler.preDragTT, dragstart: this.eventHandler.dragStartTT, drag: this.eventHandler.dragTT, dragend: this.eventHandler.dragEndTT } }) } this.$iconList = EmojiPickerTooltip_$('.as-emoji-picker-tooltip-icon-list', this); this.$leftBtn = EmojiPickerTooltip_$('.as-emoji-picker-tooltip-left-btn', this) .on('click', this.eventHandler.clickLeft); this.$scroller = EmojiPickerTooltip_$('.as-emoji-picker-tooltip-scroller', this); this.$rightBtn = EmojiPickerTooltip_$('.as-emoji-picker-tooltip-right-btn', this) .on('click', this.eventHandler.clickRight); this.$removeBtn = EmojiPickerTooltip_$('.as-emoji-picker-tooltip-remove-btn', this) .on('click', this.eventHandler.clickRemove); this.$pageIndicatior = EmojiPickerTooltip_$('pageindicator', this); this._iconButtonCache = {}; this._icons = []; this.icons = EmojiPickerTooltip.defaultIcons; } EmojiPickerTooltip.tag = 'EmojiPickerTooltip'.toLowerCase(); EmojiPickerTooltip.defaultIcons = [';(', '(sarcastic)', ':O', '(cwl)', '(heart)', '(y)', '(n)', '(rock)', '(facepalm)', '(xd)', ':$', '(waiting)', '(headbang)', '(ghost)', '(clap)', '(punch)', '(ok)', '(angry)']; EmojiPickerTooltip.emojiDict = EmojiAnims/* default.reduce */.Z.reduce(function (ac, cr) { ac[cr[0]] = { imageFileName: cr[1], text: cr[0], desc: cr[2] }; return ac; }, {}); EmojiPickerTooltip.render = function () { return EmojiPickerTooltip_({ tag: 'tooltip', extendEvent: ['pick'], class: ['as-emoji-picker-tooltip'].concat(isMobile ? ['as-mobile'] : []), child: [ { tag: 'button', class: 'as-emoji-picker-tooltip-left-btn', child: 'span.mdi.mdi-chevron-left' }, { class: 'as-emoji-picker-tooltip-scroller', child: { class: 'as-emoji-picker-tooltip-icon-list', } }, { tag: 'button', class: 'as-emoji-picker-tooltip-right-btn', child: 'span.mdi.mdi-chevron-right' }, { tag: 'button', attr: { title: 'Remove Emoji' }, class: 'as-emoji-picker-tooltip-remove-btn', child: 'span.mdi.mdi-close' }, { tag: 'pageindicator', class: 'as-emoji-picker-tooltip-page-indicator', props: { length: 3, idx: 0 } } ] }, true); }; /*var */ EmojiPickerTooltip.prototype._makeIconBtn = function (iconText) { var icon = EmojiPickerTooltip.emojiDict[iconText]; var url = EmojiPicker/* default.assetRoot */.Z.assetRoot + '/anim/x40/' + icon.imageFileName; var spriteElt = EmojiPickerTooltip_({ tag: 'sprite', class: 'as-emoji-picker-tooltip-icon', attr: { title: icon.desc }, props: { src: url, loop: true, fps: 30, debug: true }, on: { ready: function () { this.frames = { type: 'grid', col: 1, row: this.texture.naturalHeight / this.texture.naturalWidth }; this.frameIndex = 0; } } }); var buttonElt = EmojiPickerTooltip_({ tag: 'button', class: 'as-emoji-picker-tooltip-icon-btn', child: spriteElt, on: { click: this.eventHandler.clickIconBtn.bind(null, icon) } }); buttonElt.on('mouseenter', function () { spriteElt.play(); }).on('mouseleave', function () { spriteElt.stop(); spriteElt.frameIndex = 0; }); return buttonElt; }; EmojiPickerTooltip.prototype._updateIconList = function () { this.$iconList.clearChild(); var iconText; for (var i = 0; i < this._icons.length; ++i) { iconText = this._icons[i]; this._iconButtonCache[iconText] = this._iconButtonCache[iconText] || this._makeIconBtn(iconText); this.$iconList.addChild(this._iconButtonCache[iconText]) } }; EmojiPickerTooltip.property = {}; EmojiPickerTooltip.property.icons = { set: function (icons) { this._icons = icons || []; this._updateIconList(); this.viewOffset = 0; this.$pageIndicatior.length = Math.ceil(this._icons.length / 6); }, get: function () { return this._icons; } }; EmojiPickerTooltip.property.viewOffset = { set: function (value) { this._viewOffset = Math.max(0, Math.min(value, this._icons.length - 6)); this.$iconList.addStyle('left', -(100 * this._viewOffset / 6) + '%'); this.$leftBtn.disabled = this._viewOffset === 0; this.$rightBtn.disabled = this._viewOffset === this._icons.length - 6; this.$pageIndicatior.idx = Math.floor(this._viewOffset / 6); }, get: function () { return this._viewOffset; } }; EmojiPickerTooltip.eventHandler = {}; EmojiPickerTooltip.eventHandler.clickLeft = function () { this.viewOffset -= 6; }; EmojiPickerTooltip.eventHandler.clickRight = function () { this.viewOffset += 6; }; EmojiPickerTooltip.eventHandler.clickIconBtn = function (icon) { if (this._preventClick) return; this.emit('pick', Object.assign({ type: 'pick', icon: icon, target: this }, icon), this); }; EmojiPickerTooltip.eventHandler.clickRemove = function () { this.emit('pick', Object.assign({ type: 'pressremove', icon: "REMOVE", target: this }), this); }; EmojiPickerTooltip.eventHandler.preDragTT = function (event) { var scrollerBound = this.$scroller.getBoundingClientRect(); var listBound = this.$iconList.getBoundingClientRect(); this._scrollData = { left: listBound.left - scrollerBound.left, scrollerWidth: scrollerBound.width, newLeft: listBound.left - scrollerBound.left }; }; EmojiPickerTooltip.eventHandler.dragStartTT = function () { this.addClass('as-scrolling'); this._preventClick = true; }; EmojiPickerTooltip.eventHandler.dragTT = function (event) { event.preventDefault(); var dx = event.currentPoint.sub(event.startingPoint).x; var newLeft = Math.min(0, Math.max(-this._scrollData.scrollerWidth * 2, this._scrollData.left + dx)); this._scrollData.newLeft = newLeft; this.$iconList.addStyle('left', newLeft + 'px'); }; EmojiPickerTooltip.eventHandler.dragEndTT = function (event) { event.preventDefault(); this.removeClass('as-scrolling'); var dOffset = (this._scrollData.left - this._scrollData.newLeft) / this._scrollData.scrollerWidth; if (dOffset > 0.25) { dOffset = 1; } else if (dOffset < -0.25) { dOffset = -1; } else { dOffset = 0; } this.viewOffset += dOffset * 6; setTimeout(function () { this._preventClick = false; }.bind(this), 5) }; ACore/* default.install */.Z.install(EmojiPickerTooltip); EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; function prepare() { if (EmojiPickerTooltip.$holder) return; EmojiPickerTooltip.$holder = EmojiPickerTooltip_('.absol-tooltip-root-holder') EmojiPickerTooltip.$tooltip = EmojiPickerTooltip_('emojipickertooltip.top').addTo(EmojiPickerTooltip.$holder) .on('pick', function (event) { EmojiPickerTooltip._listener && EmojiPickerTooltip._listener(event.icon); }); /*** * * @type {PositionTracker|undefined} */ EmojiPickerTooltip.$element = undefined; EmojiPickerTooltip.$content = undefined; EmojiPickerTooltip._orientation = 'auto'; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip._listener = undefined; EmojiPickerTooltip._scrollOutListener = undefined; EmojiPickerTooltip.$tooltip.$arrow.updateSize = EmojiPickerTooltip.updatePosition; } EmojiPickerTooltip.updatePosition = function () { if (!EmojiPickerTooltip.$element) return; var outBound = Rectangle/* default.fromClientRect */.Z.fromClientRect((0,Dom/* traceOutBoundingClientRect */.DI)(EmojiPickerTooltip.$element)); var eBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(EmojiPickerTooltip.$element.getBoundingClientRect()); if (!outBound.isCollapse(eBound, 0)) { EmojiPickerTooltip._scrollOutListener && EmojiPickerTooltip._scrollOutListener(); } (0,Tooltip/* updateTooltipPosition */.J)(EmojiPickerTooltip); }; EmojiPickerTooltip.updatePosition = EmojiPickerTooltip.updatePosition.bind(EmojiPickerTooltip); EmojiPickerTooltip.show = function (element, menuListener, orientation) { prepare(); if (EmojiPickerTooltip.$element) { EmojiPickerTooltip.$element.stopTrackPosition(); EmojiPickerTooltip.$element.off('positionchange', EmojiPickerTooltip.updatePosition); } if (!element.startTrackPosition) { EmojiPickerTooltip_({ tag: js_PositionTracker.tag, elt: element }) } element.startTrackPosition(); EmojiPickerTooltip.$element = element; EmojiPickerTooltip.$element.on('positionchange', EmojiPickerTooltip.updatePosition); EmojiPickerTooltip._listener = menuListener; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip._orientation = orientation || 'auto'; EmojiPickerTooltip.$holder.addTo(document.body); ResizeSystem/* default.add */.Z.add(EmojiPickerTooltip.$tooltip.$arrow); EmojiPickerTooltip.$tooltip.viewOffset = 0; EmojiPickerTooltip.$tooltip.addClass('top') .removeClass('left') .removeClass('right') .removeClass('bottom') .removeClass('ne') .removeClass('nw') .removeClass('auto'); EmojiPickerTooltip.updatePosition(); return EmojiPickerTooltip._session; }; EmojiPickerTooltip.close = function (token) { if (EmojiPickerTooltip._session !== token) return; if (EmojiPickerTooltip.$element) { EmojiPickerTooltip.$element.stopTrackPosition(); EmojiPickerTooltip.$element.off('positionchange', EmojiPickerTooltip.updatePosition); } EmojiPickerTooltip.$element = undefined; EmojiPickerTooltip._listener = undefined; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip.$holder.remove(); }; EmojiPickerTooltip.toggleWhenClick = function (trigger, adaptor) { var res = { trigger: trigger, adaptor: adaptor, currentSession: undefined, }; function clickHandler(event) { if (res.currentSession === EmojiPickerTooltip._session) return; res.currentSession = EmojiPickerTooltip.show(res.adaptor.getFlowedElement ? res.adaptor.getFlowedElement() : trigger, res.adaptor.onSelect, res.adaptor.orientation || 'auto' ); if (res.adaptor.onOpen) res.adaptor.onOpen(); var finish = function (event) { if (event && ((0,EventEmitter/* hitElement */.EY)(EmojiPickerTooltip.$tooltip.$leftBtn, event) || (0,EventEmitter/* hitElement */.EY)(EmojiPickerTooltip.$tooltip.$rightBtn, event)) || (event && event.target && event.target.classList.contains('absol-tooltip-content'))) return; document.body.removeEventListener('click', finish, false); EmojiPickerTooltip.close(res.currentSession); if (adaptor.onClose) adaptor.onClose(); res.currentSession = undefined; if (EmojiPickerTooltip._scrollOutListener === EmojiPickerTooltip) EmojiPickerTooltip._scrollOutListener = undefined; }; EmojiPickerTooltip._scrollOutListener = finish; setTimeout(function () { document.body.addEventListener('click', finish, false); }, 10); } res.remove = function () { trigger.removeEventListener('click', clickHandler, false); trigger.classList.remove('as-emoji-picker-tooltip-trigger'); }; trigger.addEventListener('click', clickHandler, false); trigger.classList.add('as-emoji-picker-tooltip-trigger'); return res; }; /* harmony default export */ const js_EmojiPickerTooltip = (EmojiPickerTooltip); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/emojicounter.css var emojicounter = __webpack_require__(8364); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/emojiuserlisttooltip.css var emojiuserlisttooltip = __webpack_require__(9864); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EmojiUserListTooltip.js var EmojiUserListTooltip_ = ACore/* default._ */.Z._; var EmojiUserListTooltip_$ = ACore/* default.$ */.Z.$; /*** * @augments ToolTip * @augments AElement * @constructor */ function EmojiUserListTooltip() { this._text = null; this._users = []; this.$sprite = EmojiUserListTooltip_({ tag: 'sprite', class: 'as-emoji-user-list-tooltip-emoji', props: { fps: 30, loop: true }, on: { ready: function () { this.frames = { type: 'grid', col: 1, row: this.texture.naturalHeight / this.texture.naturalWidth }; } } }); this.appendChild(this.$sprite); this.text = '(heart)' this.user = []; } EmojiUserListTooltip.tag = 'EmojiUserListTooltip'.toLowerCase(); EmojiUserListTooltip.render = function () { return EmojiUserListTooltip_({ tag: 'tooltip', class: 'as-emoji-user-list-tooltip' }, true); }; EmojiUserListTooltip.prototype._updateUsers = function () { var thisT = this; this.$content.clearChild(); this._users.forEach(function (user) { var elt = EmojiUserListTooltip_({ class: 'as-emoji-user-list-tooltip-user', child: [ { class: 'as-emoji-user-list-tooltip-avatar', style: { backgroundImage: 'url(' + user.avatar + ')' } }, { class: 'as-emoji-user-list-tooltip-name', child: { text: user.name } } ] }); if (user.onclick) { elt.addClass('as-clickable'); elt.on('click', user.onclick.bind(user)); } thisT.$content.addChild(elt); }) }; EmojiUserListTooltip.prototype.playEmoji = function () { this.$sprite.afterReady().then(this.$sprite.play.bind(this.$sprite)); }; EmojiUserListTooltip.prototype.stopEmoji = function () { this.$sprite.stop(); }; EmojiUserListTooltip.property = {}; EmojiUserListTooltip.property.users = { set: function (users) { this._users = users || []; this._updateUsers(); }, get: function () { return this._users; } }; EmojiUserListTooltip.property.text = { set: function (value) { if (value === this._text) return; var icon = js_EmojiPickerTooltip.emojiDict[value]; if (!value) return; var url = EmojiPicker/* default.assetRoot */.Z.assetRoot + '/anim/x60/' + icon.imageFileName; this._text = value; this.$sprite.src = url; }, get: function () { return this._text; } }; ACore/* default.install */.Z.install(EmojiUserListTooltip); /* harmony default export */ const js_EmojiUserListTooltip = ((/* unused pure expression or super */ null && (EmojiUserListTooltip))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EmojiCounter.js var EmojiCounter_$ = ACore/* default.$ */.Z.$; var EmojiCounter_ = ACore/* default._ */.Z._; var EmojiCounter_isMobile = BrowserDetector/* default.isMobile */.Z.isMobile; /*** * @extends AElement * @constructor */ function EmojiCounter() { /*** * * @type {Sprite} */ this.$sprite = EmojiCounter_$('sprite', this); this.$num = EmojiCounter_$('.as-emoji-counter-num', this); this.$numText = this.$num.firstChild; this._text = '(heart)'; this.text = this._text; this._count = 0; this.count = 0; this._checkInterval = -1; if (EmojiCounter_isMobile) { this.attr('tabindex', '1'); this.on('focus', this.eventHandler.mouseEnter); } else { this.on('mouseenter', this.eventHandler.mouseEnter); } this._tooltipSession = null; this._tooltipFinishTimeout = -1; } EmojiCounter.tag = 'EmojiCounter'.toLowerCase(); EmojiCounter.render = function () { var icon = js_EmojiPickerTooltip.emojiDict["(heart)"]; var url = EmojiPicker/* default.assetRoot */.Z.assetRoot + '/anim/x40/' + icon.imageFileName; return EmojiCounter_({ class: 'as-emoji-counter', child: [ { tag: 'sprite', class: 'as-emoji-counter-sprite', props: { src: url, loop: true, fps: 30, debug: true }, on: { ready: function () { this.frames = { type: 'grid', col: 1, row: this.texture.naturalHeight / this.texture.naturalWidth }; this.frameIndex = 0; } } }, { tag: 'span', class: 'as-emoji-counter-num', child: { text: '0' } } ] } ); }; EmojiCounter.property = {}; EmojiCounter.property.text = { set: function (value) { var icon = js_EmojiPickerTooltip.emojiDict[value]; if (!icon) return; if (this._text === value) return; this.$sprite.src = EmojiPicker/* default.assetRoot */.Z.assetRoot + '/anim/x40/' + icon.imageFileName; this._text = value; }, get: function () { return this._text; } }; EmojiCounter.property.count = { set: function (value) { this.$numText.data = value + ''; if (value === 1 && this._count != 1) { this.$numText.remove(); } else if (value != 1 && this._count == 1) { this.$num.addChild(this.$numText); } if (value == 0) this.addClass('as-zero'); else this.removeClass('as-zero'); this._count = value; }, get: function () { return this._count; } } ACore/* default.install */.Z.install(EmojiCounter); EmojiCounter.eventHandler = {}; EmojiCounter.eventHandler.loop = function () { if (!this.isDescendantOf(document.body)) this.eventHandler.finishHover(); if (this.getBoundingClientRect().width === 0) this.eventHandler.finishHover(); }; EmojiCounter.eventHandler.mouseEnter = function () { if (this._tooltipFinishTimeout > 0) { clearTimeout(this._tooltipFinishTimeout); } if (this._checkInterval > 0) return; this.$sprite.play(); this._checkInterval = setInterval(this.eventHandler.loop, 1000); this.on('mouseleave', this.eventHandler.finishHover); if (this.users && this.users.length > 0) { EmojiCounter_prepare(); EmojiCounter._session = Math.random() * 10000000000 >> 0; this._tooltipSession = EmojiCounter._session; EmojiCounter.$element = this; EmojiCounter.$holder.addTo(this); EmojiCounter.$tooltip.text = this.text; EmojiCounter.$tooltip.users = this.users; EmojiCounter.$tooltip.playEmoji(); (0,Tooltip/* updateTooltipPosition */.J)(EmojiCounter); } }; EmojiCounter.eventHandler.finishHover = function () { if (this._tooltipFinishTimeout > 0) { clearTimeout(this._tooltipFinishTimeout); } this._tooltipFinishTimeout = setTimeout(function () { this._tooltipFinishTimeout = -1; this.$sprite.stop(); this.off('mouseleave', this.eventHandler.finishHover); if (this._checkInterval > 0) { clearInterval(this._checkInterval); this._checkInterval = -1; } if (this._tooltipSession === EmojiCounter._session) { EmojiCounter._session = Math.random() * 10000000000 >> 0; EmojiCounter.$holder.remove(); EmojiCounter.$tooltip.stopEmoji(); } }.bind(this), 500); }; function EmojiCounter_prepare() { if (EmojiCounter.$holder) return; EmojiCounter.$holder = EmojiCounter_('.absol-tooltip-root-holder'); EmojiCounter.$tooltip = EmojiCounter_('EmojiUserListTooltip.top'.toLowerCase()).addTo(EmojiCounter.$holder); EmojiCounter._scrollOutListener = undefined; EmojiCounter._orientation = 'top'; EmojiCounter._session = Math.random() * 10000000000 >> 0; js_EmojiPickerTooltip._listener = undefined; EmojiCounter.$element = null; EmojiCounter.$tooltip.$arrow.updateSize = EmojiCounter.updatePosition; } EmojiCounter.updatePosition = function () { if (!EmojiCounter.$element) return; var outBound = Rectangle/* default.fromClientRect */.Z.fromClientRect((0,Dom/* traceOutBoundingClientRect */.DI)(EmojiCounter.$element)); var eBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(EmojiCounter.$element.getBoundingClientRect()); if (!outBound.isCollapse(eBound, 0)) { js_EmojiPickerTooltip._scrollOutListener && EmojiCounter._scrollOutListener(); } (0,Tooltip/* updateTooltipPosition */.J)(EmojiCounter); }; EmojiCounter.updatePosition = EmojiCounter.updatePosition.bind(EmojiCounter); /* harmony default export */ const js_EmojiCounter = (EmojiCounter); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EmojiCounterList.js var EmojiCounterList_ = ACore/* default._ */.Z._; var EmojiCounterList_$ = ACore/* default.$ */.Z.$; /*** * @extends AElement * @constructor */ function EmojiCounterList() { this._counters = []; this.counters = []; } EmojiCounterList.tag = 'EmojiCounterList'.toLowerCase(); EmojiCounterList.render = function () { return EmojiCounterList_({ class: 'as-emoji-counter-list' }); }; EmojiCounterList.iconOrdering = js_EmojiPickerTooltip.defaultIcons.reduce(function (ac, cr, idx) { ac[cr] = idx + 1; return ac; }, {}); EmojiCounterList.prototype._updateCounters = function () { var newCounters = this._counters; var newCounterNameArr = Object.keys(newCounters); newCounterNameArr.sort(function (a, b) { return (EmojiCounterList.iconOrdering[a] || 1000) - (EmojiCounterList.iconOrdering[b] || 1000); }) var counterElements = Array.prototype.filter.call(this.childNodes, function (e) { return e.hasClass && e.hasClass('as-emoji-counter'); }); var newCounterElements = []; var elt, name; var oe, on; while (counterElements.length > 0 || newCounterNameArr.length > 0) { elt = counterElements[0]; name = newCounterNameArr[0]; if (elt && name) { if (elt.text === name) { newCounterElements.push(elt); counterElements.shift(); newCounterNameArr.shift(); } else { oe = EmojiCounterList.iconOrdering[elt.text]; on = EmojiCounterList.iconOrdering[name]; if (oe < on) { newCounterElements.push(elt); counterElements.shift(); } else { newCounterElements.push(name); newCounterNameArr.shift(); } } } else if (elt) { newCounterElements.push(elt); counterElements.shift(); } else { newCounterElements.push(name); newCounterNameArr.shift(); } } var cElt, prevElt; while (newCounterElements.length > 0) { cElt = newCounterElements.pop(); if (typeof cElt === "string") { cElt = EmojiCounterList_({ tag: 'emojicounter', props: { text: cElt, users: newCounters[cElt].users || [], count: newCounters[cElt].count } }); if (!prevElt) { this.addChild(cElt); } else { this.addChildBefore(cElt, prevElt); } prevElt = cElt; } else { if (newCounters[cElt.text]) { cElt.count = newCounters[cElt.text].count; cElt.users = newCounters[cElt.text].users || []; prevElt = cElt; } else { cElt.remove(); } } } }; EmojiCounterList.property = {}; EmojiCounterList.property.counters = { set: function (counters) { this._counters = Object.keys(counters || {}).reduce(function (ac, key) { var counter = counters[key]; if (typeof counter === "object") { if (counter.count > 0 && js_EmojiPickerTooltip.emojiDict[key]) { ac[key] = counter; } } return ac; }, {}) this._updateCounters(); }, get: function () { return this._counters; } } ACore/* default.install */.Z.install(EmojiCounterList); /* harmony default export */ const js_EmojiCounterList = (EmojiCounterList); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/rotatedtext.css var rotatedtext = __webpack_require__(1854); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/RotatedText.js /*** * @extends AElement * @constructor */ function RotatedText() { this.$attachHook = (0,ACore.$)('attachhook', this); this.$attachHook.requestUpdateSize = this.eventHandler.positionChange; this.$attachHook.on('attached', this.eventHandler.attached); this.$anchor = (0,ACore.$)('.as-rotated-text-anchor', this); this.$content = (0,ACore.$)('.as-rotated-text-content', this); this.$contentText = this.$content.firstChild; this.$trackElts = []; this._angle = 0; this.angle = 0; this.text = ''; this._trackInterval = -1; } RotatedText.tag = 'RotatedText'; RotatedText.render = function () { return (0,ACore._)({ tag: 'span', class: 'as-rotated-text', child: [ 'attachhook', { class:'as-rotated-text-anchor', child: { tag: 'span', class: 'as-rotated-text-content', child: { text: '' } } } ] }); }; RotatedText.prototype._trackPosition = function () { this._cancelTrackPosition(); var parent = this.parentElement; while (parent) { parent.addEventListener('scroll', this.eventHandler.positionChange); this.$trackElts.push(parent); parent = parent.parentElement; } document.addEventListener('scroll', this.eventHandler.positionChange); this.$trackElts.push(document); this._trackInterval = setInterval(this.eventHandler.intervalCheck, 3000); }; RotatedText.prototype._cancelTrackPosition = function () { if (this._trackInterval >= 0) { clearInterval(this._trackInterval); this._trackInterval = -1; } while (this.$trackElts.length > 0) { this.$trackElts.pop().removeEventListener('scroll', this.eventHandler.positionChange); } }; RotatedText.property = {}; RotatedText.property.text = { get: function () { return this.$contentText.data; }, set: function (value) { value = value || ''; value = value + ''; this.$contentText.data = value; } }; RotatedText.property.angle = { set: function (value) { value = value || 0; var matched; if (typeof value === 'number') { this._angle = value; this.$content.addStyle('transform', 'rotate(' + value + 'deg)'); } else if (value.match) { matched = value.match(/([0-9.+\-e]+)deg/); if (matched) { value = parseFloat(matched[1]); if (isFinite(value)) { this._angle = value; this.$content.addStyle('transform', 'rotate(' + this._angle + 'deg)'); } return; } matched = value.match(/([0-9.+\-e]+)rad/); if (matched) { value = parseFloat(matched[1]); if (isFinite(value)) { this._angle = value * 180 / Math.PI; this.$content.addStyle('transform', 'rotate(' + this._angle + 'deg)'); } } } }, get: function () { return this._angle; } }; RotatedText.eventHandler = {}; RotatedText.eventHandler.attached = function () { ResizeSystem/* default.add */.Z.add(this); this.eventHandler.positionChange(); this.$content.addStyle('transform-origin',Math.round(0.3 * this.$content.getFontSize()) + 'px 50%'); this._trackPosition(); }; RotatedText.eventHandler.detached = function () { this._cancelTrackPosition(); }; RotatedText.eventHandler.intervalCheck = function () { if (!this.isDescendantOf(document.body)) { this.eventHandler.detached(); } } RotatedText.eventHandler.positionChange = function () { var bound = this.getBoundingClientRect(); this.$anchor.addStyle({ top: Math.round(bound.top) + 'px', left: Math.round(bound.left) + 'px' }); }; ACore/* default.install */.Z.install(RotatedText); /* harmony default export */ const js_RotatedText = (RotatedText); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/verticaltreediagram.css var verticaltreediagram = __webpack_require__(7817); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/VerticalTreeDiagram.js function VerticalTreeDiagramNode() { this.$childCtn = (0,ACore.$)('.as-vertical-tree-diagram-child-ctn', this); this.$name = (0,ACore.$)('.as-vertical-tree-diagram-node-name', this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$name.firstChild, 'name', 'data'); this.name = "UndefinedNodeName"; } VerticalTreeDiagramNode.tag = 'VerticalTreeDiagramNode'.toLowerCase(); VerticalTreeDiagramNode.render = function () { return (0,ACore._)({ class: 'as-vertical-tree-diagram-node', child: [ { class: 'as-vertical-tree-diagram-node-name-ctn', child: { class: 'as-vertical-tree-diagram-node-name', child: { text: "" } } }, { class: 'as-vertical-tree-diagram-child-ctn' } ] }); }; ['addChild', 'removeChild', 'clearChild', 'addChildBefore', 'addChildAfter', 'findChildBefore', 'findChildAfter' ].forEach(function (name) { VerticalTreeDiagramNode.prototype[name] = function () { this.$childCtn[name].apply(this.$childCtn, arguments); if (this.$childCtn.childNodes.length > 0) { this.addClass('as-has-child'); if (this.$childCtn.childNodes.length === 1) { this.addClass('as-has-1-child'); } else { this.removeClass('as-has-1-child'); } } else { this.removeClass('as-has-child'); this.removeClass('as-has-1-child'); } }; }); function VerticalTreeDiagram(data) { this.data = data || {}; } VerticalTreeDiagram.tag = 'VerticalTreeDiagram'.toLowerCase(); VerticalTreeDiagram.render = function () { return (0,ACore._)(VerticalTreeDiagramNode.tag, true); } VerticalTreeDiagram.property = {}; VerticalTreeDiagram.property.data = { set: function (data) { data = data || {}; this._data = data; function makeNode(nodeData) { return (0,ACore._)({ tag: VerticalTreeDiagramNode.tag, props: { name: nodeData.name }, child: (nodeData.child && nodeData.child.length > 0 && nodeData.child.map(makeNode)) || [] }); } this.name = data.name + ''; this.clearChild(); if (data.child) this.addChild(data.child.map(makeNode)); }, get: function () { return this._data; } }; ACore/* default.install */.Z.install(VerticalTreeDiagramNode); ACore/* default.install */.Z.install(VerticalTreeDiagram); /* harmony default export */ const js_VerticalTreeDiagram = (VerticalTreeDiagram); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tokenfield.css var tokenfield = __webpack_require__(5347); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TokenField.js /*** * @extends AElement * @constructor */ function TokenField() { this.on('click', this.eventHandler.click); this.$input = (0,ACore.$)('input', this) .on('keydown', this.eventHandler.inputKeyDown) .on('focus', this.eventHandler.inputInteract) .on('click', this.eventHandler.inputInteract) .on('keydown', this.eventHandler.inputInteract); this.$attachhook = (0,ACore.$)('attachhook', this) .on('attached', function () { ResizeSystem/* default.add */.Z.add(this); this.requestUpdateSize(); }); this.$attachhook.requestUpdateSize = this.updateSize.bind(this); /*** * * @type {SelectListBox} */ this.$selectlistBox = (0,ACore._)({ tag: 'selectlistbox', props: { anchor: [1, 6, 2, 5] }, on: { preupdateposition: this.eventHandler.preUpdateListPosition } }); this.$selectlistBox.on('pressitem', this.eventHandler.selectListBoxPressItem); this.$selectlistBox.sponsorElement = this; this.autocomplete = null; this.separator = ' '; this.placeHolder = ''; } TokenField.tag = 'TokenField'.toLowerCase(); TokenField.render = function () { return (0,ACore._)({ class: 'as-token-field', extendEvent: ['change'], child: [ { tag: 'input', class: 'as-token-field-input-text', attr: { type: 'text', tabindex: '1' } }, 'attachhook' ] }); }; TokenField.prototype._makeItem = function (text) { var itemElt = (0,ACore._)({ tag: js_SelectBoxItem.tag, class: 'as-token-field-item', attr: { tabindex: 1 }, props: { data: { text: text, value: text } } }); itemElt.on({ keydown: this.eventHandler.itemKeyDown.bind(this, itemElt), close: this.eventHandler.itemClose.bind(this, itemElt), focus: this.eventHandler.itemFocus.bind(this, itemElt) }); return itemElt; }; TokenField.prototype._appendItem = function (itemElt) { this.addChildBefore(itemElt, this.$input); }; TokenField.prototype._updateInputWidth = function () { var lastItem = this.findChildBefore(this.$input); if (lastItem) { var lastItemBound = lastItem.getBoundingClientRect(); var bound = this.getBoundingClientRect(); var aRight = bound.right - 4 - lastItemBound.right; if (aRight > 60) { this.$input.addStyle('width', aRight + 'px'); } else { this.$input.addStyle('width', '100%'); } } else { this.$input.addStyle('width', '100%'); } }; TokenField.prototype._isSeparatorKey = function (key) { if (key === 'Enter') return true; if (this.separator === ' ') return key === ' '; if (this.separator === '\n') return key === 'Enter'; if (this.separator === '\t') return key === 'Tab'; return key === this.separator; }; TokenField.prototype.updateSize = function () { this._updateInputWidth(); }; TokenField.prototype._notifyChange = function (data) { this.emit('change', Object.assign({ type: 'change', target: this }, data), this); }; TokenField.prototype._searchInList = function () { if (this._searchTimeout > 0) { clearTimeout(this._searchTimeout); } this._searchTimeout = setTimeout(function () { var text = this.$input.value; if (this.$selectlistBox.isDescendantOf(document.body)) { this.$selectlistBox.$searchInput.value = text; this.$selectlistBox.eventHandler.searchModify(); if (this.$selectlistBox._displayItems.length === 0) { this.$selectlistBox.addStyle('visibility', 'hidden'); } else { this.$selectlistBox.removeStyle('visibility'); } } }.bind(this), 100); } TokenField.eventHandler = {}; TokenField.property = {}; TokenField.property.separator = { set: function (value) { if (typeof value !== "string") value = ' '; this._separator = value; }, get: function () { return this._separator; } }; TokenField.property.placeHolder = { set: function (value) { this.$input.attr('placeholder', value || ''); }, get: function () { return this.$input.attr('placeholder'); } }; TokenField.property.items = { set: function (items) { items = items || []; while (this.firstChild && this.firstChild && this.firstChild.hasClass('as-token-field-item')) { this.firstChild.remove(); } for (var i = 0; i < items.length; ++i) { this._appendItem(this._makeItem(items[i])); } }, get: function () { return Array.prototype.slice.call(this.childNodes).filter(function (elt) { return elt.hasClass && elt.hasClass('as-token-field-item'); }).map(function (elt) { return elt.data.value; }); } }; TokenField.property.autocomplete = { set: function (value) { this._autocomplete = value || null; if (this._autocomplete) { this.$selectlistBox.items = this._autocomplete.map(function (it) { return { value: it + '', text: it + '' }; }); } else { this.$selectlistBox.items = []; } }, get: function () { return this._autocomplete; } } TokenField.eventHandler.inputKeyDown = function (event) { if (this._isSeparatorKey(event.key)) { var text = this.$input.value; if (text.length > 0) { this.$input.value = ''; var newItem = this._makeItem(text); this._appendItem(newItem); this.updateSize(); this._notifyChange({ action: 'add', item: text, itemElt: newItem }); this.eventHandler.inputOut(); } event.preventDefault(); } else if (event.key.startsWith('Arrow') || event.key === 'Backspace') { if (this.$input.selectionStart === 0 && this.$input.selectionEnd === 0) { if (event.key === 'ArrowLeft' || event.key === 'Backspace') { event.preventDefault(); var prevChild = this.findChildBefore(this.$input); if (prevChild) prevChild.focus(); } else if (event.key === 'ArrowUp') { var item, itemBound; var inputBound = this.$input.getBoundingClientRect(); var anchorPos = new Vec2/* default */.Z(inputBound.left + 5, inputBound.top + inputBound.height / 2); var minDis = Infinity; var dis; var aboveItem; for (var i = 0; i < this.childNodes.length; ++i) { item = this.childNodes[i]; if (item.hasClass && item.hasClass('as-token-field-item')) { itemBound = item.getBoundingClientRect(); if (itemBound.bottom < inputBound.top) { dis = new Vec2/* default */.Z(itemBound.left + itemBound.width / 2, itemBound.top + itemBound.height / 2) .sub(anchorPos) .abs(); if (dis < minDis) { minDis = dis aboveItem = item; } } } } if (aboveItem) { aboveItem.focus(); event.preventDefault(); } } } else { this._searchInList(); } } else { this._searchInList(); } }; TokenField.eventHandler.inputInteract = function (event) { var lt = this._lastInteractTime; this._lastInteractTime = new Date().getTime(); if (lt && (this._lastInteractTime - lt < 100)) { return; } if (this.$selectlistBox.isDescendantOf(document.body)) return; this.$selectlistBox.addTo(document.body); this.$selectlistBox.followTarget = this; this._searchInList(); var bound = this.getBoundingClientRect(); this.$selectlistBox.addStyle('min-width', bound.width + 'px'); this.$selectlistBox.refollow(); this.$selectlistBox.updatePosition(); setTimeout(document.addEventListener.bind(document, 'click', this.eventHandler.inputOut), 100) }; TokenField.eventHandler.inputOut = function (event) { if (event && ((0,EventEmitter/* hitElement */.EY)(this.$selectlistBox, event) || (0,EventEmitter/* hitElement */.EY)(this.$input, event))) return; document.removeEventListener('click', this.eventHandler.inputOut); this.$selectlistBox.selfRemove(); this.$selectlistBox.followTarget = null; this._lastInteractTime = new Date().getTime(); }; TokenField.eventHandler.itemKeyDown = function (itemElt, event) { var nextElt; if (event.key === 'Delete' || event.key === 'Backspace') { if (event.key === 'Delete') { nextElt = this.findChildAfter(itemElt); } else { nextElt = this.findChildBefore(itemElt) || this.$input; } itemElt.remove(); this._notifyChange({ item: itemElt.data.value, action: 'remove', itemElt: itemElt }); if (nextElt === this.$input) { this.$input.focus(); (0,Text.setCaretPosition)(this.$input, 0); } else { nextElt.focus(); } } else if (event.key === 'ArrowLeft') { nextElt = this.findChildBefore(itemElt); if (nextElt) nextElt.focus(); } else if (event.key === 'ArrowRight') { nextElt = this.findChildAfter(itemElt); if (nextElt === this.$input) { this.$input.focus(); (0,Text.setCaretPosition)(this.$input, 0); } else { nextElt.focus(); } } else if (event.key === 'ArrowUp' || event.key === 'ArrowDown') { var currentItemBound = itemElt.getBoundingClientRect(); var center = new Vec2/* default */.Z(currentItemBound.left + currentItemBound.width / 2, currentItemBound.top + currentItemBound.height / 2); var childElt, itemBound, dis; var minDis = Infinity; var i; if (event.key === 'ArrowUp') { for (i = 0; i < this.childNodes.length; ++i) { childElt = this.childNodes[i]; if (childElt.hasClass && childElt.hasClass('as-token-field-item') || childElt === this.$input) { itemBound = childElt.getBoundingClientRect(); if (itemBound.bottom < currentItemBound.top) { dis = new Vec2/* default */.Z(itemBound.left + itemBound.width / 2, itemBound.top + itemBound.height / 2) .sub(center) .abs(); if (dis < minDis) { minDis = dis nextElt = childElt; } } } } } else { for (i = 0; i < this.childNodes.length; ++i) { childElt = this.childNodes[i]; if (childElt.hasClass && childElt.hasClass('as-token-field-item') || childElt === this.$input) { itemBound = childElt.getBoundingClientRect(); if (itemBound.top > currentItemBound.bottom) { dis = new Vec2/* default */.Z(itemBound.left + itemBound.width / 2, itemBound.top + itemBound.height / 2) .sub(center) .abs(); if (dis < minDis) { minDis = dis nextElt = childElt; } } } } } if (nextElt) { nextElt.focus(); } } }; TokenField.eventHandler.itemFocus = function (itemElt) { this.eventHandler.inputOut(); }; TokenField.eventHandler.itemClose = function (itemElt) { itemElt.remove(); this._notifyChange({ action: 'remove', item: itemElt.data.value, itemElt: itemElt }); this.$input.focus(); }; TokenField.eventHandler.click = function (event) { if (event.target === this) this.$input.focus(); }; TokenField.eventHandler.preUpdateListPosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$selectlistBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { // this.isFocus = false; // } }; TokenField.eventHandler.selectListBoxPressItem = function (event) { var text = event.data.value; var newItem = this._makeItem(text); this._appendItem(newItem); this.updateSize(); this._notifyChange({ action: 'add', item: text, itemElt: newItem }); this.eventHandler.inputOut(); this.$input.value = ''; setTimeout(()=>{ this.$input.focus(); }, 30); } ACore/* default.install */.Z.install(TokenField); /* harmony default export */ const js_TokenField = (TokenField); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dvexptree.css var dvexptree = __webpack_require__(2265); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DVExpTree.js /*** * @extends ExpTree * @constructor */ function DVExpTree() { this.injectInput(); } DVExpTree.tag = 'DVExpTree'.toLowerCase(); DVExpTree.render = function () { return (0,ACore._)({ tag: ExpTree/* default.tag */.ZP.tag, extendEvent: ['radiochange', 'indexclick'], class: 'as-dv-exp-tree' }, true); }; DVExpTree.prototype.injectInput = function () { this.$radio = (0,ACore._)({ tag: 'radiobutton', on: { change: this.eventHandler.radioChange } }); this.$node.insertBefore(this.$radio, this.$node.$extIcon); this.$index = (0,ACore._)({ tag: 'span', class: 'as-dv-exp-tree-index', on: { click: this.eventHandler.indexClick } }); this.$node.insertBefore(this.$index, this.$node.$desc); this.$node.on('click', this.eventHandler.clickInNode); }; DVExpTree.property = {}; DVExpTree.property.radioName = { enumerable: true, set: function (value) { if (!value) { this.removeClass('as-has-radio'); this.$radio.name = undefined; } else { this.addClass('as-has-radio'); this.$radio.name = value + ''; } }, get: function () { return this.$radio.name; } }; DVExpTree.property.radioValue = { enumerable: true, set: function (value) { this.$radio.value = value; }, get: function () { return this.$radio.value; } }; DVExpTree.property.radioChecked = { enumerable: true, set: function (value) { this.$radio.checked = value; }, get: function () { return this.$radio.checked; } }; DVExpTree.property.hasIndex = { enumerable: true, set: function (value) { if (value) this.addClass('as-has-index-input'); else this.removeClass('as-has-index-input'); }, get: function () { return this.hasClass('as-has-index-input'); } }; DVExpTree.property.indexValue = { enumerable: true, set: function (value) { this.$index.innerHTML = value; }, get: function () { return this.$index.innerHTML; } }; DVExpTree.eventHandler = {}; DVExpTree.eventHandler.radioChange = function (event) { this.emit('radiochange', Object.assign({}, event, { target: this, radioElt: this.$radio }), this); }; DVExpTree.eventHandler.indexClick = function (event) { this.emit('indexclick', Object.assign({}, event, { target: this, indexInput: this.$index }), this); }; DVExpTree.eventHandler.clickInNode = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$index, event) || (0,EventEmitter/* hitElement */.EY)(this.$radio, event) || (0,EventEmitter/* hitElement */.EY)(this.$node.$toggleIcon, event)) return; if ((0,EventEmitter/* hitElement */.EY)(this.$node, event) && this.radioName) this.$radio.click(); }; ACore/* default.install */.Z.install(DVExpTree); /* harmony default export */ const js_DVExpTree = (DVExpTree); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/checklistitem.css var checklistitem = __webpack_require__(1100); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Ref.js var Ref = __webpack_require__(4446); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/Attributes.js /*** * * @param {Object} node * @constructor */ /*** * @typedef {{defined?:function,revoked?:function,get?:function, set?: function, descriptor?: Object|function, export?: function}} AttributeHandler */ /*** * * @param {Object} node * @constructor */ function Attributes(node) { Object.defineProperty(this, '$$node', { enumerable: false, configurable: true, writable: false, value: node }) Object.defineProperty(this, '_definedProperties', { enumerable: false, writable: false, value: {} }); Object.defineProperty(this, '_definedComputedHandlers', { enumerable: false, writable: false, value: {} }); } Object.defineProperty(Attributes.prototype, 'loadAttributeHandlers', { enumerable: false, configurable: true, writable: false, value: function (newHandlers) { var self = this; var definedHandlers = this._definedProperties; var definedComputedHandlers = this._definedComputedHandlers; Object.keys(this._definedProperties).forEach(function (key) { if (!newHandlers[key]) { delete definedHandlers[key]; delete definedComputedHandlers[key]; delete self[key]; } }); Object.keys(newHandlers).forEach(function (key) { if (definedHandlers[key] !== newHandlers[key]) { self.defineProperty(key, newHandlers[key]); } }); } }); Object.defineProperty(Attributes.prototype, 'unloadAttributeHandlers', { enumerable: false, configurable: true, writable: false, value: function (oldHandlers) { var self = this; Object.keys(oldHandlers).forEach(function (key) { self.revokeProperty(key, oldHandlers[key]); }); } }); Object.defineProperty(Attributes.prototype, 'revokeProperty', { enumerable: false, configurable: true, writable: false, value: function (name, handler) { if (!this._definedProperties[name]) return; if (handler && this._definedProperties[name] !== handler) return;//verify if (handler.revoked) { handler.revoked.call(this, this._definedComputedHandlers[name].ref); } var value = this[name]; delete this[name]; this[name] = value; delete this._definedProperties[name]; } }); Object.defineProperty(Attributes.prototype, 'defineProperty', { enumerable: false, configurable: true, writable: false, value: function (name, handler) { var self = this; this._definedProperties[name] = handler; var hadValue = !!(name in this); var privateValueRef = new Ref/* default */.Z(this[name]); var objectDescriptor = { enumerable: true, configurable: true, set: function (value) { if (handler.set) privateValueRef.set(handler.set.apply(self.$$node, Array.prototype.slice.call(arguments).concat([privateValueRef]))); else privateValueRef.set(value); }, get: function () { if (handler.get) return handler.get.apply(self.$$node, Array.prototype.slice.call(arguments).concat([privateValueRef])); else return privateValueRef.get(); } }; Object.defineProperty(this, name, objectDescriptor); this._definedComputedHandlers[name] = objectDescriptor; objectDescriptor.ref = privateValueRef; if (handler.defined) { handler.defined.call(this, privateValueRef); } if (hadValue) this[name] = privateValueRef.get(); } }); Object.defineProperty(Attributes.prototype, 'getProperty', { enumerable: false, configurable: true, writable: false, value: function (name) { var args = Array.prototype.slice.call(arguments, 1); var handler = this._definedComputedHandlers[name]; if (handler) { return handler.get.apply(this, args); } else return this[name]; } }); Object.defineProperty(Attributes.prototype, 'setProperty', { enumerable: false, configurable: true, writable: false, value: function (name, value) { var args = Array.prototype.slice.call(arguments, 1); var handler = this._definedComputedHandlers[name]; if (handler) { return handler.set.apply(this, args); } else this[name] = value; } }); Object.defineProperty(Attributes.prototype, 'export', { enumerable: false, configurable: true, value: function () { var self = this; return Object.keys(this).reduce(function (ac, key) { var value; var handler = self._definedProperties[key]; var computedHandler = self._definedComputedHandlers[key]; var exporter = handler && handler.export; if (exporter) { value = exporter.call(self.$$node, computedHandler.ref); } else { value = self[key] } if (value !== undefined) ac[key] = value; return ac; }, {}); } }); Object.defineProperty(Attributes.prototype, 'getPropertyDescriptor', { enumerable: false, configurable: true, writable: false, value: function (name) { var handler = this._definedProperties[name]; if (handler && (typeof handler.descriptor === 'function')) return handler.descriptor.call(this.$$node); var value = this[name]; return (handler && handler.descriptor) || { type: typeof value } } }); /* harmony default export */ const AppPattern_Attributes = (Attributes); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/SelectListItem.js var SelectListItem = __webpack_require__(6843); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckListItem.js function measureMaxCheckboxTextWidth(items) { var maxTextWidth = 0; var maxText = 0; var maxEst = 0; var maxLv = 0; var est; var text; var item; for (var i = 0; i < items.length; ++i) { item = items[i]; if (item.text) { text = item.text; est = estimateWidth14(text) + 14 * 1.25 * (item.level || 0); if (est > maxEst) { maxEst = est; maxText = text; maxLv = item.level || 0; } } } if (maxText) maxTextWidth = 18 + 14 * (1.25 + 0.35) * maxLv + measureText(maxText, '14px Arial, Helvetica, sans-serif').width + 14;//padding left, right 7px, checkbox 18px return maxTextWidth; } function measureCheckListHeight(items) { var border = 0; var n = items.length - 1; return items.length * 25 + border; } function measureCheckListSize(items) { var descWidth = measureMaxDescriptionWidth(items); var textWidth = measureMaxCheckboxTextWidth(items); var width = textWidth; if (descWidth > 0) { width += descWidth + 14; } var height = measureCheckListHeight(items); return { width: width, height: height, descWidth: descWidth, textWidth: textWidth }; } /*** * @extends SelectListItem * @constructor */ function CheckListItem() { this.$text = (0,ACore.$)('span.absol-selectlist-item-text', this); this.$textValue = this.$text.childNodes[0]; this.$descCtn = (0,ACore.$)('.absol-selectlist-item-desc-container', this); this.$desc = (0,ACore.$)('span.absol-selectlist-item-desc', this.$descCtn); this.$descValue = this.$desc.childNodes[0]; this.$checkbox = (0,ACore.$)(CheckboxButton/* default.tag */.Z.tag, this) .on('change', this.eventHandler.checkboxChange); this.$icon = null; this._icon = null; this._viewData = new AppPattern_Attributes(this); this._viewData.loadAttributeHandlers(this.viewHandlers); OOP/* default.drillProperty */.ZP.drillProperty(this, this._viewData, 'extendClasses'); OOP/* default.drillProperty */.ZP.drillProperty(this, this._viewData, 'extendStyle'); this.level = 0; this.selected = false; this.on('click', this.eventHandler.clickText); } CheckListItem.tag = 'CheckListItem'.toLowerCase(); CheckListItem.render = function () { return (0,ACore._)({ extendEvent: ['select'], class: ['as-check-list-item', "absol-selectlist-item"], child: [ { tag: CheckboxButton/* default.tag */.Z.tag, class: 'as-check-list-item-checkbox' }, { tag: 'span', class: 'absol-selectlist-item-text', child: {text: ''} }, { class: 'absol-selectlist-item-desc-container', child: { tag: 'span', class: 'absol-selectlist-item-desc', child: {text: ''} } } ] }); }; CheckListItem.property = { text: SelectListItem/* default.property.text */.ZP.property.text, value: SelectListItem/* default.property.value */.ZP.property.value, icon: SelectListItem/* default.property.icon */.ZP.property.icon, lastInGroup: SelectListItem/* default.property.lastInGroup */.ZP.property.lastInGroup, }; CheckListItem.property.data = { set: function (value) { this._data = value; var viewData = { text:'', desc: '', noSelect: false, extendStyle: null, extendClasses: null, icon: null, lastInGroup:false }; if (typeof value === 'string') { viewData.text = value } else { Object.assign(viewData, value); } Object.assign(this._viewData, viewData); }, get: function () { return this._data; } }; CheckListItem.property.selected = { set: function (value) { this.$checkbox.checked = !!value; }, get: function () { return this.$checkbox.checked; } }; CheckListItem.property.level = { set: function (value) { value = value || 0; this._level = value; this.$checkbox.addStyle('margin-left', value * 1.75 + 'em'); }, get: function () { return this._level; } }; CheckListItem.prototype.viewHandlers = {}; CheckListItem.prototype.viewHandlers.text = { set: function (value) { this.$textValue.data = value; }, get: function () { return this.$textValue.data; } }; CheckListItem.prototype.viewHandlers.desc = { set: function (value) { this.$descValue.data = value; }, get: function () { return this.$descValue.data; } }; CheckListItem.prototype.viewHandlers.extendClasses = { set: function (value, ref) { var prevVal = ref.get() || []; var i; for (i = 0; i < prevVal.length; ++i) { this.removeClass(prevVal[i]); } var newVal = []; if (typeof value == 'string') value = value.trim().split(/\s+/); value = value || []; for (i = 0; i < value.length; ++i) { newVal.push(value[i]); this.addClass(value[i]); } return newVal; } }; CheckListItem.prototype.viewHandlers.extendStyle = { /*** * * @param value * @param {Ref} ref */ set: function (value, ref) { this.removeStyle(ref.get() || {}); this._extendStyle = Object.assign({}, value || {}); this.addStyle(this._extendStyle); }, get: function () { return this._extendClasses; } }; CheckListItem.prototype.viewHandlers.noSelect = { set: function (value){ if (value) this.addClass('as-no-select'); else this.removeClass('as-no-select'); return value; } }; CheckListItem.prototype.viewHandlers.icon = { set: function (icon){ this.icon = icon; }, get: function (){ return this.icon; } }; CheckListItem.prototype.viewHandlers.lastInGroup = { set: function (value){ this.lastInGroup = value; }, get: function (){ return this.lastInGroup; } } CheckListItem.eventHandler = {}; CheckListItem.eventHandler.clickText = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$checkbox, event)) return; this.$checkbox.checked = !this.$checkbox.checked; this.emit('select', { target: this, type: 'select', originalEvent: event.originalEvent || event.originEvent || event, selected: this.selected }); }; CheckListItem.eventHandler.checkboxChange = function (event) { this.emit('select', { target: this, type: 'select', originalEvent: event.originalEvent || event.originEvent || event, selected: this.selected }); }; ACore/* default.install */.Z.install(CheckListItem); /* harmony default export */ const js_CheckListItem = (CheckListItem); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/checklistbox.css var checklistbox = __webpack_require__(6801); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tool/TextMeasurement.js var TextMeasurement = __webpack_require__(1866); // EXTERNAL MODULE: ./node_modules/absol/src/DataStructure/Array.js var DataStructure_Array = __webpack_require__(7835); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringUtils.js var stringUtils = __webpack_require__(2973); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckListBox.js var CheckListBox_itemPool = []; function CheckListBox_makeItem() { return (0,ACore._)({ tag: js_CheckListItem, on: { select: function (event) { this.$parent.eventHandler.itemSelect(this, event) } } }); } function CheckListBox_requireItem($parent) { var item; if (CheckListBox_itemPool.length > 0) { item = CheckListBox_itemPool.pop(); } else { item = CheckListBox_makeItem(); } item.$parent = $parent; return item; } function CheckListBox_releaseItem(item) { item.$parent = null; item.selected = false; CheckListBox_itemPool.push(item); } function fillItemToPage($parent, $page, n) { while ($page.childNodes.length > n) { CheckListBox_releaseItem($page.lastChild); $page.removeChild($page.lastChild); } while ($page.childNodes.length < n) { $page.addChild(CheckListBox_requireItem($parent)); } } var mTextMeasurement = null; var measureArial14TextWidth = text => { if (!mTextMeasurement) { mTextMeasurement = new TextMeasurement/* default */.Z(); mTextMeasurement.compute('14px arial'); } return mTextMeasurement.measureTextWidth(text, '14px arial'); } var keyStringOfItem = item => { return (0,utils.keyStringOf)(item.value) + (0,stringUtils/* stringHashCode */.$)(item.text + ''); } /*** * TODO: check all duplicate value when select * @extends SelectListBox * @constructor */ function CheckListBox() { if (this.cancelWaiting) this.cancelWaiting(); this._items = []; this._valueDict = {}; this.itemHolders = []; this._holderDict = {}; this._estimateWidth = 100; this.widthLimit = calcWidthLimit(); this.addStyle('--as-width-limit', this.widthLimit + 'px'); this.$scroller = (0,ACore.$)('.as-select-list-box-scroller', this); this.$content = (0,ACore.$)('.as-select-list-box-content', this); this.$pages = (0,ACore.$$)('.as-select-list-box-page', this); this.$searchInput = (0,ACore.$)('searchtextinput', this).on('stoptyping', this.eventHandler.searchModify); this.pagingCtrl = new CLPagingController(this); this.searchMaster = new ListSearchMaster/* default */.Z(); this._initDomHook(); this._initFooter(); this.domSignal.on('viewListAtValue', this.viewListAtValue.bind(this)); this.domSignal.on('viewListAtItem', this.viewListAtItem.bind(this)); /*** * @name selectedAll * @type {boolean} * @memberOf CheckListBox# */ /*** * @name selectedItems * @type {Array<>} * @memberOf CheckListBox# */ } CheckListBox.tag = 'CheckListBox'.toLowerCase(); CheckListBox.render = function () { return (0,ACore._)({ tag: Follower/* default.tag */.Z.tag, extendEvent: ['change', 'cancel', 'close'], attr: { tabindex: 0 }, class: ['as-select-list-box', 'as-check-list-box'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller'], child: [ { class: 'as-select-list-box-content', child: Array(3).fill('.as-select-list-box-page') } ] }, { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { 'data-ml-key': 'txt_cancel' } }, { tag: 'a', class: 'as-select-list-box-close-btn', attr: { 'data-ml-key': 'txt_close' } }] } ] }, 'attachhook.as-dom-signal' ], props: { anchor: [1, 6, 2, 5] } }); }; Object.assign(CheckListBox.prototype, js_SelectListBox.prototype); CheckListBox.property = {}; CheckListBox.eventHandler = {}; CheckListBox.prototype.footerMinWidth = 110; CheckListBox.prototype.revokeResource = function () { this.searchMaster.revokeResource(); }; CheckListBox.prototype._initDomHook = function () { this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('viewListAt', this.viewListAt.bind(this)); this.domSignal.on('viewListAtFirstSelected', this.viewListAtFirstSelected.bind(this)); this.domSignal.on('viewListAtCurrentScrollTop', this.viewListAtCurrentScrollTop.bind(this)); this.domSignal.on('updateCheckedAll', () => { this.$checkAll.checked = this.selectedAll; }); }; CheckListBox.prototype._initFooter = function () { this.$checkAll = (0,ACore.$)('.as-select-list-box-check-all', this) .on('change', this.eventHandler.checkAllChange); this.$cancelBtn = (0,ACore.$)('.as-select-list-box-cancel-btn', this) .on('click', this.eventHandler.clickCancelBtn); this.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this); if (this.$closeBtn)//mobile ref this.$closeBtn.on('click', this.eventHandler.clickCloseBtn); }; CheckListBox.prototype.viewListAtFirstSelected = noop/* default */.Z; CheckListBox.prototype.viewListAtValue = function (value) { if (this.isDescendantOf(document.body)) { this.pagingCtrl.viewListAtValue(value); } }; CheckListBox.prototype.viewListAtItem = function (item) { if (this.isDescendantOf(document.body)) { this.pagingCtrl.viewListAtItem(item); } }; /** * wrong function name * @deprecated * @param value * @returns {*} */ CheckListBox.prototype.findItemsByValue = function (value) { return this._holderDict[(0,utils.keyStringOf)(value)]; }; CheckListBox.prototype.findItemHoldersByValue = function (value) { return this._holderDict[(0,utils.keyStringOf)(value)]; }; CheckListBox.prototype.findItemByValue = function (value) { var holders = this._holderDict[(0,utils.keyStringOf)(value)]; if (holders && holders.length > 0) { return holders[0].item; } else return null; }; /** * * @param {number | Array<number>}idx */ CheckListBox.prototype.getItemByIndex = function (idx) { var arr = this._items; if (!Array.isArray(idx)) { idx = [idx]; } for (var i = 0; i < idx.length; ++i) { if (!arr) return null; if (i + 1 === idx.length) return arr[idx[i]]; arr = arr[idx[i]].items; } }; CheckListBox.prototype.notifyChange = function (data) { this.emit('change', Object.assign({ target: this, type: 'change' }, data), this); } CheckListBox.prototype.focus = js_SelectListBox.prototype.focus; CheckListBox.property.values = { set: function (values) { values = values || []; var dict = values.reduce((ac, cr) => { var key = (0,utils.keyStringOf)(cr); ac[key] = cr; return ac; }, {}); this._valueDict = dict; this.itemHolders.forEach(function visit(holder) { holder.selected = (holder.valueKey in dict); if (holder.children) holder.children.forEach(visit); }); this.pagingCtrl.updateSelected(); this.domSignal.emit('updateCheckedAll'); }, get: function () { var values = this.itemHolders.reduce(function visit(ac, holder) { if (holder.selected && !holder.data.noSelect) ac.push(holder.data.value); if (holder.children) holder.children.reduce(visit, ac); return ac; }, []); return (0,DataStructure_Array.arrayUnique)(values); } }; CheckListBox.property.selectedIndexes = { set: function (indexes) { if (!Array.isArray(indexes)) indexes = []; }, get: function () { var genVisit = (rootValue) => { return (ac, holder, i) => { if (holder.selected && !holder.data.noSelect) { if (rootValue) ac.push(rootValue.concat([i])); else ac.push(i); } if (holder.children) holder.children.reduce(genVisit((rootValue || []).concat([i])), ac); return ac; } }; return this.itemHolders.reduce(genVisit(), []); } }; CheckListBox.property.selectedItems = { get: function () { return this.selectedIndexes.map((idx) => this.getItemByIndex(idx)).filter(it => !!it); } }; CheckListBox.prototype.resetSearchState = function () { this.$searchInput.value = ''; this.pagingCtrl.viewArr(this.itemHolders); }; CheckListBox.property.enableSearch = js_SelectListBox.property.enableSearch; CheckListBox.property.items = { set: function (items) { items = items || []; items = (0,utils.copySelectionItemArray)(items, { removeNoView: true, removeNewLine: true }); this._items = items; this.itemHolders = items.map(it => new CLHolder(this, it)); var res = this.itemHolders.reduce(function visit(ac, cr) { var textWidth = 3.5 * 14 + 1.75 * 14 * cr.level + 14 + measureArial14TextWidth(cr.data.text + '') + 7 + 17 if (cr.data.icon) textWidth += 32; ac.textWidth = Math.max(ac.textWidth, textWidth); if (cr.data.desc) { ac.descWidth = Math.max(ac.descWidth, measureArial14TextWidth(cr.data.desc + '')); } ac.dict[cr.valueKey] = ac.dict[cr.valueKey] || []; ac.dict[cr.valueKey].push({ idx: ac.idx++, item: cr.data, holder: cr }); if (cr.children) cr.children.reduce(visit, ac); return ac; }, { idx: 0, dict: {}, textWidth: 50, descWidth: 0 }); this._holderDict = res.dict; this._estimateWidth = Math.min(this.widthLimit || Infinity, res.textWidth + (res.descWidth ? res.descWidth + 30 : 0)); this.addStyle('--select-list-estimate-width', this._estimateWidth + 'px'); this.$scroller.scrollTop = 0; this.pagingCtrl.viewArr(this.itemHolders); this.searchMaster.transfer(this.itemHolders.map(it => it.getSearchItem())); this.domSignal.emit('updateCheckedAll'); }, get: function () { return (0,utils.copySelectionItemArray)(this._items); } }; CheckListBox.property.selectedAll = { get: function () { return this.itemHolders.length > 0 && this.itemHolders.every(function visit(holder) { var res = holder.selected || holder.data.noSelect; if (res && holder.children) { res = holder.children.every(visit); } return res; }); } }; /*** * @this CheckListBox * @param event */ CheckListBox.eventHandler.checkAllChange = function (event) { var checked = this.$checkAll.checked; var changed = false; var visit = (holder) => { var canCheck = checked && !holder.data.noSelect; if (holder.selected !== canCheck) { changed = true; holder.selected = canCheck; } if (canCheck) { this._valueDict[holder.valueKey] = holder.data.value; } else { delete this._valueDict[holder.valueKey]; } if (holder.children) holder.children.forEach(visit); } this.itemHolders.forEach(visit); this.pagingCtrl.updateSelected(); if (changed) { this.notifyChange({ originalEvent: event.originalEvent || event.originEvent || event, action: checked ? 'check_all' : "uncheck_all" }, this); } }; /*** * @this CheckListBox * @param itemElt * @param event */ CheckListBox.eventHandler.itemSelect = function (itemElt, event) { var selected = itemElt.selected; var holder = itemElt.clHolder; holder.selected = selected; if (selected) { this._valueDict[holder.valueKey] = holder.data.value; } else { delete this._valueDict[holder.valueKey]; } this.$checkAll.checked = this.selectedAll; this.notifyChange({ originalEvent: event.originalEvent || event.originEvent || event, action: selected ? 'check' : 'uncheck', value: holder.data.value, itemData: holder.data }); this.domSignal.emit('updateCheckedAll'); }; /*** * @this CheckListBox * @param event */ CheckListBox.eventHandler.clickCancelBtn = function (event) { this.emit('cancel', { type: 'cancel', target: this, originalEvent: event }, this); }; /*** * @this CheckListBox * @param event */ CheckListBox.eventHandler.clickCloseBtn = function (event) { this.emit('close', { type: 'close', target: this, originalEvent: event }, this); }; /** * @this {CheckListBox} */ CheckListBox.eventHandler.searchModify = function () { var text = this.$searchInput.value; if (text) { this.searchMaster.query({ text: text }).then(result => { if (text !== this.$searchInput.value) return; if (!result) return;//why? var arr = this.itemHolders.filter(it => !!result[it.id]); arr.sort((a, b) => result[b.id][1] - result[a.id][1]); var searchHolders = arr.map(holder => new CLHolderRef(this, holder, null, result)); this.$scroller.scrollTop = 0; this.pagingCtrl.viewArr(searchHolders); ResizeSystem/* default.update */.Z.update(); }); } else { this.pagingCtrl.viewArr(this.itemHolders.reduce((ac, holder) => holder.toArray(ac), [])); ResizeSystem/* default.update */.Z.update(); } }; ACore/* default.install */.Z.install(CheckListBox); /** * @param boxElt * @param data * @param parent * @constructor */ function CLHolder(boxElt, data, parent) { this.id = (0,stringGenerate.randomIdent)(8); this.parent = parent; this.level = parent ? parent.level + 1 : 0; this.boxElt = boxElt; this.data = data; (0,OOP/* drillProperty */.pj)(this, this, 'item', 'data');//adapt mobile and desktop this.valueKey = (0,utils.keyStringOf)(data.value); this.itemKey = keyStringOfItem(data); this.itemElt = null; this.children = null; this.selected = this.valueKey in boxElt._valueDict; var Clazz = this.constructor; if (data.items && data.items.length > 0) { this.children = data.items.map(it => new Clazz(boxElt, it, this)); } } CLHolder.prototype.toArray = function (ac) { ac = ac || []; ac.push(this); if (this.children) this.children.reduce((ac, holder) => holder.toArray(ac), ac); return ac; }; CLHolder.prototype.toDictionary = function (ac) { ac = ac || {}; ac[this.valueKey] = this; if (this.children) this.children.reduce((ac, holder) => holder.toDictionary(ac), ac); return ac; }; CLHolder.prototype.attachView = function (itemElt) { if (itemElt.clHolder) itemElt.clHolder.detachView(); if (!this.textLength) this.textLength = (0,utils.measureText)(this.data.text + '', '14px arial').width; if (this.textLength > this.boxElt.widthLimit - (0.7 + 2.5) * 14) { itemElt.attr('title', this.data.text); } itemElt.clHolder = this; this.itemElt = itemElt; itemElt.data = this.data; itemElt.level = this.level; itemElt.selected = this.selected; }; CLHolder.prototype.detachView = function () { if (this.itemElt) { this.itemElt.attr('title', null); this.itemElt.clHolder = null; this.itemElt = null; } }; CLHolder.prototype.getSearchItem = function () { var res = { value: this.id }; res.text = this.data.text + ''; if (this.data.desc) res.text += '/' + this.data.desc; if (this.children) res.items = this.children.map(c => c.getSearchItem()) return res; }; function CLHolderRef(boxElt, origin, parent, result) { this.boxElt = boxElt; this.origin = origin; this.data = origin.data; this.parent = parent; this.level = origin.level; OOP/* default.drillProperty */.ZP.drillProperty(this, origin, 'selected'); var Clazz = this.constructor; var arr, children; if (origin.children) { arr = origin.children.filter(it => !!result[it.id]); arr.sort((a, b) => result[b.id][1] - result[a.id][1]); children = arr.map(holder => new Clazz(boxElt, holder, this, result)); if (children.length > 0) this.children = children; } } OOP/* default.mixClass */.ZP.mixClass(CLHolderRef, CLHolder); /*** * * @param {CheckListBox} boxElt * @constructor */ function CLPagingController(boxElt) { this.boxElt = boxElt; this.$pages = boxElt.$pages; this.$content = boxElt.$content; this.$scroller = boxElt.$scroller.on('scroll', this.ev_scroll.bind(this)); this.itemPerPage = Math.ceil((0,Dom/* getScreenSize */.tE)().height / this.itemHeight * 2); this.holderArr = []; this.holderDict = {}; } CLPagingController.prototype.itemHeight = 30; CLPagingController.prototype.ev_scroll = function (event) { if (this.pageN <= 2) return; var top = this.$scroller.scrollTop; var pageIdx = Math.min(this.pageN - 1, Math.max(0, Math.floor(top / this.itemHeight / this.itemPerPage))); if (pageIdx === this.pageIdx) return; if (pageIdx === this.pageIdx - 1) { this.pageIdx = pageIdx; this.$pages.unshift(this.$pages.pop()); if (pageIdx > 0) { this.$pages[0].removeStyle('display').addStyle('top', (pageIdx - 1) * this.itemPerPage * this.itemHeight + 'px'); fillItemToPage(this.boxElt, this.$pages[0], this.itemPerPage); Array.prototype.forEach.call(this.$pages[0].childNodes, (elt, i) => this.holderArr[(pageIdx - 1) * this.itemPerPage + i].attachView(elt)); } else { this.$pages[0].addStyle('display', 'none'); } } else if (pageIdx === this.pageIdx + 1) { this.pageIdx = pageIdx; this.$pages.push(this.$pages.shift()); if (pageIdx + 1 < this.pageN) { this.$pages[2].removeStyle('display').addStyle('top', (pageIdx + 1) * this.itemPerPage * this.itemHeight + 'px'); fillItemToPage(this.boxElt, this.$pages[2], Math.min(this.itemPerPage, this.holderArr.length - this.itemPerPage * (pageIdx + 1))); Array.prototype.forEach.call(this.$pages[2].childNodes, (elt, i) => this.holderArr[(pageIdx + 1) * this.itemPerPage + i].attachView(elt)); } else { this.$pages[2].addStyle('display', 'none'); } } else { this.update(); } }; CLPagingController.prototype.update = function () { var top = this.$content.scrollTop; var pageIdx = Math.floor(top / this.itemHeight / this.itemPerPage); this.pageIdx = pageIdx; var ii = (pageIdx - 1) * this.itemPerPage; var pageElt; var itemInPage; for (var pi = 0; pi < 3; ++pi) { pageElt = this.$pages[pi]; if (ii < 0 || ii >= this.holderArr.length) { ii += this.itemPerPage; pageElt.addStyle('display', 'none'); } else { itemInPage = Math.min(this.itemPerPage, this.holderArr.length - ii); fillItemToPage(this.boxElt, pageElt, itemInPage); pageElt.removeStyle('display').addStyle('top', this.itemHeight * ii + 'px'); Array.prototype.forEach.call(pageElt.childNodes, (child, i) => { this.holderArr[ii].attachView(child); ii++; }); } } }; CLPagingController.prototype.viewListAtIdx = function (idx) { var bound = this.$scroller.getBoundingClientRect(); if (!bound.height) return; var y = idx * this.itemHeight; var maxY = this.holderArr.length * this.itemHeight - bound.height; this.$scroller.scrollTop = Math.min(maxY, y); }; CLPagingController.prototype.viewListAtValue = function (value) { var idx = this.holderDict[(0,utils.keyStringOf)(value)]; if (idx === undefined) return; this.viewListAtIdx(idx); }; CLPagingController.prototype.viewListAtItem = function (item) { var idx = this.holderHashDict[keyStringOfItem(item)]; if (idx === undefined) return; this.viewListAtIdx(idx); }; CLPagingController.prototype.viewArr = function (itemHolders) { this.holderArr = itemHolders.reduce((ac, holder) => holder.toArray(ac), []); this.holderDict = this.holderArr.reduce((ac, cr, idx) => { if (!(0,utils.isNaturalNumber)(ac[cr.valueKey])) ac[cr.valueKey] = idx; return ac; }, {}); this.holderHashDict = this.holderArr.reduce((ac, cr, idx) => { ac[cr.itemKey] = idx; return ac; }, {}); this.pageN = Math.ceil(this.holderArr.length / this.itemPerPage); this.$content.addStyle('height', this.holderArr.length * this.itemHeight + 'px'); this.update(); }; CLPagingController.prototype.updateSelected = function () { this.$pages.forEach(pageElt => { Array.prototype.forEach.call(pageElt.childNodes, itemElt => { if (itemElt.clHolder) itemElt.selected = itemElt.clHolder.selected; }); }); }; /**********************************************************************************************************************/ /*** * @extends SelectListBox * @constructor */ function CheckListBoxV1() { this._initDomHook(); this._initControl(); this._initScroller(); this._initFooter(); this._initProperty(); this.domSignal.on('viewListAtValue', this.viewListAtValue.bind(this)); } CheckListBoxV1.tag = 'CheckListBox'.toLowerCase(); CheckListBoxV1.render = function () { return (0,ACore._)({ tag: Follower/* default.tag */.Z.tag, extendEvent: ['change', 'cancel', 'close'], attr: { tabindex: 0 }, class: ['as-select-list-box', 'as-check-list-box'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller'], child: [ { class: 'as-select-list-box-content', child: Array(this.prototype.preLoadN).fill('.as-select-list-box-page') } ] }, { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { 'data-ml-key': 'txt_cancel' } }, { tag: 'a', class: 'as-select-list-box-close-btn', attr: { 'data-ml-key': 'txt_close' } }] } ] }, 'attachhook.as-dom-signal' ], props: { anchor: [1, 6, 2, 5] } }); }; Object.assign(CheckListBoxV1.prototype, js_SelectListBox.prototype); CheckListBoxV1.property = Object.assign({}, js_SelectListBox.property); CheckListBoxV1.eventHandler = Object.assign({}, js_SelectListBox.eventHandler); CheckListBoxV1.prototype.itemHeightMode = [25, 30]; CheckListBoxV1.prototype.itemHeight = 25; CheckListBoxV1.prototype.footerMinWidth = 110; CheckListBoxV1.prototype._initFooter = function () { this.$checkAll = (0,ACore.$)('.as-select-list-box-check-all', this) .on('change', this.eventHandler.checkAllChange); this.$cancelBtn = (0,ACore.$)('.as-select-list-box-cancel-btn', this) .on('click', this.eventHandler.clickCancelBtn); this.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this); if (this.$closeBtn)//mobile ref this.$closeBtn.on('click', this.eventHandler.clickCloseBtn); }; CheckListBoxV1.prototype._requireItem = function (pageElt, n) { var itemElt; while (pageElt.childNodes.length > n) { itemElt = pageElt.lastChild; itemElt.selfRemove(); CheckListBox_releaseItem(itemElt); } while (pageElt.childNodes.length < n) { itemElt = CheckListBox_requireItem(this); pageElt.addChild(itemElt); } }; CheckListBoxV1.prototype.viewListAtFirstSelected = noop/* default */.Z; CheckListBoxV1.prototype.viewListAtValue = function (value) { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('viewListAtValue', value); return; } if (this._displayValue === VALUE_HIDDEN) { return false; } var itemHolders = this._displayItemHolderByValue[value + '']; if (itemHolders) { this.domSignal.once('scrollIntoValue', function () { var holder = itemHolders[0]; this.viewListAt(holder.idx); var itemElt = (0,ACore.$)('.as-check-list-item', this.$listScroller, function (elt) { return elt.value === value; }); if (itemElt) { var scrollBound = this.$listScroller.getBoundingClientRect(); var itemBound = itemElt.getBoundingClientRect(); this.$listScroller.scrollTop += itemBound.top - scrollBound.top; } }.bind(this)); this.domSignal.emit('scrollIntoValue'); return true; } else return false; }; CheckListBoxV1.prototype.focus = js_SelectListBox.prototype.focus; CheckListBoxV1.property.values = { set: function (value) { js_SelectListBox.property.values.set.apply(this, arguments); this.$checkAll.checked = this._values.length === this.items.length; }, get: js_SelectListBox.property.values.get }; /*** * @this CheckListBoxV1 * @param event */ CheckListBoxV1.eventHandler.checkAllChange = function (event) { var checked = this.$checkAll.checked; if (checked) { this._values = this.items.map(function (cr) { return typeof cr === "object" ? cr.value : cr; }); this._valueDict = this._values.reduce(function (ac, value) { ac[value + ''] = true; return ac; }, {}); } else { this._values = []; this._valueDict = {}; } this._updateSelectedItem(); this.emit('change', { target: this, type: 'change', originalEvent: event.originalEvent || event.originEvent || event, action: checked ? 'check_all' : "uncheck_all" }, this); }; /*** * @this CheckListBoxV1 * @param itemElt * @param event */ CheckListBoxV1.eventHandler.itemSelect = function (itemElt, event) { var selected = itemElt.selected; var value = itemElt.value; var itemData = itemElt.data; var idx; if (selected) { this._values.push(value); this._valueDict[value + ''] = true; } else { idx = this._values.indexOf(value); delete this._valueDict[value + '']; if (idx >= 0) { this._values.splice(idx, 1); } else { console.error("Violation data"); } } this.emit('change', { target: this, type: 'change', originalEvent: event.originalEvent || event.originEvent || event, action: selected ? 'check' : 'uncheck', value: value, itemData: itemData }, this); }; /*** * @this CheckListBoxV1 * @param event */ CheckListBoxV1.eventHandler.clickCancelBtn = function (event) { this.emit('cancel', { type: 'cancel', target: this, originalEvent: event }, this); }; /*** * @this CheckListBoxV1 * @param event */ CheckListBoxV1.eventHandler.clickCloseBtn = function (event) { this.emit('close', { type: 'close', target: this, originalEvent: event }, this); }; ACore/* default.install */.Z.install('checklistboxv1', CheckListBoxV1); /* harmony default export */ const js_CheckListBox = ((/* unused pure expression or super */ null && (CheckListBoxV1))); // EXTERNAL MODULE: ./node_modules/absol/src/JSX/attribute.js + 1 modules var attribute = __webpack_require__(2953); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/MultiLanguageCSS.js var MultiLanguageCSS = __webpack_require__(1812); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/MSelectListItem.js /*** * * @extends {AElement} * @constructor */ function MSelectListItem() { this.$textCtn = (0,ACore.$)('.am-selectlist-item-text-ctn', this); this.$text = (0,ACore.$)('span.am-selectlist-item-text', this); this.$textValue = this.$text.childNodes[0]; this.$descCtn = (0,ACore.$)('.am-selectlist-item-desc-ctn', this); this.$desc = (0,ACore.$)('span.am-selectlist-item-desc', this.$descCtn); this.$descValue = this.$desc.childNodes[0]; this._extendClasses = []; this._extendStyle = {}; this._data = ""; this._level = 0; } MSelectListItem.tag = 'MSelectListItem'.toLowerCase(); MSelectListItem.render = function () { return (0,ACore._)({ class: 'am-selectlist-item', child: [ { class: 'am-selectlist-item-text-ctn', child: { tag: 'span', class: 'am-selectlist-item-text', child: { text: '' } } }, { class: 'am-selectlist-item-desc-ctn', child: { tag: 'span', class: 'am-selectlist-item-desc', child: { text: '' } } } ] }); } MSelectListItem.property = Object.assign({}, SelectListItem/* default.property */.ZP.property); MSelectListItem.property.icon = { set: function (icon) { if (this.$icon) { this.$icon.remove(); this.$icon = null; } this._icon = icon || null; if (this._icon) { this.$icon = (0,ACore._)(this._icon).addClass('am-selectlist-item-icon'); this.$textCtn.addChildAfter(this.$icon, null); } }, get: function () { return this._icon; } }; /* harmony default export */ const selectlistbox_MSelectListItem = (MSelectListItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multicheckmenu/MChecklistItem.js /**** * @extends MSelectListItem * @constructor */ function MChecklistItem() { this.$checkbox = (0,ACore.$)('.am-selectlist-item-check-ctn > '+CheckboxButton/* default.tag */.Z.tag, this) .on('change', this.eventHandler.checkboxChange); selectlistbox_MSelectListItem.call(this); this.on('click', this.eventHandler.clickText); } MChecklistItem.tag = 'MChecklistItem'.toLowerCase(); MChecklistItem.property = Object.assign({}, selectlistbox_MSelectListItem.property); MChecklistItem.render = function () { return (0,ACore._)({ extendEvent:['change', 'select'], class: 'am-selectlist-item', child: [ { class: 'am-selectlist-item-check-ctn', child: { tag: CheckboxButton/* default.tag */.Z.tag } }, { class: 'am-selectlist-item-text-ctn', child: { tag: 'span', class: 'am-selectlist-item-text', child: {text: ''} } }, { class: 'am-selectlist-item-desc-ctn', child: { tag: 'span', class: 'am-selectlist-item-desc', child: {text: ''} } } ] }); }; MChecklistItem.eventHandler = {}; MChecklistItem.eventHandler.clickText = js_CheckListItem.eventHandler.clickText MChecklistItem.eventHandler.checkboxChange = js_CheckListItem.eventHandler.checkboxChange; MChecklistItem.property.selected = js_CheckListItem.property.selected; ACore/* default.install */.Z.install(MChecklistItem); /* harmony default export */ const multicheckmenu_MChecklistItem = (MChecklistItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/MSelectList.js function measureListSize(items) { var descWidth = (0,SelectList/* measureMaxDescriptionWidth */.jG)(items); var textWidth = (0,SelectList/* measureMaxTextWidth */.up)(items); var width = descWidth + 20 + textWidth + 12 + 15;//padding, margin return { width: width, descWidth: descWidth, textWidth: textWidth }; } var MSelectList_itemPool = []; function onClickItem(event) { var thisSL = this.$parent; if (thisSL) { thisSL.value = this.value; thisSL.emit('pressitem', { type: 'pressitem', target: thisSL, itemElt: this, value: this.value, data: this.data }); } } /** * @returns {MSelectListItem} */ function MSelectList_makeItem() { return (0,ACore._)({ tag: selectlistbox_MSelectListItem, on: { click: onClickItem } }); } function MSelectList_requireItem($parent) { var item; if (MSelectList_itemPool.length > 0) { item = MSelectList_itemPool.pop(); } else { item = MSelectList_makeItem(); } item.$parent = $parent; return item; } function MSelectList_releaseItem(item) { item.$parent = null; item.attr('class', 'am-selectlist-item'); item.selected = false; MSelectList_itemPool.push(item); } /*global absol*/ /*** * @extends AElement * @constructor */ function MSelectList() { var res = this; this.defineEvent(['pressitem', 'cancelasync', 'valuevisibilityasync', 'finishasync', 'sizechangeasync']); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.sync = new Promise(function (rs) { res.$attachhook.once('error', rs); }); this.$items = []; this.$itemByValue = {};//quick find element this.$selectedItem = undefined; this._itemSession = 0; this._finished = true; this._resourceReady = true; }; MSelectList.tag = "MSelectList".toLowerCase(); MSelectList.render = function () { return (0,ACore._)('.am-selectlist'); }; //todo: update this feature to SelectList /*** * * @param value * @return {MSelectListItem|null} */ MSelectList.prototype.getItemElementByValue = function (value) { return this.$itemByValue[value + ''] || null; }; MSelectList.prototype._updateSelectedItem = function () { var newSelectedItemElt = this.$itemByValue[this._selectValue + '']; if (newSelectedItemElt !== this.$selectedItem) { if (this.$selectedItem) { this.$selectedItem.removeClass('selected'); } if (newSelectedItemElt) { newSelectedItemElt.addClass('selected'); this.$selectedItem = newSelectedItemElt; } } }; MSelectList.prototype._requireItems = function (itemCout) { var item; while (this.$items.length < itemCout) { item = MSelectList_requireItem(this); this.$items.push(item); this.addChild(item); } while (this.$items.length > itemCout) { item = this.$items.pop(); item.remove(); MSelectList_releaseItem(item); } }; MSelectList.prototype._assignItems = function (from, to) { var foundSelected = false; var itemElt; var item; for (var i = from; i < to; ++i) { itemElt = this.$items[i]; item = this._items[i]; itemElt.data = item; itemElt.__index__ = i; if (this.$itemByValue[item.value + '']) { console.warn('Value ' + this.$items[i].value + ' is duplicated!'); } else { this.$itemByValue[item.value + ''] = itemElt; if (this._selectValue == item.value) { itemElt.selected = true; this.$selectedItem = itemElt; foundSelected = true; } else { itemElt.selected = false; } } } return foundSelected; }; MSelectList.prototype.setItemsAsync = function (items) { //start process this._finished = false; var session = Math.floor(Math.random() * 1000000); this._itemSession = session; this._items = items || []; this.$itemByValue = {}; this.measuredSize = measureListSize(items); var thisSL = this; var i = 0; var limit = 20; function tick() { if (thisSL._itemSession != session) { thisSL.emit('cancelasync', { session: session, type: 'cancelasync' }, this); return; } if (i >= items.length) { thisSL._updateSelectedItem(); thisSL._finished = false; thisSL.emit('finishasync', { session: session, type: 'finishasync' }, this); return; } var n = Math.min(items.length - i, limit); var itemCout = i + n; thisSL._requireItems(itemCout); i = itemCout; var foundSelected = thisSL._assignItems(itemCout - n, itemCout); if (foundSelected) { thisSL.emit('valuevisibilityasync', { session: session, type: 'valuevisibilityasync', itemElt: thisSL.$items[i] }, thisSL); } thisSL.emit('sizechangeasync', { session: session, type: 'sizechangeasync' }, this); setTimeout(tick, 2); } setTimeout(tick, 2); return Object.assign({ session: session }, this.measuredSize); }; MSelectList.prototype.setItems = function (items) { this._finished = false; var session = Math.floor(Math.random() * 1000000); this._itemSession = session; this._items = items || []; this.$itemByValue = {}; this.measuredSize = measureListSize(items); var itemCount = items.length; this._requireItems(itemCount); this._assignItems(0, itemCount); this._finished = true; return Object.assign({ session: this._itemSession }, this.measuredSize); }; MSelectList.property = Object.assign({}, SelectList/* default.property */.ZP.property); MSelectList.prototype.init = SelectList/* default.prototype.init */.ZP.prototype.init; MSelectList.eventHandler = {}; /* harmony default export */ const selectlistbox_MSelectList = ((/* unused pure expression or super */ null && (MSelectList))); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextMeasure.js + 1 modules var TextMeasure = __webpack_require__(2610); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/list/search.js var search = __webpack_require__(2551); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/MListModal.js var MListModal_VALUE_HIDDEN = -1; var MListModal_VALUE_NORMAL = 1; /*** * @extends AElement * @constructor */ function MListModal() { this._initDomHook(); this._initControl(); this._initScroller(); this._initProperty(); } MListModal.tag = "MListModal".toLowerCase(); MListModal.render = function () { return (0,ACore._)({ extendEvent: ['pressitem', 'pressclose', 'pressout'], class: 'am-list-modal', child: [ { class: ['am-list-popup-box'], child: [ { class: 'am-list-popup-header', child: [ { tag: 'searchtextinput' }, { tag: 'button', class: 'am-list-popup-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: 'am-list-popup-list-scroller', child: { class: 'am-list-popup-content', child: Array(MListModal.prototype.preLoadN).fill('.am-list-popup-list-page.am-selectlist') } } ] } ] }); }; MListModal.prototype.toLoadNextY = 200; MListModal.prototype.preLoadN = 5; MListModal.prototype._initDomHook = function () { this.estimateSize = { width: 0 }; this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$attachhook._isAttached = false; this.$attachhook.requestUpdateSize = this.updateSize.bind(this); this.$attachhook.on('attached', function () { Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); this.requestUpdateSize(); this._isAttached = true; }); this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('viewListAt', this.viewListAt.bind(this)); this.domSignal.on('viewListAtFirstSelected', this.viewListAtFirstSelected.bind(this)); this.searchMaster = new ListSearchMaster/* default */.Z(); }; MListModal.prototype.cancelWaiting = function () { this.$attachhook.cancelWaiting(); } MListModal.prototype._initControl = function () { this._currentOffset = 0; this._startItemIdx = 0; this.$closeBtn = (0,ACore.$)('.am-list-popup-close-btn', this) .on('click', this.notifyPressClose.bind(this)); this.on('click', this.eventHandler.click); this.$box = (0,ACore.$)('.am-list-popup-box', this); this.$searchInput = (0,ACore.$)('searchtextinput', this) .on('stoptyping', this.eventHandler.searchModify); }; MListModal.prototype._initScroller = function () { this._estimateHeight = 0; this._pageOffsets = Array(this.preLoadN + 1).fill(0); this._pageYs = Array(this.preLoadN + 1).fill(0); this.$listScroller = (0,ACore.$)('.am-list-popup-list-scroller', this) .on('scroll', this.eventHandler.scroll); this.$content = (0,ACore.$)('.am-list-popup-content', this); this.$listPages = (0,ACore.$$)('.am-list-popup-list-page', this); }; MListModal.prototype._initProperty = function () { this._items = []; this._values = []; this._valueDict = {}; this._itemsByValue = {}; this._preDisplayItems = []; this._displayItems = []; this._searchCache = {}; this._displayValue = MListModal_VALUE_NORMAL; this.displayValue = MListModal_VALUE_NORMAL; this.items = []; }; MListModal.prototype.findItemsByValue = function (value) {//keep return this._itemsByValue[(0,utils.keyStringOf)(value)]; }; MListModal.prototype.updateSize = function () { var bound = this.getBoundingClientRect(); var boxBound = this.$box.getBoundingClientRect(); var listScrollerBound = this.$listScroller.getBoundingClientRect(); this.$listScroller.addStyle('max-height', 'calc(' + (bound.height - listScrollerBound.top + boxBound.top) + 'px - var(--modal-margin-bottom) - var(--modal-margin-top))'); }; MListModal.prototype._requireItem = function (pageElt, n) { var itemElt; while (pageElt.childNodes.length > n) { itemElt = pageElt.lastChild; itemElt.selfRemove(); MSelectList_releaseItem(itemElt); } while (pageElt.childNodes.length < n) { itemElt = MSelectList_requireItem(this); pageElt.addChild(itemElt); } }; MListModal.prototype._listToDisplay = function (items) {//keep return items; }; /*** * * @param {Array<{value:String|Number}>} items * @return {Array<{value:String|Number}>} */ MListModal.prototype._filterValue = function (items) { if (this._displayValue === MListModal_VALUE_NORMAL) return items; var dict = this._valueDict; return items.filter(function (item) { return !dict[item.value + '']; }); }; MListModal.prototype._assignItems = function (pageElt, offset) { var n = Math.min(this._displayItems.length - offset, pageElt.childNodes.length); var itemElt, value; for (var i = 0; i < n; ++i) { itemElt = pageElt.childNodes[i]; itemElt.data = this._displayItems[offset + i]; value = itemElt.value + ''; } }; MListModal.prototype._alignPage = function () { var pageElt; var pageBound; for (var i = 0; i < this.$listPages.length; ++i) { pageElt = this.$listPages[i]; pageBound = pageElt.getBoundingClientRect(); if (i > 0) this.$listPages[i].addStyle('top', this._pageYs[i] + 'px'); this._pageYs[i + 1] = this._pageYs[i] + pageBound.height; } this.$content.addStyle('height', this._pageYs[this.preLoadN] + 'px'); }; MListModal.prototype._updateSelectedItem = function () { var valueDict = this._valueDict; this.$listPages.forEach(function (pageElt) { Array.prototype.forEach.call(pageElt.childNodes, function (itemElt) { var value = itemElt.value + ''; if (valueDict[value]) { itemElt.selected = true; } else { itemElt.selected = false; } }); }); if (this._displayValue === MListModal_VALUE_HIDDEN) this._alignPage(); }; MListModal.prototype.viewListAt = function (offset) { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('viewListAt', offset); return; } var fontSize = this.$listScroller.getFontSize() || 14; offset = Math.max(0, Math.min(offset, this._displayItems.length - 1)); var screenSize = Dom/* default.getScreenSize */.ZP.getScreenSize(); var maxItem = Math.ceil(screenSize.height / (fontSize * 2.25)); var contentBound = this.$content.getBoundingClientRect(); this._pageOffsets[0] = Math.max(offset - maxItem, 0); for (var i = 1; i <= this.preLoadN; ++i) { this._pageOffsets[i] = Math.min(this._pageOffsets[i - 1] + maxItem, this._displayItems.length); } var sIdx, nItem, pageBound; var pageElt; for (var pageIndex = 0; pageIndex < this.preLoadN; ++pageIndex) { sIdx = this._pageOffsets[pageIndex]; nItem = this._pageOffsets[pageIndex + 1] - sIdx; pageElt = this.$listPages[pageIndex]; if (pageIndex === 0) { this._pageYs[pageIndex] = sIdx / this._displayItems.length * contentBound.height; } pageElt.addStyle('top', this._pageYs[pageIndex] + 'px'); this._requireItem(pageElt, nItem); this._assignItems(pageElt, sIdx); pageBound = pageElt.getBoundingClientRect(); this._pageYs[pageIndex + 1] = this._pageYs[pageIndex] + pageBound.height; } if (this._pageOffsets[this.preLoadN] === this._displayItems.length) { this.$content.addStyle('height', this._pageYs[this.preLoadN] + 'px'); } else { this.$content.addStyle('height', this._estimateHeight + 'px'); } this._updateSelectedItem(); }; MListModal.prototype.viewListAtFirstSelected = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('viewListAtFirstSelected'); return; } if (this._displayValue == MListModal_VALUE_HIDDEN) { return false; } else if (this._values.length > 0) { var value = this._values[0]; var itemHolders = this._itemHolderByValue[value + '']; if (itemHolders) { this.domSignal.once('scrollIntoSelected', function () { var holder = itemHolders[0]; this.viewListAt(holder.idx); var itemElt = (0,ACore.$)('.as-selected', this.$listScroller); if (itemElt) { var scrollBound = this.$listScroller.getBoundingClientRect(); var itemBound = itemElt.getBoundingClientRect(); this.$listScroller.scrollTop += itemBound.top - scrollBound.top; } }.bind(this)); this.domSignal.emit('scrollIntoSelected'); return true; } else return false; } else return false; }; MListModal.prototype.searchItemByText = js_SelectListBox.prototype.searchItemByText; MListModal.prototype.prepareSearch = js_SelectListBox.prototype.prepareSearch; MListModal.prototype.resetSearchState = function () { this.$searchInput.value = ''; this._preDisplayItems = this._listToDisplay(this._items); this._displayItems = this._filterValue(this._preDisplayItems); this._updateItemIndex(); this.domSignal.emit('viewListAt', 0); this.$listScroller.scrollTop = 0; }; MListModal.prototype.notifyPressOut = function () { this.emit('pressout', { target: this, type: 'pressout' }, this); }; MListModal.prototype.notifyPressClose = function () { this.emit('pressclose', { target: this, type: 'pressclose' }, this); }; MListModal.prototype._findFirstPageIdx = function () { for (var i = 0; i < this.preLoadN; ++i) { if (this._pageOffsets[i + 1] - this._pageOffsets[i] > 0) { return i; } } return -1; }; MListModal.prototype._findLastPageIdx = function () { for (var i = this.preLoadN - 1; i >= 0; --i) { if (this._pageOffsets[i + 1] - this._pageOffsets[i] > 0) { return i; } } return -1; }; MListModal.prototype._updateItemIndex = function () { this._itemHolderByValue = this._displayItems.reduce(function (ac, cr, idx) { var value = typeof cr === "string" ? cr : cr.value + ''; ac[value] = ac[value] || []; ac[value].push({ idx: idx, item: cr }); return ac; }, {}); }; MListModal.property = {}; /*** * * @type {MListModal} */ MListModal.property.items = { get: function () { return this._items; }, set: function (items) { items = items || []; if (!Array.isArray(items)) items = [];//no items = (0,utils.copySelectionItemArray)(items) this._items = items; this._preDisplayItems = this._listToDisplay(this._items); this._displayItems = this._filterValue(this._preDisplayItems); this._itemsByValue = items.reduce(function reducer(ac, cr) { var key = (0,utils.keyStringOf)(cr.value); if (!ac[key]) ac[key] = []; else console.error("Duplicate value", cr); ac[key].push(cr); if (cr.items && cr.items.reduce) cr.items.reduce(reducer, ac); return ac; }, {}); this._updateItemIndex(); /*****************/ this.idx2key = []; var makeSearchItem = it => { var res = { value: this.idx2key.length }; var valueKey; res.text = it.text + ''; if (it.desc) res.text += it.desc; valueKey = (0,utils.keyStringOf)(it.value); it.keyValue = valueKey; this.idx2key.push(valueKey); if (it.items && it.items.length > 0 && it.items.map) { res.items = it.items.map(makeSearchItem); } return res; }; this.searchingItems = this._items.map(makeSearchItem); this.key2idx = this.idx2key.reduce((ac, cr, i) => { ac[cr] = i; return ac; }, {}); this.searchMaster.transfer(this.searchingItems); /*****************/ this._searchCache = {}; var estimateSize = measureListSize(this._preDisplayItems); if (estimateSize.descWidth > 0) { this.$listScroller.addStyle('--desc-width', 100 * (estimateSize.descWidth + 15) / (estimateSize.width) + '%'); } else { this.$listScroller.removeStyle('--desc-width'); } var estimateHeight = this._displayItems.length * 30 * Math.ceil(estimateSize.width * 1.2 / Math.min(Dom/* default.getScreenSize */.ZP.getScreenSize().width - 80, 500)); this._estimateHeight = estimateHeight; this.$content.addStyle('height', estimateHeight + 'px'); this.estimateSize = estimateSize; this.domSignal.emit('viewListAt', 0); } }; MListModal.property.values = { set: function (values) { values = values || []; values = values.slice(); this._values = values; this._valueDict = values.reduce(function (ac, cr) { ac[cr + ''] = true; ac[(0,utils.keyStringOf)(cr)] = cr; return ac; }, {}); this._displayItems = this._filterValue(this._preDisplayItems); this._updateItemIndex(); //todo if (this._pageOffsets[this.preLoadN] > this._pageOffsets[0]) this._updateSelectedItem(); }, get: function () { return this._values; } }; MListModal.property.displayValue = { set: function (value) { this._displayValue = value; this._displayItems = this._filterValue(this._preDisplayItems); this._updateItemIndex(); if (value === MListModal_VALUE_HIDDEN) { this.addClass('am-value-hidden'); } else { this.removeClass('am-value-hidden'); } }, get: function () { return this._displayValue; } } MListModal.property.enableSearch = { set: function (value) { if (value) this.$box.addClass('am-enable-search'); }, get: function () { return this.$box.removeClass('am-enable-search'); } }; /*** * * @type {MListModal} */ MListModal.eventHandler = {}; /*** * * @param {MouseEvent} event */ MListModal.eventHandler.click = function (event) { if (event.target === this) this.notifyPressOut(); }; MListModal.eventHandler.searchModify = function () { var text = this.$searchInput.value; var searchSession = Math.random() + ''; this._seachSession = searchSession; this.searchItemByText(text).then(searchedItems => { if (this._seachSession !== searchSession) return; this._preDisplayItems = this._listToDisplay(searchedItems); this._displayItems = this._filterValue(this._preDisplayItems); this._updateItemIndex(); this.viewListAt(0); this.$listScroller.scrollTop = 0; }); }; MListModal.eventHandler.scroll = function () { var scrollerBound = this.$listScroller.getBoundingClientRect(); var topIdx = this._findFirstPageIdx(); var fontSize = this.$listScroller.getFontSize() || 14; var screenSize = Dom/* default.getScreenSize */.ZP.getScreenSize(); var maxItem = Math.ceil(screenSize.height / (fontSize * 2.25)); var pageBound; var topBound = this.$listPages[topIdx].getBoundingClientRect(); if (this._pageOffsets[topIdx] > 0) { if (topBound.top + this.toLoadNextY > scrollerBound.top) { this._pageOffsets.unshift(this._pageOffsets.pop()); this._pageYs.unshift(this._pageYs.pop()); this.$listPages.unshift(this.$listPages.pop()); this._pageOffsets[topIdx] = Math.max(0, this._pageOffsets[topIdx + 1] - maxItem); this._requireItem(this.$listPages[topIdx], this._pageOffsets[topIdx + 1] - this._pageOffsets[topIdx]); this._assignItems(this.$listPages[topIdx], this._pageOffsets[topIdx]); pageBound = this.$listPages[topIdx].getBoundingClientRect(); this._pageYs[topIdx] = this._pageYs[topIdx + 1] - pageBound.height; this.$listPages[topIdx].addStyle('top', this._pageYs[topIdx] + 'px'); this._updateSelectedItem(); if (this._pageOffsets[topIdx] === 0) { this.$listPages[0].addStyle('top', '0'); this._pageYs[0] = 0; this._alignPage(); this.$listScroller.scrollTop = 0; } } } else { if (topBound.top > scrollerBound.top) { this.$listScroller.scrollTop += topBound.top - scrollerBound.top; } } var botIdx = this._findLastPageIdx(); var botBound; botBound = this.$listPages[botIdx].getBoundingClientRect(); if (this._pageOffsets[botIdx + 1] < this._displayItems.length) { if (botBound.bottom - this.toLoadNextY < scrollerBound.bottom) { this._pageOffsets.push(this._pageOffsets.shift()); this._pageYs.push(this._pageYs.shift()); this.$listPages.push(this.$listPages.shift()); this._pageOffsets[botIdx + 1] = Math.min(this._displayItems.length, this._pageOffsets[botIdx] + maxItem); this.$listPages[botIdx].addStyle('top', this._pageYs[botIdx] + 'px'); this._requireItem(this.$listPages[botIdx], this._pageOffsets[botIdx + 1] - this._pageOffsets[botIdx]); this._assignItems(this.$listPages[botIdx], this._pageOffsets[botIdx]); pageBound = this.$listPages[botIdx].getBoundingClientRect(); this._pageYs[botIdx + 1] = this._pageYs[botIdx] + pageBound.height; this._updateSelectedItem(); if (this._pageOffsets[botIdx + 1] < this._displayItems.length) { this.$content.addStyle('height', this._estimateHeight + 'px'); } else { this.$content.addStyle('height', this._pageYs[botIdx + 1] + 'px'); } } } }; /* harmony default export */ const selectlistbox_MListModal = (MListModal); ACore/* default.install */.Z.install('mlistmodal', MListModal); Dom/* default.ShareInstance.install */.ZP.ShareInstance.install('mlistmodal', MListModal); /** * @extends AElement * @constructor */ function MListModalV2() { this.estimateSize = { textWidth: 0, descWidth: 0 }; this.itemHolders = []; this.itemHolderByValue = {}; this.screenSize = (0,Dom/* getScreenSize */.tE)(); this.pagingCtrl = new MLMPagingController(this); this.layoutCtrl = new MLMLayoutController(this); this.on('pressitem', this.eventHandler.selectItem); this._value = undefined; this.selectedHolder = null; this.searchCtrl = new MLMSearchController(this); this.$closeBtn = (0,ACore.$)('.am-list-popup-close-btn', this) this.on('click', this.eventHandler.click); this.$closeBtn.on('click', this.eventHandler.clickCloseBtn); /** * @type {any} * @name value * @memberof MListModalV2# */ /** * @type {Array} * @name items * @memberof MListModalV2# */ /** * @type {boolean} * @name enableSearch * @memberof MListModalV2# */ /** * @type {boolean} * @name strictValue * @memberof MListModalV2# */ /** * @type {number} * @name selectedIndex * @memberof MListModalV2# */ } MListModalV2.tag = 'MListModalV2'.toLowerCase(); MListModalV2.render = function () { return (0,ACore._)({ extendEvent: ['pressitem', 'pressclose', 'pressout'], class: 'am-list-modal-v2', child: [ { class: ['am-list-popup-box'], child: [ { class: 'am-list-popup-header', child: [ { tag: 'searchtextinput' }, { tag: 'button', class: 'am-list-popup-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: 'am-list-popup-list-scroller', child: { class: 'am-list-popup-content', child: Array(MListModal.prototype.preLoadN).fill('.am-list-popup-list-page.am-selectlist') } } ] } ] }); }; MListModalV2.prototype.resetSearchState = function () { this.searchCtrl.resetSearchState(); }; MListModalV2.prototype.cancelWaiting = function () { } MListModalV2.prototype.findItemsByValue = function (value) { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (!holder) return null; return [holder.data]; }; MListModalV2.prototype.findItemByValue = function (value) { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (!holder) return null; return holder.data; }; MListModalV2.prototype.viewListAt = function (idx) { var offset = this.pagingCtrl.offsetTopOfHolders[idx]; offset = offset || 0; this.pagingCtrl.$listScroller.scrollTop = offset; this.pagingCtrl.update(); }; MListModalV2.prototype.viewListAtFirstSelected = function () { var selectedIndex = this.selectedIndex; this.viewListAt(selectedIndex); }; MListModalV2.prototype.updateSelectedItem = function () { if (this.selectedHolder) { this.selectedHolder.selected = false; this.selectedHolder.updateView(); } var value = this.value;//computed value this.selectedHolder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (this.selectedHolder) { this.selectedHolder.selected = true; this.selectedHolder.updateView(); } }; MListModalV2.property = {}; MListModalV2.property.items = { set: function (items) { this.itemHolders.forEach(holder => { holder.detachView(); }); this.selectedHolder = null; if (!Array.isArray(items)) items = []; this.itemHolders = items.map(it => new MLMHolder(this, it)); this.itemHolders.forEach((holder, i) => { holder.idx = i; }); this.itemHolderByValue = this.itemHolders.reduce(function reducer(ac, cr) { ac[cr.keyValue] = cr; return ac; }, {}); this.updateSelectedItem(); this.layoutCtrl.calcSize(); this.pagingCtrl.viewArr(this.itemHolders); }, get: function () { return this.itemHolders.map(it => it.data); } }; MListModalV2.property.enableSearch = { /*** * @this SelectListBox * @param {boolean} value */ set: function (value) { if (value) this.addClass('as-enable-search'); else this.removeClass('as-enable-search'); }, /*** * @this SelectListBox */ get: function () { return this.hasClass('as-enable-search'); } }; MListModalV2.property.values = { set: function (values) { values = values || []; this.value = values[0]; }, get: function () { return [this.value]; } } MListModalV2.property.value = { set: function (value) { this._value = value; this.updateSelectedItem(); }, /** * @this MListModalV2 * @returns {*} */ get: function () { var value = this._value; var holder; if (this.strictValue) { holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (holder) return value; if (this.itemHolders.length > 0) { return this.itemHolders[0].data.value; } else { return value; } } else return value; } }; MListModalV2.property.strictValue = { set: function (value) { if (value) { this.addClass('as-strict-value'); } else { this.removeClass('as-strict-value'); } }, get: function () { return this.hasClass('as-strict-value'); } }; MListModalV2.property.selectedItem = { get: function () { var value = this._value; var holder; holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)] || null; if (this.strictValue) { if (!holder && this.itemHolders.length > 0) holder = this.itemHolders[0]; } if (holder) return holder.data; return null; } }; MListModalV2.property.selectedIndex = { get: function () { var value = this._value; var holder; holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)] || null; if (this.strictValue) { if (!holder && this.itemHolders.length > 0) holder = this.itemHolders[0]; } if (holder) return holder.idx; return 0; } }; MListModalV2.eventHandler = {}; MListModalV2.eventHandler.selectItem = function (event) { var value = event.value; var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (this.selectedHolder !== holder && this.selectedHolder) { this.selectedHolder.selected = false; this.selectedHolder.updateView(); } if (holder) { holder.selected = true; holder.updateView(); } }; MListModalV2.eventHandler.click = function (event) { if (event.target === this) { this.emit('pressclose', { target: this, type: 'pressclose' }, this); } }; MListModalV2.eventHandler.clickCloseBtn = function (event) { this.emit('pressclose', { target: this, type: 'pressclose' }, this); }; /** * * @param {MListModalV2} boxElt * @constructor */ function MLMLayoutController(boxElt) { this.boxElt = boxElt; } MLMLayoutController.prototype.calcSize = function () { var holders = this.boxElt.itemHolders; var screenSize = this.boxElt.screenSize; var maxAvailableWidth = Math.max(0, screenSize.width - 20); var col1maxWidth = 0; var col2maxWidth = 0; var visit = (nd) => { if (nd.computedSize.col1maxWidth > col1maxWidth) { col1maxWidth = nd.computedSize.col1maxWidth; } if (nd.computedSize.col2maxWidth > col2maxWidth) { col2maxWidth = nd.computedSize.col2maxWidth; } } holders.forEach(visit); var col1Width = col1maxWidth; var col2Width = col2maxWidth; if (col1maxWidth + col2maxWidth > maxAvailableWidth) { col1Width = col1maxWidth / ((col1maxWidth + col2maxWidth) || 1) * maxAvailableWidth; col2Width = Math.max(maxAvailableWidth - col1Width, 0); } var visit2 = (nd) => { nd.applyViewWidth(col1Width, col2Width); if (nd.children && nd.children.length) { nd.children.forEach(visit2); } } holders.forEach(visit2); this.boxElt.estimateSize.textWidth = col1maxWidth - 30; this.boxElt.estimateSize.descWidth = Math.max(0, col2maxWidth - 20); this.boxElt.addStyle('--col1-width', col1Width + 'px'); this.boxElt.addStyle('--col2-width', col2Width + 'px'); }; /** * * @param {MListModalV2} boxElt * @constructor */ function MLMPagingController(boxElt) { this.boxElt = boxElt; this.$content = (0,ACore.$)('.am-list-popup-content', this.boxElt); this.$listScroller = (0,ACore.$)('.am-list-popup-list-scroller', this.boxElt); this.holderArr = []; this.$listPages = []; this.$listScroller.on('scroll', this.ev_scroll.bind(this)); } MLMPagingController.prototype.itemPerPage = 100; MLMPagingController.prototype.preloadN = 5; MLMPagingController.prototype.fillPage = function (pageElt, n) { var itemElt; while (pageElt.childNodes.length > n) { itemElt = pageElt.lastChild; itemElt.selfRemove(); MSelectList_releaseItem(itemElt); } while (pageElt.childNodes.length < n) { itemElt = MSelectList_requireItem(this.boxElt); pageElt.addChild(itemElt); } } MLMPagingController.prototype.viewArr = function (itemHolders) { this.holderArr = itemHolders; var pageN = Math.ceil(this.holderArr.length / this.itemPerPage); while (this.$listPages.length > pageN) { this.$listPages.pop().remove(); } var pageElt; while (this.$listPages.length < pageN) { pageElt = (0,ACore._)({ class: 'am-check-list-page', child: [] }).addTo(this.$content); this.$listPages.push(pageElt); } // console.log('viewArr', holderArr.length); var itemIdx = 0; var k; var pageHeights = Array(pageN).fill(0); var pageIdx; this.offsetTopOfHolders = [0]; for (pageIdx = 0; pageIdx < pageN; ++pageIdx) { pageElt = this.$listPages[pageIdx]; pageElt.clearChild(); for (k = 0; (k < this.itemPerPage) && (itemIdx < this.holderArr.length); ++k, ++itemIdx) { pageHeights[pageIdx] += this.holderArr[itemIdx].computedSize.height; this.offsetTopOfHolders[itemIdx + 1] = this.offsetTopOfHolders[itemIdx] + this.holderArr[itemIdx].computedSize.height; } } for (pageIdx = 0; pageIdx < pageN; ++pageIdx) { pageElt = this.$listPages[pageIdx]; pageElt.addStyle('height', pageHeights[pageIdx] + 'px'); } this.$listScroller.scrollTop = 0; this.update(); }; MLMPagingController.prototype.update = function () { //by scrollTop var offset = this.$listScroller.scrollTop; var low = 0; var high = this.offsetTopOfHolders.length - 1; var mid; while (low < high) { mid = Math.floor((low + high) / 2); if (this.offsetTopOfHolders[mid] < offset) { low = mid + 1; } else { high = mid; } } var itemPerPage = this.itemPerPage; var startPageIdx = Math.max(0, Math.floor(low / this.itemPerPage - 1)); var endPageIdx = Math.min(this.$listPages.length, startPageIdx + this.preloadN); var pageIdx; var pageLength; var itemStartIdx, itemEndIdx; var itemIdx; for (pageIdx = 0; pageIdx < startPageIdx; pageIdx++) { this.fillPage(this.$listPages[pageIdx], 0); } for (pageIdx = endPageIdx; pageIdx < this.$listPages.length; pageIdx++) { this.fillPage(this.$listPages[pageIdx], 0); } for (pageIdx = startPageIdx; pageIdx < endPageIdx; pageIdx++) { itemStartIdx = pageIdx * itemPerPage; itemEndIdx = Math.min(itemStartIdx + itemPerPage, this.holderArr.length); pageLength = itemEndIdx - itemStartIdx; this.fillPage(this.$listPages[pageIdx], pageLength); for (itemIdx = itemStartIdx; itemIdx < itemEndIdx; itemIdx++) { this.holderArr[itemIdx].attachView(this.$listPages[pageIdx].childNodes[itemIdx - itemStartIdx]); } } }; MLMPagingController.prototype.ev_scroll = function () { this.update(); } /** * * @param {MListModalV2} boxElt * @param data * @constructor */ function MLMHolder(boxElt, data) { this.boxElt = boxElt; this.id = (0,stringGenerate.randomIdent)(6); this.idx = 0; this.data = data; this.selected = false; (0,OOP/* drillProperty */.pj)(this, this, 'item', 'data');//adapt old this.value = data.value; this.wrappedText = [this.data.text]; this.wrappedDesc = [this.data.desc]; this.keyValue = (0,utils.keyStringOf)(data.value); this.itemElt = null; this.computedSize = { width: 0, height: 30, col1maxWidth: 0, col2maxWidth: 0 }; this.calcInitSize(); } MLMHolder.prototype.getSearchItem = function () { var res = { value: this.id }; res.text = this.data.text + ''; if (this.data.desc) res.text += " " + this.data.desc; return res; }; MLMHolder.prototype.calcInitSize = function () { this.computedSize.textWidth = Math.ceil(TextMeasure/* default.measureWidth */.Z.measureWidth(this.data.text + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14)); //- 30px - 21px - 10px this.computedSize.col1maxWidth = this.computedSize.textWidth + 30; if (this.data.desc) { this.computedSize.descWidth = Math.ceil(TextMeasure/* default.measureWidth */.Z.measureWidth((this.data.desc || '') + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14)); this.computedSize.col2maxWidth = this.computedSize.descWidth + 20; } else { this.computedSize.descWidth = 0; } } MLMHolder.prototype.applyViewWidth = function (col1Width, col2Width) { this.computedSize.availableTextWidth = col1Width - 30; this.computedSize.availableDescWidth = col2Width - 20; if (this.computedSize.availableTextWidth < this.computedSize.textWidth) { this.wrappedText = TextMeasure/* default.wrapText */.Z.wrapText(this.data.text + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14, this.computedSize.availableTextWidth); } else { this.wrappedText = [this.data.text + '']; } if (this.data.desc && this.computedSize.availableDescWidth < this.computedSize.descWidth) { this.wrappedDesc = TextMeasure/* default.wrapText */.Z.wrapText((this.data.desc || '') + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14, this.computedSize.availableDescWidth); } else { this.wrappedDesc = [(this.data.desc || '') + '']; } this.computedSize.height = Math.max(this.wrappedText.length, this.wrappedDesc.length) * 20 + 10; }; MLMHolder.prototype.attachView = function (itemElt) { if (this.itemElt === itemElt) { this.updateView(); return; } if (itemElt.mlmHolder) { itemElt.mlmHolder.detachView(); } this.itemElt = itemElt; this.itemElt.mlmHolder = this; this.itemElt.data = this.data; this.itemElt.selected = this.data.selected; this.itemElt.addStyle('height', this.computedSize.height + 'px'); this.itemElt.$text.firstChild.data = this.wrappedText.join('\n'); this.itemElt.$desc.firstChild.data = this.wrappedDesc.join('\n'); }; MLMHolder.prototype.detachView = function () { if (this.itemElt) { this.itemElt.mlmHolder = null; this.itemElt = null; } }; MLMHolder.prototype.updateView = function () { if (this.itemElt) { this.itemElt.selected = this.selected; } }; /** * * @param {MListModalV2} boxElt * @constructor */ function MLMSearchController(boxElt) { this.boxElt = boxElt; this.$searchInput = (0,ACore.$)('searchtextinput', this.boxElt) .on('stoptyping', this.ev_searchModify.bind(this)); this.cache = {}; this.searchItems = null; this.holderDict = {}; } MLMSearchController.prototype.reset = function () { this.cache = {}; this.searchItems = null; this.holderDict = {}; } MLMSearchController.prototype.prepareSearchingHolders = function () { if (this.searchItems) return; this.searchItems = []; this.holderDict = {}; var visit = holder => { var it = holder.getSearchItem(); this.holderDict[it.value] = holder; this.searchItems.push(it); }; this.boxElt.itemHolders.forEach(visit); (0,search/* prepareSearchForList */.Lb)(this.searchItems); }; MLMSearchController.prototype.resetSearchState = function () { this.$searchInput.value = ''; this.ev_searchModify(); }; /** * * @param query * @returns {string[]} array of id */ MLMSearchController.prototype.query = function (query) { this.prepareSearchingHolders(); var result = this.cache[query]; var lcList; var visit; if (!result) { lcList = (0,search/* searchListByText */.o)(query, this.searchItems); result = []; visit = (it) => { result.push(it.value) }; lcList.forEach(visit); this.cache[query] = result; } return result; }; MLMSearchController.prototype.ev_searchModify = function () { var query = this.$searchInput.value; query = query.trim(); if (query.length === 0) { this.boxElt.pagingCtrl.viewArr(this.boxElt.itemHolders); return; } var result = this.query(query); var arr = []; for (var i = 0; i < result.length; ++i) { arr.push(this.holderDict[result[i]]); } this.boxElt.pagingCtrl.viewArr(arr); }; // EXTERNAL MODULE: ./node_modules/absol-acomp/js/SelectMenu.js var js_SelectMenu = __webpack_require__(5357); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectmenu/MSelectMenu.js /*** * @extends AElement * @constructor */ function MSelectMenu() { this._value = undefined; this._isFocus = false; this._itemsByValue = {}; this.$holderItem = (0,ACore.$)('.am-selectmenu-holder-item', this); /*** * @type {MListModalV2} */ this.$selectlist = (0,ACore._)({ tag: MListModalV2 }); this.$selectlist.cancelWaiting(); var checkView = () => { if (this.isDescendantOf(document.body)) { setTimeout(checkView, 10000); } else { if (this.$selectlist.searchMaster) this.$selectlist.searchMaster.destroy(); } } setTimeout(checkView, 30000); this.$selectlist.on('pressitem', this.eventHandler.pressItem, true) .on('pressout', this.eventHandler.pressOut) .on('pressclose', this.eventHandler.pressOut); this.on('click', this.eventHandler.click, true); this.$attachhook = (0,ACore.$)('attachhook', this).on('error', this.eventHandler.attached); /** * @name value * @memberof MSelectMenu# */ /** * @name items * @memberof MSelectMenu# */ } MSelectMenu.tag = 'mselectmenu'; MSelectMenu.render = function () { return (0,ACore._)({ class: ['absol-selectmenu', 'am-selectmenu', 'as-strict-value'], extendEvent: ['change', 'minwidthchange'], attr: { tabindex: '1' }, child: [ '.am-selectmenu-holder-item', { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] }, 'attachhook', ] }); }; MSelectMenu.prototype.findItemsByValue = function (value) { return this.$selectlist.findItemsByValue(value); }; MSelectMenu.prototype.findItemByValue = function (value) { return this.$selectlist.findItemByValue(value); }; MSelectMenu.prototype.updateItem = function () { this.$holderItem.clearChild(); var selected = this.findItemsByValue(this.value); if (selected) { var elt = (0,ACore._)({ tag: selectlistbox_MSelectListItem, props: { data: selected[0] } }).addTo(this.$holderItem); } }; MSelectMenu.prototype.notifyChange = function (data) { this.emit('change', Object.assign({}, data, { type: 'change', target: this }), this); }; MSelectMenu.prototype._dictByValue = js_SelectMenu/* default.prototype._dictByValue */.Z.prototype._dictByValue; MSelectMenu.prototype.getRecommendWith = function () { var res = 12 + this.$selectlist.estimateSize.textWidth + 30; if (this.$selectlist.estimateSize.descWidth) res += this.$selectlist.estimateSize.descWidth + 20; return res; }; MSelectMenu.prototype.init = js_SelectMenu/* default.prototype.init */.Z.prototype.init; MSelectMenu.property = {}; MSelectMenu.property.items = { set: function (value) { this._itemIdxByValue = null; /** * verity data */ if (value) { value.forEach(function (it) { if (it && it.text) { it.text = it.text + ''; } }); } this._items = value; this._itemsByValue = this._dictByValue(value); this.$selectlist.items = value; if (!this._itemsByValue[this.value] && value.length > 0 && false) {} else this.updateItem(); if (this.style.width === 'auto' || !this.style.width) { this.addStyle('--recommend-width', this.getRecommendWith() / 14 + 'em'); } }, get: function () { return this._items || []; } }; MSelectMenu.property.value = { set: function (value) { this._value = value; this.$selectlist.values = [value]; this.updateItem(); }, get: function () { if (!this.strictValue) return this._value; var selected = this.findItemsByValue(this._value); if (selected) { return selected[0].value; } else { if (this._items && this._items.length > 0) { return this._items[0].value; } } return this._value; } }; MSelectMenu.property.strictValue = { set: function (value) { if (value) { this.addClass('as-strict-value'); } else { this.removeClass('as-strict-value'); } }, get: function () { return this.hasClass('as-strict-value'); } }; MSelectMenu.property.enableSearch = { set: function (value) { this.$selectlist.enableSearch = !!value; }, get: function () { return this.$selectlist.enableSearch; } }; MSelectMenu.property.isFocus = { set: function (value) { var thisSM = this; value = !!value; if (value === this._isFocus) return; if (this.readOnly || this.disabled) return; this._isFocus = value; if (value) { this.$selectlist.addTo(document.body); if (this.$selectlist.$attachhook) { this.$selectlist.$attachhook.emit('attached'); } thisSM.$selectlist.viewListAt(0); thisSM.$selectlist.viewListAtFirstSelected(); } else { this.$selectlist.selfRemove(); setTimeout(function () { thisSM.$selectlist.resetSearchState(); }, 100); } }, get: function () { return this._isFocus; } }; MSelectMenu.property.selectedIndex = js_SelectMenu/* default.property.selectedIndex */.Z.property.selectedIndex; MSelectMenu.property.disabled = js_SelectMenu/* default.property.disabled */.Z.property.disabled; MSelectMenu.property.hidden = js_SelectMenu/* default.property.hidden */.Z.property.hidden; /** * @type {MSelectMenu} */ MSelectMenu.eventHandler = {}; MSelectMenu.eventHandler.attached = function () { if (this.style.width === 'auto' || !this.style.width) { this.addStyle('--recommend-width', this.getRecommendWith() / 14 + 'em'); } }; MSelectMenu.eventHandler.click = function (event) { this.isFocus = !this.isFocus; }; MSelectMenu.eventHandler.pressOut = function (event) { this.isFocus = false; }; MSelectMenu.eventHandler.pressItem = function (event) { var newValue = event.value; if (newValue !== this._value) { var lastValue = this._value; this._value = newValue; this.$selectlist.values = [newValue]; this.updateItem(); var changeEvent = Object.assign({}, event, { lastValue: lastValue }); setTimeout(function () { this.notifyChange(changeEvent); }.bind(this), 1); } setTimeout(function () { this.isFocus = false; }.bind(this), 100); }; ACore/* default.install */.Z.install(MSelectMenu); /* harmony default export */ const selectmenu_MSelectMenu = (MSelectMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreemenu/MSelectTreeMenu.js /*** * @extends MListModal * @constructor */ function MTreeModal() { selectlistbox_MListModal.call(this); } MTreeModal.tag = 'MTreeModal'.toLowerCase(); MTreeModal.render = function () { return selectlistbox_MListModal.render().addClass('am-tree-modal'); }; Object.assign(MTreeModal.prototype, selectlistbox_MListModal.prototype); MTreeModal.prototype._listToDisplay = function (items) { return treeListToList(items); }; MTreeModal.property = Object.assign({}, selectlistbox_MListModal.property); MTreeModal.eventHandler = Object.assign({}, selectlistbox_MListModal.eventHandler); /** * @extends {AElement} * @constructor */ function MSelectTreeMenu() { this._isFocus = false; this._itemsByValue = {}; this.$holderItem = (0,ACore.$)('.am-selectmenu-holder-item', this); /*** * @type {MTreeModal} */ this.$selectlist = (0,ACore._)({ tag: MTreeModal }); this.$selectlist.cancelWaiting(); this.$selectlist.on('pressitem', this.eventHandler.pressItem, true) .on('pressout', this.eventHandler.pressOut) .on('pressclose', this.eventHandler.pressOut); this.on('click', this.eventHandler.click, true); this.$attachhook = (0,ACore.$)('attachhook', this).on('error', this.eventHandler.attached); this.addStyle('--as-width-limit', calcWidthLimit() + 'px'); } MSelectTreeMenu.tag = 'MSelectTreeMenu'.toLowerCase(); MSelectTreeMenu.render = function () { return selectmenu_MSelectMenu.render().addClass('am-select-tree-menu'); }; Object.assign(MSelectTreeMenu.prototype, selectmenu_MSelectMenu.prototype); MSelectTreeMenu.property = Object.assign({}, selectmenu_MSelectMenu.property); MSelectTreeMenu.eventHandler = Object.assign({}, selectmenu_MSelectMenu.eventHandler); MSelectTreeMenu.prototype._dictByValue = function (items) { return items.reduce(function visitor(ac, cr) { if (cr.items && cr.items.reduce) { cr.items.reduce(visitor, ac); } var value = cr.value + ''; ac[value] = cr; return ac; }, {}) }; ACore/* default.install */.Z.install(MSelectTreeMenu); /* harmony default export */ const selecttreemenu_MSelectTreeMenu = ((/* unused pure expression or super */ null && (MSelectTreeMenu))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multicheckmenu/MCheckListModal.js function MCheckListModal_measureListSize(items) { var descWidth = measureMaxDescriptionWidth(items); var textWidth = measureMaxTextWidth(items); var width = descWidth + 20 + textWidth + 12 + 15 + 18;//padding, margin return { width: width, descWidth: descWidth, textWidth: textWidth }; } var MCheckListModal_itemPool = []; function MCheckListModal_onClickItem(event) { var thisSL = this.$parent; if (thisSL) { thisSL.eventHandler.selectItem(this, event); } } /** * @returns {MSelectListItem} */ function MCheckListModal_makeItem() { return (0,ACore._)({ tag: multicheckmenu_MChecklistItem, on: { select: MCheckListModal_onClickItem } }); } function MCheckListModal_requireItem($parent) { var item; if (MCheckListModal_itemPool.length > 0) { item = MCheckListModal_itemPool.pop(); } else { item = MCheckListModal_makeItem(); } item.$parent = $parent; return item; } function MCheckListModal_releaseItem(item) { item.$parent = null; item.attr('class', 'am-selectlist-item'); item.selected = false; MCheckListModal_itemPool.push(item); } /*** * @extends MListModal * @constructor */ function MCheckListModal() { this.itemHolderByValue = {}; this.itemHolders = []; this.domSignal = new DelaySignal/* default */.Z(); this.$checkAll = (0,ACore.$)('.as-select-list-box-check-all', this); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$box = (0,ACore.$)('.am-list-popup-box', this); this.$scroller = (0,ACore.$)('.am-check-list-scroller', this); this.pagingCtrl = new MCLPagingController(this); this.actionCtrl = new MCLActionController(this); this.searchCtrl = new MCLSearchController(this); this.screenSize = (0,Dom/* getScreenSize */.tE)(); this.widthLimit = this.screenSize.width - 20; this._values = []; this._valueDict = {}; this.layoutCtrl = new MCLLayoutController(this); /** * @type {boolean} * @name selectedAll * @memberOf MCheckListModal# * @readonly */ /** * @type {[]} * @name values * @memberOf MCheckListModal# */ /** * @type {[]} * @name items * @memberOf MCheckListModal# */ } MCheckListModal.tag = 'MChecklistModal'.toLowerCase(); Object.assign(MCheckListModal.prototype, selectlistbox_MListModal.prototype); MCheckListModal.property = Object.assign({}, selectlistbox_MListModal.property); MCheckListModal.eventHandler = Object.assign({}, selectlistbox_MListModal.eventHandler); delete MCheckListModal.property.orderly; MCheckListModal.render = function () { return (0,ACore._)({ extendEvent: ['change', 'close', 'cancel'], class: ['am-list-modal', 'am-check-list-modal'], child: [ { class: ['am-list-popup-box'], child: [ { class: 'am-list-popup-header', child: [ { tag: 'searchtextinput' }, { tag: 'button', class: 'am-list-popup-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: 'am-check-list-scroller', child: { class: 'am-list-popup-content' } }, { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: { tag: 'a', class: 'as-select-list-box-cancel-btn', child: { text: 'Cancel' } } } ] } ] } ] }); }; MCheckListModal.prototype.addTo = function (parent) { AElement/* default.prototype.addTo.apply */.Z.prototype.addTo.apply(this, arguments); this.pagingCtrl.viewListAt(0); }; /** * wrong function name * @deprecated * @param value * @returns {*|null} */ MCheckListModal.prototype.findItemsByValue = function (value) { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (holder) return holder.data; return null; }; MCheckListModal.prototype.findItemByValue = function (value) { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (holder) return holder.data; return null; }; MCheckListModal.prototype.refollow = noop/* default */.Z; MCheckListModal.prototype.updatePosition = noop/* default */.Z; MCheckListModal.prototype.resetSearchState = function () { this.searchCtrl.resetSearchState(); }; /** * * @param value * @returns {null|[*]} */ MCheckListModal.prototype.findItemHoldersByValue = function (value) { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (holder) return [holder]; return null; }; MCheckListModal.prototype.viewListAtValue = function (value) { this.pagingCtrl.viewListAtValue(value); }; MCheckListModal.prototype.viewListAtFirstSelected = function () { var value = this.values[0]; var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (!holder) return; var idx = holder.idx; this.pagingCtrl.viewListAt(idx); }; MCheckListModal.property.values = { set: function (values) { values = values || []; if (!Array.isArray(values)) { values = []; } this._values = values.slice(); this._valueDict = this._values.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr)] = cr; return ac; }, {}); this.itemHolders.forEach(holder => { holder.selected = holder.valueKey in this._valueDict; holder.updateView(); }); this.$checkAll.checked = this.selectedAll; }, get: function () { var valueHolders = this._values.map(value => { var holder = this.itemHolderByValue[(0,utils.keyStringOf)(value)]; return holder ? { value: value, idx: holder.idx, } : null; }).filter(x => !!x); valueHolders.sort((a, b) => a.idx - b.idx); return valueHolders.map(x => x.value); } }; MCheckListModal.property.items = { /** * @this {MCheckListModal} * @param items */ set: function (items) { items = items || []; if (!Array.isArray(items)) items = []; items = (0,utils.copySelectionItemArray)(items, { removeNoView: true, removeNewLine: true }); this._items = items; this.itemHolders = this._items.map(it => new MCLHolder(this, it, null)); this.itemHolderByValue = this.itemHolders.reduce((ac, cr) => { return cr.toDictionary(ac); }, {}); //update idx var idx = 0; var visit = (nd) => { nd.idx = idx++; if (nd.children && nd.children.length) { nd.children.forEach(visit); } } this.itemHolders.forEach(visit); this.layoutCtrl.calcSize(); this.pagingCtrl.viewArr(this.itemHolders); this.$checkAll.checked = this.selectedAll; }, get: function () { return this._items; } }; MCheckListModal.property.selectedItems = { get: function () { var holders = this._values.map(value => this.itemHolderByValue[(0,utils.keyStringOf)(value)]).filter(x => !!x); holders.sort((a, b) => a.idx - b.idx); return holders.map(it => it.data); } }; MCheckListModal.property.selectedAll = { get: function () { return this.itemHolders.length > 0 && this.itemHolders.every(function visit(holder) { var res = holder.selected || holder.data.noSelect; if (res && holder.children) { res = holder.children.every(visit); } return res; }); } }; /** * @this {MCheckListModal} * @param itemElt * @param event */ MCheckListModal.eventHandler.selectItem = function (itemElt, event) { var selected = itemElt.selected; var data = itemElt.data; var value = itemElt.value; var key = (0,utils.keyStringOf)(value); var holder = this.itemHolderByValue[key]; if (holder) { holder.selected = selected; } var idx; if (selected) { this._valueDict[key] = true; this._values.push(value); this.$checkAll.checked = this.selectedAll; } else { delete this._valueDict[key]; idx = this._values.indexOf(value); if (idx >= 0) this._values.splice(idx, 1); this.$checkAll.checked = false; } this.emit('change', { type: 'change', target: this, itemElt: this, value: value, data: data, itemData: data, action: selected ? "check" : "uncheck", originalEvent: event.originalEvent || event.originEvent || event }); }; MCheckListModal.eventHandler.checkAllChange = CheckListBox.eventHandler.checkAllChange; MCheckListModal.eventHandler.clickCancelBtn = CheckListBox.eventHandler.clickCancelBtn; ACore/* default.install */.Z.install(MCheckListModal); /* harmony default export */ const multicheckmenu_MCheckListModal = (MCheckListModal); /** * * @param {MCheckListModal} boxElt * @constructor */ function MCLLayoutController(boxElt) { this.boxElt = boxElt; } MCLLayoutController.prototype.calcSize = function () { var holders = this.boxElt.itemHolders; var screenSize = this.boxElt.screenSize; var maxAvailableWidth = Math.max(0, screenSize.width - 20); var col1maxWidth = 0; var col2maxWidth = 0; var visit = (nd) => { if (nd.computedSize.col1maxWidth > col1maxWidth) { col1maxWidth = nd.computedSize.col1maxWidth; } if (nd.computedSize.col2maxWidth > col2maxWidth) { col2maxWidth = nd.computedSize.col2maxWidth; } if (nd.children && nd.children.length) { nd.children.forEach(visit); } } holders.forEach(visit); var col1Width = col1maxWidth; var col2Width = col2maxWidth; if (col1maxWidth + col2maxWidth > maxAvailableWidth) { col1Width = col1maxWidth / ((col1maxWidth + col2maxWidth) || 1) * maxAvailableWidth; col2Width = Math.max(maxAvailableWidth - col1Width, 0); } var visit2 = (nd) => { nd.applyViewWidth(col1Width, col2Width); if (nd.children && nd.children.length) { nd.children.forEach(visit2); } } holders.forEach(visit2); this.boxElt.addStyle('--col1-width', col1Width + 'px'); this.boxElt.addStyle('--col2-width', col2Width + 'px'); }; /** * @extends CLHolder * @param {MCheckListModal} boxElt * @param data * @param parent * @constructor */ function MCLHolder(boxElt, data, parent) { this.idx = 0; this.id = (0,stringGenerate.randomIdent)(8); this.parent = parent; this.level = parent ? parent.level + 1 : 0; this.boxElt = boxElt; this.data = data; (0,OOP/* drillProperty */.pj)(this, this, 'item', 'data');//adapt mobile and desktop this.valueKey = (0,utils.keyStringOf)(data.value); this.itemKey = keyStringOfItem(data); this.itemElt = null; this.children = null; this.selected = this.valueKey in boxElt._valueDict; var Clazz = this.constructor; if (data.items && data.items.length > 0) { this.children = data.items.map(it => new Clazz(boxElt, it, this)); } this.computedSize = { textWidth: 0, descWidth: 0, width: 0, height: 0, col1maxWidth: 0, col2maxWidth: 0, col1Width: 0, col2width: 0, availableTextWidth: 0, availableDescWidth: 0, levelWidth: 0, }; this.calcInitSize(); this.wrappedText = [this.data.text]; this.wrappedDesc = [this.data.desc]; } (0,OOP/* mixClass */.Jx)(MCLHolder, CLHolder); MCLHolder.prototype.calcInitSize = function () { this.computedSize.textWidth = Math.ceil(TextMeasure/* default.measureWidth */.Z.measureWidth(this.data.text + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14)); this.computedSize.levelWidth = this.level * 12; //- 30px - 21px - 10px this.computedSize.col1maxWidth = this.computedSize.textWidth + 30 + this.computedSize.levelWidth + 21 + 10;//todo if (this.data.desc) { this.computedSize.descWidth = Math.ceil(TextMeasure/* default.measureWidth */.Z.measureWidth((this.data.desc || '') + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14)); this.computedSize.col2maxWidth = this.computedSize.descWidth + 20; } else { this.computedSize.descWidth = 0; } }; MCLHolder.prototype.applyViewWidth = function (col1Width, col2Width) { this.computedSize.col1Width = col1Width; this.computedSize.col2Width = col2Width; this.computedSize.availableTextWidth = col1Width - 30 - this.computedSize.levelWidth - 21 - 10; if (col1Width < this.computedSize.col1maxWidth) {//must wrap this.wrappedText = TextMeasure/* default.wrapText */.Z.wrapText(this.data.text + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14, this.computedSize.availableTextWidth); } else { this.wrappedText = [this.data.text]; } if (col2Width && col2Width < this.computedSize.col2maxWidth && this.data.desc) {//must wrap this.computedSize.availableDescWidth = col2Width - 20; this.wrappedDesc = TextMeasure/* default.wrapText */.Z.wrapText((this.data.desc || '') + '', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14, this.computedSize.availableDescWidth); } else { this.wrappedDesc = [(this.data.desc || '') + '']; } this.computedSize.height = 10 + Math.max(this.wrappedText.length, this.wrappedDesc.length, 1) * 20; this.computedSize.width = Math.ceil(this.boxElt.screenSize.width - 20); }; MCLHolder.prototype.toArray = function (ac) { ac = ac || []; ac.push(this); if (this.children) this.children.reduce((ac, holder) => holder.toArray(ac), ac); return ac; }; MCLHolder.prototype.toDictionary = function (ac) { ac = ac || {}; ac[this.valueKey] = this; if (this.children) this.children.reduce((ac, holder) => holder.toDictionary(ac), ac); return ac; }; MCLHolder.prototype.detachView = function () { if (this.itemElt) { this.itemElt.attr('title', null); this.itemElt.clHolder = null; this.itemElt = null; } }; MCLHolder.prototype.getSearchItem = function () { var res = { value: this.id }; res.text = this.data.text + ''; if (this.data.desc) res.text += '/' + this.data.desc; if (this.children) res.items = this.children.map(c => c.getSearchItem()) return res; }; MCLHolder.prototype.attachView = function (itemElt) { if (this.itemElt === itemElt) return; if (itemElt.clHolder) itemElt.clHolder.detachView(); itemElt.clHolder = this; this.itemElt = itemElt; itemElt.data = this.data; itemElt.level = this.level; itemElt.selected = this.selected; itemElt.$text.firstChild.data = this.wrappedText.join('\n'); itemElt.$desc.firstChild.data = this.wrappedDesc && this.wrappedDesc.length ? this.wrappedDesc.join('\n') : ''; itemElt.addStyle('height', this.computedSize.height + 'px'); } MCLHolder.prototype.updateView = function () { if (this.itemElt) { this.itemElt.selected = this.selected; } }; /** * @extends MCLHolder * @param {MCheckListModal} boxElt * @param origin * @param parent * @param result * @constructor */ function MCLHolderRef(boxElt, origin, parent, result) { this.boxElt = boxElt; this.origin = origin; this.data = origin.data; this.parent = parent; this.level = origin.level; this.wrappedText = origin.wrappedText; this.wrappedDesc = origin.wrappedDesc; OOP/* default.drillProperty */.ZP.drillProperty(this, origin, 'selected'); var Clazz = this.constructor; var arr, children; if (origin.children) { arr = origin.children.filter(it => !!result[it.id]); arr.sort((a, b) => result[a.id] - result[b.id]); children = arr.map(holder => new Clazz(boxElt, holder, this, result)); if (children.length > 0) this.children = children; } this.computedSize = origin.computedSize; } (0,OOP/* mixClass */.Jx)(MCLHolderRef, MCLHolder); /** * * @param {MCheckListModal} boxElt * @constructor */ function MCLPagingController(boxElt) { this.boxElt = boxElt; this.$listScroller = (0,ACore.$)('.am-check-list-scroller', this.boxElt) .on('scroll', this.ev_scroll.bind(this)); this.$listPages = []; this.$content = (0,ACore.$)('.am-list-popup-content', this.boxElt); this.holderArr = []; this.offsetTopOfHolders = [];//y of each item } MCLPagingController.prototype.preLoadN = 3; MCLPagingController.prototype.itemPerPage = 100; MCLPagingController.prototype._requireItem = function (pageElt, n) { var itemElt; while (pageElt.childNodes.length > n) { itemElt = pageElt.lastChild; itemElt.selfRemove(); MCheckListModal_releaseItem(itemElt); } while (pageElt.childNodes.length < n) { itemElt = MCheckListModal_requireItem(this.boxElt); pageElt.addChild(itemElt); } }; MCLPagingController.prototype.viewArr = function (itemHolders) { this.holderArr = itemHolders.reduce((ac, holder) => holder.toArray(ac), []); var pageN = Math.ceil(this.holderArr.length / this.itemPerPage); while (this.$listPages.length > pageN) { this.$listPages.pop().remove(); } var pageElt; while (this.$listPages.length < pageN) { pageElt = (0,ACore._)({ class: 'am-check-list-page', child: [] }).addTo(this.$content); this.$listPages.push(pageElt); } var itemIdx = 0; var k; var pageHeights = Array(pageN).fill(0); var pageIdx; this.offsetTopOfHolders = [0]; for (pageIdx = 0; pageIdx < pageN; ++pageIdx) { pageElt = this.$listPages[pageIdx]; pageElt.clearChild(); for (k = 0; (k < this.itemPerPage) && (itemIdx < this.holderArr.length); ++k, ++itemIdx) { pageHeights[pageIdx] += this.holderArr[itemIdx].computedSize.height; this.offsetTopOfHolders[itemIdx + 1] = this.offsetTopOfHolders[itemIdx] + this.holderArr[itemIdx].computedSize.height; } } for (pageIdx = 0; pageIdx < pageN; ++pageIdx) { pageElt = this.$listPages[pageIdx]; pageElt.addStyle('height', pageHeights[pageIdx] + 'px'); } this.$listScroller.scrollTop = 0; this.update(); }; MCLPagingController.prototype.update = function () { var now = Date.now(); //by scrollTop var offset = this.$listScroller.scrollTop; var low = 0; var high = this.offsetTopOfHolders.length - 1; var mid; while (low < high) { mid = Math.floor((low + high) / 2); if (this.offsetTopOfHolders[mid] < offset) { low = mid + 1; } else { high = mid; } } var itemPerPage = this.itemPerPage; var startPageIdx = Math.max(0, Math.floor(low / this.itemPerPage - 1)); var endPageIdx = Math.min(this.$listPages.length, startPageIdx + this.preLoadN); var pageIdx; var pageLength; var itemStartIdx, itemEndIdx; var itemIdx; for (pageIdx = 0; pageIdx < startPageIdx; pageIdx++) { this._requireItem(this.$listPages[pageIdx], 0); } for (pageIdx = endPageIdx; pageIdx < this.$listPages.length; pageIdx++) { this._requireItem(this.$listPages[pageIdx], 0); } for (pageIdx = startPageIdx; pageIdx < endPageIdx; pageIdx++) { itemStartIdx = pageIdx * itemPerPage; itemEndIdx = Math.min(itemStartIdx + itemPerPage, this.holderArr.length); pageLength = itemEndIdx - itemStartIdx; this._requireItem(this.$listPages[pageIdx], pageLength); for (itemIdx = itemStartIdx; itemIdx < itemEndIdx; itemIdx++) { this.holderArr[itemIdx].attachView(this.$listPages[pageIdx].childNodes[itemIdx - itemStartIdx]); } } } MCLPagingController.prototype.viewListAtValue = function (value) { var holder = this.boxElt.itemHolderByValue[(0,utils.keyStringOf)(value)]; if (!holder) return; var idx = holder.idx; this.$listScroller.scrollTop = this.offsetTopOfHolders[idx] || 0; this.update(); }; MCLPagingController.prototype.viewListAt = function (offset) { this.$listScroller.scrollTop = this.offsetTopOfHolders[offset] || 0; this.update(); }; MCLPagingController.prototype.ev_scroll = function () { this.update(); }; function MCLSearchController(boxElt) { this.boxElt = boxElt; this.$searchInput = (0,ACore.$)('searchtextinput', boxElt) .on('stoptyping', this.ev_searchModify.bind(this)); this.cache = {}; this.searchItems = null; this.holderDict = null; this.session = Math.floor(Math.random() * 1000000); } MCLSearchController.prototype.reset = function () { this.cache = {}; this.searchItems = null; this.holderDict = null;//by id this.session = Math.floor(Math.random() * 1000000); }; MCLSearchController.prototype.prepareSearchingHolders = function () { if (this.searchItems) return; this.searchItems = this.boxElt.itemHolders.map(it => it.getSearchItem()); (0,search/* prepareSearchForList */.Lb)(this.searchItems); var holderDict = {}; var visit = (nd) => { var id = nd.id; holderDict[id] = nd; if (nd.children && nd.children.length) { nd.children.forEach(visit); } } this.boxElt.itemHolders.forEach(visit); this.holderDict = holderDict; }; MCLSearchController.prototype.resetSearchState = function () { this.$searchInput.value = ''; this.session = Math.floor(Math.random() * 1000000); this.ev_searchModify(); }; /** * * @param query * @returns {null|{}} return dictionary of id */ MCLSearchController.prototype.query = function (query) { //todo: async or split task this.prepareSearchingHolders(); var result = this.cache[query]; var lcList; var visit, idx; if (!result) { lcList = (0,search/* searchTreeListByText */.$l)(query, this.searchItems); result = {}; idx = 0; visit = (it) => { result[it.value] = ++idx; if (it.items && it.items.length) { it.items.forEach(visit); } }; lcList.forEach(visit); this.cache[query] = result; } this.ev_queryComplete(result); return result; }; MCLSearchController.prototype.ev_queryComplete = function (result) { var arr = this.boxElt.itemHolders.filter(it => !!result[it.id]); arr.sort((a, b) => result[a.id] - result[b.id]); var searchHolders = arr.map(holder => new MCLHolderRef(this.boxElt, holder, null, result)); this.boxElt.pagingCtrl.viewArr(searchHolders); }; MCLSearchController.prototype.ev_searchModify = function () { var query = this.$searchInput.value; query = query.trim(); if (query.length === 0) { this.boxElt.pagingCtrl.viewArr(this.boxElt.itemHolders); return; } this.query(query); }; /** * * @param {MCheckListModal} boxElt * @constructor */ function MCLActionController(boxElt) { this.boxElt = boxElt; this.$checkAll = this.boxElt.$checkAll; this.$cancelBtn = (0,ACore.$)('.as-select-list-box-cancel-btn', boxElt); this.$closeBtn = (0,ACore.$)('.am-list-popup-close-btn', boxElt); this.$checkAll.on('change', this.ev_checkedChange.bind(this)); this.boxElt.on('click', this.ev_clickModal.bind(this)); this.$closeBtn.on('click', this.ev_clickClose.bind(this)); this.$cancelBtn.on('click', this.ev_clickCancel.bind(this)); } MCLActionController.prototype.ev_checkedChange = function () { var values = this.boxElt._values; var dict = this.boxElt._valueDict; while (values.length > 0) values.pop(); Object.keys(dict).forEach(function (key) { delete dict[key]; }); var checked = this.$checkAll.checked; var visit = (nd) => { if (!nd.data.noSelect) nd.selected = checked; if (checked && !dict[nd.valueKey]) { dict[nd.valueKey] = true; values.push(nd.data.value); } if (nd.children && nd.children.length) { nd.children.forEach(visit); } }; this.boxElt.itemHolders.forEach(visit); this.boxElt.pagingCtrl.holderArr.forEach(hd => hd.updateView()); this.boxElt.emit('change', { type: 'change' }, this); }; MCLActionController.prototype.ev_clickCancel = function () { this.boxElt.emit('cancel', { type: 'cancel' }, this); }; MCLActionController.prototype.ev_clickClose = function () { this.boxElt.emit('close', { type: 'close' }, this); }; MCLActionController.prototype.ev_clickModal = function (event) { if (event.target === this.boxElt) { this.boxElt.emit('close', { type: 'close' }, this); } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiCheckMenu.js var hitItem = event => { var target = event.target; for (var i = 0; i < 5 && target; ++i) { if (target.hasClass && target.hasClass('absol-selectbox-item')) return true; target = target.parentElement; } return false; } var hitClose = event => { var target = event.target; if (target.hasClass && target.hasClass('absol-selectbox-item-close')) return true; target = target.parentElement; return !!(target.hasClass && target.hasClass('absol-selectbox-item-close')); }; /*** * @extends AElement * @constructor */ function MultiCheckMenu() { (0,MultiLanguageCSS/* loadLanguageModule */.q)(); this.addClass('as-multi-check-menu'); // this.on('click', this.eventHandler.click); /*** * @type {CheckListBox|MCheckListModal} */ this.$selectlistBox = (0,ACore._)({ tag: BrowserDetector/* default.isMobile */.Z.isMobile ? multicheckmenu_MCheckListModal : CheckListBox,//use new version//TODO: in process props: { anchor: [1, 6, 2, 5], } }); (0,OOP/* drillProperty */.pj)(this, this.$selectlistBox, 'debug') this.addStyle('--as-width-limit', Math.max(140, (this.$selectlistBox.widthLimit || 0)) + 'px'); this.$itemCtn = (0,ACore.$)('.as-multi-select-menu-item-ctn', this); this.$attachhook = (0,ACore.$)('attachhook', this) .on('attached', this.eventHandler.attached); this.$attachhook.requestUpdateSize = this.updateSize.bind(this); this.boxCtrl = new MSMBoxController(this); this.itemsViewCtrl = new MSMItemsViewController(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.boxCtrl, 'isFocus'); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectlistBox, 'enableSearch'); OOP/* default.drillProperty */.ZP.drillProperty(this, this.itemsViewCtrl, '$items');//adapt this.commitedValues = [];//commit value this.$selectlistBox.followTarget = this; this.$selectlistBox.sponsorElement = this; this.disableClickToFocus = false; this.orderly = true;//always true this.itemFocusable = false; /** * @type {boolean} * @memberof MultiCheckMenu# * @name disabled */ /** * @type {boolean} * @memberof MultiCheckMenu# * @name readOnly */ /** * @type {Array<number|null|string|Date>} * @memberof MultiCheckMenu# * @name values */ } MultiCheckMenu.tag = 'MultiCheckMenu'.toLowerCase(); MultiCheckMenu.render = js_MultiSelectMenu.render; Object.assign(MultiCheckMenu.prototype, js_MultiSelectMenu.prototype); MultiCheckMenu.property = Object.assign({}, js_MultiSelectMenu.property); MultiCheckMenu.eventHandler = Object.assign({}, js_MultiSelectMenu.eventHandler); delete MultiCheckMenu.property.isFocus; delete MultiCheckMenu.property.orderly; MultiCheckMenu.prototype.styleHandlers = {}; MultiCheckMenu.prototype.styleHandlers.maxWidth = function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (parsedValue.unit === 'px') { this.addClass('as-has-max-width'); this.addStyle('--max-width', value); } else { this.removeClass('as-has-max-width'); } }; MultiCheckMenu.prototype.styleHandlers['max-width'] = MultiCheckMenu.prototype.styleHandlers.maxWidth; MultiCheckMenu.prototype.styleHandlers.width = function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (parsedValue.unit === 'px') { this.addClass('as-has-max-width'); this.addStyle('--max-width', value); this.style.width = value; } else { this.removeClass('as-has-max-width'); } }; /** * @this MultiCheckMenu * @param value */ MultiCheckMenu.prototype.styleHandlers.maxHeight = function (value) { var psValue = (0,attribute.parseMeasureValue)(value); if (psValue) { switch (psValue.unit) { case 'px': psValue.value = Math.min(psValue.value, 90); break; case 'em': case 'rem': psValue.value = Math.min(psValue.value, 90 / 14); break; } this.$itemCtn.addStyle('max-height', psValue.value + psValue.unit); } else { this.$itemCtn.removeStyle('max-height'); } }; MultiCheckMenu.prototype.styleHandlers['max-height'] = MultiCheckMenu.prototype.styleHandlers.maxHeight; MultiCheckMenu.prototype.styleHandlers.hidden = function (value) { if (value === 'hidden') { this.style.overflow = 'hidden'; this.$itemCtn.style.overflow = 'hidden'; } else { this.style.overflow = ''; this.$itemCtn.style.overflow = ''; } } MultiCheckMenu.prototype.addStyle = function (arg0, arg1) { if ((typeof arg0 === "string") && (this.styleHandlers[arg0])) { this.styleHandlers[arg0].apply(this, Array.prototype.slice.call(arguments, 1)); return this; } else { return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } }; MultiCheckMenu.prototype.removeStyle = function (arg0) { if ((typeof arg0 === "string") && (this.styleHandlers[arg0])) { this.styleHandlers[arg0].call(this, ''); return this; } else { return AElement/* default.prototype.removeStyle.apply */.Z.prototype.removeStyle.apply(this, arguments); } }; MultiCheckMenu.prototype._updateOverflow = function () { //todo: calc item size before render var bound, i; var fromIdx = Infinity; if (this.getComputedStyleValue('overflow') === 'hidden') { bound = this.getBoundingClientRect(); if (bound.width === 0) return; this.$itemCtn.removeClass('as-has-more'); var hasMore = false; var elt; for (i = 0; i < this.$itemCtn.childNodes.length; ++i) { elt = this.$itemCtn.childNodes[i]; if (!hasMore) { elt.removeStyle('display'); var cBound = elt.getBoundingClientRect(); if (cBound.bottom > bound.bottom) { hasMore = true; fromIdx = i - 1; break; } } } if (hasMore) { this.$itemCtn.addClass('as-has-more'); for (i = 0; i < this.$itemCtn.childNodes.length; ++i) { elt = this.$itemCtn.childNodes[i]; if (i > 0 && i >= fromIdx) { elt.addStyle('display', 'none'); } else { elt.removeStyle('display'); } } } else { for (i = 0; i < this.$itemCtn.childNodes.length; ++i) { elt = this.$itemCtn.childNodes[i]; elt.removeStyle('display'); } } } }; MultiCheckMenu.property.values = { set: function (values) { if (values === undefined || values === null) values = []; else if (!Array.isArray(values)) values = [values]; this.$selectlistBox.values = values; this.commitedValues = this.$selectlistBox.values; this.itemsViewCtrl.update(); }, get: function () { return this.commitedValues; } }; MultiCheckMenu.property.items = { /** * @this MultiCheckMenu * @param items */ set: function (items) { this.$selectlistBox.items = items; this.commitedValues = this.$selectlistBox.values; this.addStyle('--list-min-width', Math.max(140, this.$selectlistBox._estimateWidth || 0) + 'px'); this.itemsViewCtrl.update(); }, get: function () { return this.$selectlistBox.items; } }; MultiCheckMenu.property.placeholder = { set: function (value) { if (typeof value === "string") value = value.trim(); if (value) { this.$itemCtn.attr('data-placeholder', value + ''); } else { this.$itemCtn.attr('data-placeholder', null); } }, get: function () { return this.$itemCtn.attr('data-placeholder') || ''; } }; MultiCheckMenu.prototype.updateSize = function () { var bound; if (this.boxCtrl.isFocus) { bound = this.getBoundingClientRect(); if (!BrowserDetector/* default.isMobile */.Z.isMobile) this.$selectlistBox.addStyle('min-width', Math.max(bound.width, this.$selectlistBox.getFontSize() * 18.5) + 'px'); this.$selectlistBox.refollow(); this.$selectlistBox.updatePosition(); } }; MultiCheckMenu.prototype.findItemsByValue = function (value) { return this.$selectlistBox.findItemsByValue(value); }; MultiCheckMenu.prototype.findItemByValue = function (value) { return this.$selectlistBox.findItemByValue(value); } MultiCheckMenu.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } } /*** * call after close checklistbox * @param event */ MultiCheckMenu.eventHandler.selectListBoxPressItem = function (event) { console.log('press') var prevValues = this.commitedValues; var prevDict = prevValues.reduce(function (ac, cr) { ac[cr + ''] = cr; return ac; }, {}); this.$selectlistBox.updatePosition(); var curValues = this.$selectlistBox.values; var changed = false; var curDict = curValues.reduce(function (ac, cr) { ac[cr + ''] = cr; return ac; }, {}); this.commitedValues = curValues.slice(); prevValues.forEach(function (value) { if ((value + '') in curDict) return; var holders = this.$selectlistBox.findItemsByValue(value); if (!holders || holders.length === 0) return; var item = holders[0].item; this.emit('remove', Object.assign({}, event, { type: 'remove', target: this, value: item.value, data: item, itemData: item }), this); changed = true; }.bind(this)); curValues.forEach(function (value) { if ((value + '') in prevDict) return; var holders = this.$selectlistBox.findItemsByValue(value); if (!holders || holders.length === 0) return; var item = holders[0].item; this.emit('add', Object.assign({}, event, { type: 'add', target: this, value: item.value, data: item, itemData: item }), this); changed = true; }.bind(this)); this._updateItems(); this.isFocus = false; if (changed) this.emit('change', Object.assign({}, event, { type: 'change', action: 'submit', target: this, values: this.values }), this); }; ACore/* default.install */.Z.install(MultiCheckMenu); /* harmony default export */ const js_MultiCheckMenu = (MultiCheckMenu); /** * * @param {MultiCheckMenu} elt * @constructor */ function MSMItemsViewController(elt) { this.elt = elt; this.$items = []; } MSMItemsViewController.prototype.share = { pool: [], pressCloseEventHandle: function pressCloseEventHandle(event) { var parentElt = this.$parent; if (!parentElt) return; parentElt.itemsViewCtrl.ev_pressCloseItem(this, event); }, pressHandler: function pressHandler(event) { var parentElt = this.$parent; if (!parentElt) return; parentElt.itemsViewCtrl.ev_pressItem(this, event); } }; MSMItemsViewController.prototype.revokeResource = function () { delete this.elt; }; MSMItemsViewController.prototype.makeItem = function () { return (0,ACore._)({ tag: 'selectboxitem', on: { close: this.share.pressCloseEventHandle, press: this.share.pressHandler } }); }; MSMItemsViewController.prototype.releaseItem = function (itemElt) { this.share.pool.push(itemElt); itemElt.$parent = null; }; MSMItemsViewController.prototype.requireItem = function () { var itemElt; if (this.share.pool.length > 0) { itemElt = this.share.pool.pop(); } else { itemElt = this.makeItem(); } itemElt.$parent = this.elt; return itemElt; } MSMItemsViewController.prototype.requireListLength = function (n) { if (!(0,utils.isNaturalNumber)(n)) n = 0; var itemElt; while (this.$items.length < n) { itemElt = this.requireItem(); this.elt.$itemCtn.addChild(itemElt); this.$items.push(itemElt); } while (this.$items.length > n) { itemElt = this.$items.pop(); this.elt.$itemCtn.removeChild(itemElt); this.releaseItem(itemElt); } }; MSMItemsViewController.prototype.assignItems = function (items) { for (var i = 0; i < this.$items.length && i < items.length; ++i) { this.$items[i].data = items[i]; } }; MSMItemsViewController.prototype.viewItems = function (items) { var cBound = this.elt.getBoundingClientRect(); this.requireListLength(items.length); this.assignItems(items); setTimeout(this.elt._updateOverflow.bind(this.elt), 10) setTimeout(this.elt._updateOverflow.bind(this.elt), 100) setTimeout(this.elt._updateOverflow.bind(this.elt), 150) var nBound = this.elt.getBoundingClientRect(); if (nBound.width !== cBound.width || nBound.height !== cBound.height) { ResizeSystem/* default.updateUp */.Z.updateUp(this.elt); } }; MSMItemsViewController.prototype.viewItemsByIndexes = function (indexes) { var items = []; var item; for (var i = 0; i < indexes.length; ++i) { item = this.elt.$selectlistBox.getItemByIndex(indexes[i]); if (item) items.push(item); } this.viewItems(items); }; MSMItemsViewController.prototype.viewItemsByValues = function (values) { values = values || []; var items = []; var holders; for (var i = 0; i < values.length; ++i) { holders = this.elt.$selectlistBox.findItemHoldersByValue(values[i]); if (holders) { holders = holders.map(hd => hd.item); items = items.concat(holders); } } this.viewItems(items); }; MSMItemsViewController.prototype.update = function () { this.viewItemsByValues(this.elt.values); }; MSMItemsViewController.prototype.ev_pressCloseItem = function (itemElt, event) { var values = this.elt.$selectlistBox.values; var value = itemElt.value; var newValues = values.filter(x => x !== value); var data = itemElt.data; this.elt.$selectlistBox.values = newValues; if (this.elt.boxCtrl.isFocus) { this.viewItemsByValues(newValues); } else { this.elt.commitedValues = this.elt.$selectlistBox.values; this.update(); this.elt.emit('change', { type: 'change', action: 'remove', data: data, value: value, target: this.elt }); } }; MSMItemsViewController.prototype.ev_pressItem = function (itemElt, event) { if (!this.disableClickToFocus && this.itemFocusable) { this.elt.$selectlistBox.viewListAtItem(itemElt.data); //todo: focus } }; Object.defineProperty(MSMItemsViewController.prototype, 'disableClickToFocus', { set: function (value) { if (value) { this.elt.addClass('as-disable-click-to-focus'); } else { this.elt.removeClass('as-disable-click-to-focus'); } }, get: function () { return this.elt.hasClass('as-disable-click-to-focus'); } }); Object.defineProperty(MSMItemsViewController.prototype, 'itemFocusable', { set: function (value) { if (value) { this.elt.addClass('as-item-focusable'); } else { this.elt.removeClass('as-item-focusable'); } this._updateFocusItem(); }, get: function () { return this.elt.hasClass('as-item-focusable'); } }); Object.defineProperty(MSMItemsViewController.prototype, 'activeValue', { set: function (value) { this._activeValue = value; if (this.itemFocusable) { this._updateFocusItem(); //todo } }, get: function () { return this._activeValue; } }); /** * * @param {MultiCheckMenu} elt * @constructor */ function MSMBoxController(elt) { Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) this[key] = this[key].bind(this); }); this.elt = elt; if (this.elt.$selectlistBox.cancelWaiting) this.elt.$selectlistBox.cancelWaiting(); this.lockOpen = false; this.elt.on('mousedown', this.ev_click); this.elt.$selectlistBox.on({ preupdateposition: this.ev_preUpdateListPosition, change: this.ev_listChange, cancel: this.ev_listCancel, close: this.ev_listClose }); } Object.defineProperty(MSMBoxController.prototype, 'isFocus', { /** * @this MSMBoxController * @returns {*} */ set: function (value) { value = !!value; if (value) { this.open(); } else { this.close(); } }, /** * @this MSMBoxController * @returns {*} */ get: function () { return this.elt.hasClass('as-focus'); } }); MSMBoxController.prototype.open = function () { if (this.lockOpen || this.elt.disabled || this.elt.readOnly) return; if (this.elt.hasClass('as-focus')) return; this.elt.addClass('as-focus'); this.elt.$selectlistBox.addTo(document.body); this.elt.off('mousedown', this.ev_click); var bound = this.elt.getBoundingClientRect(); if (!BrowserDetector/* default.isMobile */.Z.isMobile)// not modal this.elt.$selectlistBox.addStyle('min-width', Math.max(bound.width, this.elt.$selectlistBox.getFontSize() * 18.5) + 'px'); this.elt.$selectlistBox.followTarget = this.elt; this.addListennerTO = setTimeout(() => { document.addEventListener('mousedown', this.ev_mousedownOut); if (!BrowserDetector/* default.isMobile */.Z.isMobile) { this.elt.$selectlistBox.focus(); this.elt.$selectlistBox.viewListAtFirstSelected(); } }, 50); }; MSMBoxController.prototype.close = function () { if (!this.elt.hasClass('as-focus')) return; this.elt.removeClass('as-focus'); this.elt.$selectlistBox.resetSearchState(); this.elt.$selectlistBox.selfRemove(); clearTimeout(this.addListennerTO); document.removeEventListener('mousedown', this.ev_mousedownOut); this.elt.on('mousedown', this.ev_click); var values = this.elt.$selectlistBox.values; if (!(0,DataStructure_Array.arrayCompare)(values, this.elt.commitedValues)) { this.elt.commitedValues = values; this.elt.emit('change', Object.assign({}, event, { type: 'change', action: 'submit', target: this, }), this); } }; MSMBoxController.prototype.ev_click = function (event) { if (hitClose(event)) return; this.open(); }; MSMBoxController.prototype.ev_preUpdateListPosition = function () { var bound = this.elt.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.elt.$selectlistBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this.elt); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { if (!BrowserDetector/* default.isMobile */.Z.isMobile) this.close(); } }; MSMBoxController.prototype.ev_listChange = function (event) { setTimeout(() => { this.elt.itemsViewCtrl.viewItems(this.elt.$selectlistBox.selectedItems); }, 1); }; MSMBoxController.prototype.ev_listCancel = function () { this.elt.$selectlistBox.values = this.elt.commitedValues; this.close(); this.elt.itemsViewCtrl.update(); }; MSMBoxController.prototype.ev_listClose = function (event) { var newValues = this.elt.$selectlistBox.values; if (!(0,DataStructure_Array.arrayCompare)(this.elt.commitedValues, newValues)) { this.elt.commitedValues = newValues; this.elt.emit('change', Object.assign({}, event, { type: 'change', target: this.elt, originalEvent: event.originalEvent || event })); } this.elt.itemsViewCtrl.update(); this.close(); }; MSMBoxController.prototype.ev_mousedownOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.elt.$selectlistBox, event)) return; if (!this.elt.disableClickToFocus && this.elt.itemFocusable && hitItem(event)) return; this.lockOpen = true; this.close(); document.addEventListener('mouseup', this.ev_mouseupOut); }; MSMBoxController.prototype.ev_mouseupOut = function () { setTimeout(() => { this.lockOpen = false; }, 50); }; ACore/* default.install */.Z.install(MultiCheckMenu); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/chrometime24picker.css var chrometime24picker = __webpack_require__(9216); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ChromeTime24Picker.js /** * * @param {number} leftOffset */ function calcMinHMTime(leftOffset) { var h = Math.floor(leftOffset / datetime.MILLIS_PER_HOUR); var m = Math.floor(leftOffset / datetime.MILLIS_PER_MINUTE) % 60; if (leftOffset % datetime.MILLIS_PER_MINUTE > 0) { if (m === 59) { h++; m = 0; } else { m++; } } var offset = h * datetime.MILLIS_PER_HOUR + m * datetime.MILLIS_PER_MINUTE; return { m: m, h: h, offset: offset }; } /*** * @extends AElement * @constructor */ function ChromeTime24Picker() { var tText = `24 ${LanguageSystem/* default.getText */.ZP.getText('txt_next_day') || 'Next day'})`; this.addStyle('--next-day-h24-width', Math.ceil((0,utils.measureText)(tText, '16px arial').width + 15) + 'px'); this.$lists = (0,ACore.$$)('.as-chrome-time-picker-list', this); this.$scrollers = (0,ACore.$$)('.as-chrome-time-picker-scroller', this); this.minuteController = new CTPMinuteListController(this); this.hourController = new CTPHourListController(this); this._dayOffset = 0; this._value = 0; /** * @name dayOffset * @type {number} * @memberOf ChromeTime24Picker# */ /** * @name value * @type {number | null} * @memberOf ChromeTime24Picker# */ } ChromeTime24Picker.tag = 'ChromeTime24Picker'.toLowerCase(); ChromeTime24Picker.render = function () { return (0,ACore._)({ extendEvent: 'change', class: ['as-chrome-time-24-picker', 'as-chrome-time-picker'], child: [ { class: ['as-chrome-time-picker-scroller', 'as-chrome-time-24-picker-hour', 'as-chrome-time-picker-infinity-scroller'], child: [ { tag: 'button', class: 'as-chrome-time-picker-scroller-up', child: 'span.mdi.mdi-chevron-up' }, { tag: 'button', class: 'as-chrome-time-picker-scroller-down', child: 'span.mdi.mdi-chevron-down' }, { class: ['as-chrome-time-picker-infinity-viewport', 'as-chrome-time-picker-h24', 'as-chrome-time-picker-list'], child: Array(25).fill(0).map(function (u, i) { return { tag: 'button', class: 'as-chrome-time-picker-btn', child: [ { tag: 'span', child: { text: i + '' } }, { tag: 'span', class: 'as-chrome-time-24-picker-tomorrow-text', child: { text: ` (${LanguageSystem/* default.getText */.ZP.getText('txt_next_day') || 'Next day'})` } } ], props: { __hour__: i } } }) } ] }, { class: ['as-chrome-time-picker-scroller', 'as-chrome-time-picker-infinity-scroller'], child: [ { tag: 'button', class: 'as-chrome-time-picker-scroller-up', child: 'span.mdi.mdi-chevron-up' }, { tag: 'button', class: 'as-chrome-time-picker-scroller-down', child: 'span.mdi.mdi-chevron-down' }, { class: ['as-chrome-time-picker-infinity-viewport', 'as-chrome-time-picker-m60', 'as-chrome-time-picker-list'], child: Array(60).fill(0).map(function (u, i) { return { tag: 'button', class: 'as-chrome-time-picker-btn', child: { tag: 'span', child: { text: i + '' } }, props: { __min__: i } } }) } ] } ] }); }; ChromeTime24Picker.prototype.updateViewByValue = function () { var offset = this.dayOffset; var offsetMH = calcMinHMTime(offset); var value = this.value; this.hourController.hourOffset = offsetMH.h; var valueMH; if ((0,utils.isRealNumber)(value)) { valueMH = calcMinHMTime(offset + value); this.hourController.hour = valueMH.h; if (valueMH.h === offsetMH.h) { this.minuteController.activeItem(offsetMH.m, Infinity); } else if (valueMH.h === offsetMH.h + 24) { this.minuteController.activeItem(Infinity, offsetMH.m + 1); } this.minuteController.minute = valueMH.m; } else { this.hourController.hour = null; this.minuteController.minute = null; } }; ChromeTime24Picker.prototype.scrollIntoSelected = function () { this.hourController.scrollIntoSelected(true); this.minuteController.scrollIntoSelected(true); }; ChromeTime24Picker.prototype.flushViewToValue = function () { var hour = this.hourController.hour; var minute = this.minuteController.minute; var endMil, newValue; if ((0,utils.isRealNumber)(hour) && (0,utils.isRealNumber)(minute)) { endMil = hour * datetime.MILLIS_PER_HOUR + minute * datetime.MILLIS_PER_MINUTE; newValue = endMil - this.dayOffset; if (newValue !== this._value) { this._value = newValue; this.notifyChange(); } } }; ChromeTime24Picker.prototype.notifyChange = function () { this.emit('change', { type: 'change' }, this); }; ChromeTime24Picker.property = {}; ChromeTime24Picker.property.dayOffset = { /*** * @this ChromeTime24Picker * @param {number|Date} value */ set: function (value) { if (value instanceof Date) { value = value.getTime() - (0,datetime.beginOfDay)(value).getTime(); } if ((0,utils.isRealNumber)(value)) { value = Math.round(value); value = value % datetime.MILLIS_PER_DAY; if (value < 0) value += datetime.MILLIS_PER_DAY; } else { value = 0; } this._dayOffset = calcMinHMTime(value).offset;//round to minute this.updateViewByValue(); }, /** * @this ChromeTime24Picker * @returns {number|*} */ get: function () { return this._dayOffset; } }; ChromeTime24Picker.property.value = { /*** * @this ChromeTime24Picker * @param value */ set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.min(datetime.MILLIS_PER_DAY, Math.max(0, Math.round(value))); value = calcMinHMTime(value).offset; } else { value = null; } this._value = value; this.updateViewByValue(); }, /** * @this ChromeTime24Picker * @returns {number|*} */ get: function () { return this._value; } }; ChromeTime24Picker.property.hour = { get: function () { return Math.floor((this.dayOffset + this.value) / datetime.MILLIS_PER_HOUR); } }; ChromeTime24Picker.property.minute = { get: function () { return Math.floor((this.dayOffset + this.value) / datetime.MILLIS_PER_MINUTE) % 60; } }; ACore/* default.install */.Z.install(ChromeTime24Picker); /* harmony default export */ const js_ChromeTime24Picker = (ChromeTime24Picker); function CTPHourListController(elt) { for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.elt = elt; this.hourScroller = new CTPInfinityVerticalScroller(this.elt.$scrollers[0]); this.$list = (0,ACore.$)('.as-chrome-time-picker-h24.as-chrome-time-picker-list', elt); this.$items = Array.prototype.slice.call(this.$list.childNodes); this.$list.on('click', this.ev_clickList); this._offset = 0; this.selectedValue = null; this.$selectedItem = null; this.itemLength = this.$items.length; /** * @type {number} * @name hour - from 0 to 23, 24... is next day * @memberOf CTPHourListController */ } Object.defineProperty(CTPHourListController.prototype, 'hourOffset', { set: function (value) { if (!(0,utils.isRealNumber)(value)) value = 0; value = Math.round(value); value = value % 24; if (value < 0) value += 24; this._offset = value; for (var i = 0; i < this.$items.length; ++i) { this.$items[i].firstChild.firstChild.data = (i + value)% 24; this.$items[i].__hour__ = i + value; if ((value + i) >= 24) { this.$items[i].addClass('as-in-tomorrow'); } else { this.$items[i].removeClass('as-in-tomorrow'); } } this.updateSelected(); }, get: function () { return this._offset; } }); CTPHourListController.prototype.updateSelected = function () { if (this.$selectedItem) { this.$selectedItem.removeClass('as-selected'); } if ((0,utils.isRealNumber)(this.selectedValue)) { this.$selectedItem = this.$items[this.selectedValue - this._offset]; } else { this.$selectedItem = null; } if (this.$selectedItem) { this.$selectedItem.addClass('as-selected'); } }; CTPHourListController.prototype.ev_clickList = function (event) { this.hour = this.itemValueOf(event.target); this.scrollIntoSelected(false); var offsetMH = calcMinHMTime(this.elt.dayOffset); if (this.hour === offsetMH.h) { this.elt.minuteController.activeItem(offsetMH.m, Infinity); if (!(0,utils.isRealNumber)(this.elt.minuteController.minute) || this.elt.minuteController.minute < offsetMH.m) { this.elt.minuteController.minute = offsetMH.m; this.elt.minuteController.scrollIntoSelected(true); } } else if (this.hour === offsetMH.h + 24) { this.elt.minuteController.activeItem(Infinity, offsetMH.m + 1); if (!(0,utils.isRealNumber)(this.elt.minuteController.minute) || this.elt.minuteController.minute > offsetMH.m ) { this.elt.minuteController.minute = offsetMH.m; this.elt.minuteController.scrollIntoSelected(true); } } else { if (!(0,utils.isRealNumber)(this.elt.minuteController.minute)) { this.elt.minuteController.minute = 0; this.elt.minuteController.scrollIntoSelected(true); } this.elt.minuteController.activeItem(Infinity, Infinity); } this.elt.flushViewToValue(); }; CTPHourListController.prototype.scrollIntoSelected = function (onTop) { if (this.selectedValue == null) return; var curOffset = this.hourScroller.offset; var targetOffset = this.selectedValue - this.hourOffset; var k, minCost = Infinity; var cost; var t; for (k = -2; k <= 2; ++k) { t = (this.selectedValue - this.hourOffset)+ k * this.itemLength; if (t >= curOffset && t <= curOffset + 3 && !onTop) { minCost = 0; targetOffset = curOffset; } else { cost = Math.abs(t - curOffset); if (cost < minCost) { minCost = cost; targetOffset = t; } cost = Math.abs(t - curOffset - 3); if (cost < minCost && !onTop) { minCost = cost; targetOffset = t - 3; } } } this.hourScroller.makeAnimation(targetOffset, 200); }; CTPHourListController.prototype.itemValueOf = function (itemElt) { while (itemElt) { if (itemElt.hasClass && itemElt.hasClass('as-chrome-time-picker-btn')) break; itemElt = itemElt.parentElement; } if (!itemElt) return undefined; return itemElt.__hour__; }; Object.defineProperty(CTPHourListController.prototype, 'hour', { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.round(value); } else { value = null; } this.selectedValue = value; this.updateSelected(); }, get: function () { return this.selectedValue; } }); function CTPInfinityVerticalScroller(elt) { this.elt = elt; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.$upBtn = (0,ACore.$)('.as-chrome-time-picker-scroller-up', this.elt) .on('pointerdown', this.ev_pressUpBtn); this.$downBtn = (0,ACore.$)('.as-chrome-time-picker-scroller-down', this.elt) .on('pointerdown', this.ev_pressDownBtn); this.$upBtn.addEventListener('contextmenu', function (event) { event.preventDefault(); }, BrowserDetector/* default.supportPassiveEvent */.Z.supportPassiveEvent ? { passive: false } : true); this.$downBtn.addEventListener('contextmenu', function (event) { event.preventDefault(); }, BrowserDetector/* default.supportPassiveEvent */.Z.supportPassiveEvent ? { passive: false } : true); this.$viewport = (0,ACore.$)('.as-chrome-time-picker-infinity-viewport', this.elt); this.offset = 0; this.buttonHeight = 28;//2em this.elt.addEventListener('wheel', this.ev_wheel); this.$items = (0,ACore.$$)('.as-chrome-time-picker-btn', this.$viewport); this.updateItemPosition(); this.$viewport.addEventListener('touchstart', this.ev_touchStart, BrowserDetector/* default.supportPassiveEvent */.Z.supportPassiveEvent ? { passive: false } : true); /** * * @type {null|{startTime: number, endTime: number, startValue: number, endValue: number, type: string}} */ this.animation = null; this.touchInfo = {}; } CTPInfinityVerticalScroller.prototype.ev_touchStart = function (event) { var evFlag = BrowserDetector/* default.supportPassiveEvent */.Z.supportPassiveEvent ? { passive: false } : true; document.addEventListener('touchmove', this.ev_touchMove, evFlag); document.addEventListener('touchend', this.ev_touchEnd, evFlag); var touch = event.changedTouches[0]; var now = Date.now(); this.touchInfo.prevY = touch.clientY; this.touchInfo.prevTime = now; this.touchInfo.target = touch.target; this.touchInfo.identifier = touch.identifier; this.touchInfo.state = 0;//init this.touchInfo.checkPoints = [{ time: now, y: touch.clientY }]; event.preventDefault(); }; CTPInfinityVerticalScroller.prototype.ev_touchMove = function (event) { var touch = (0,EventEmitter/* findChangedTouchByIdent */.VY)(event, this.touchInfo.identifier); if (!touch) return; var dy = touch.clientY - this.touchInfo.prevY; var now = Date.now(); if (this.touchInfo.state === 0) { if (Math.abs(dy) > 2) { this.touchInfo.state = 1; } } if (this.touchInfo.state === 1) { this.makeAnimation(this.offset - dy / this.buttonHeight, 0); this.touchInfo.prevY = touch.clientY; this.touchInfo.prevTime = now; this.touchInfo.checkPoints.push({ time: now, y: touch.clientY }); } event.preventDefault(); }; /** * * @returns {number} - offset/s */ CTPInfinityVerticalScroller.prototype.getTouchSped = function () { var checkPoints = this.touchInfo.checkPoints; if (checkPoints.length < 2) return 0; var minTime = 100; var lastTime = checkPoints[checkPoints.length - 1].time; var dy; var dt; for (var i = checkPoints.length - 2; i >= 0; --i) { dy = checkPoints[i].y - checkPoints[checkPoints.length - 1].y; dt = checkPoints[i].time - checkPoints[checkPoints.length - 1].time; if (lastTime - checkPoints[i].time > minTime) break } if (dy === 0) return 0; return dy / this.buttonHeight / (dt / 1000); }; CTPInfinityVerticalScroller.prototype.ev_touchEnd = function (event) { var touch = (0,EventEmitter/* findChangedTouchByIdent */.VY)(event, this.touchInfo.identifier); if (!touch) return; var evFlag = BrowserDetector/* default.supportPassiveEvent */.Z.supportPassiveEvent ? { passive: false } : true; document.removeEventListener('touchmove', this.ev_touchMove, evFlag); document.removeEventListener('touchend', this.ev_touchEnd, evFlag); var speed = 0, acc = 10; var target; if (this.touchInfo.state === 1) { speed = this.getTouchSped(); this.makeAnimation(this.offset - speed * Math.abs(speed) / acc / 2, Math.abs(speed) / acc * 1000, 'pow2'); } else { target = this.touchInfo.target; var now = Date.now(); while (target && target !== this.elt) { if (target.isSupportedEvent && target.isSupportedEvent('press')) { if (!target.lastPressTime || now - target.lastPressTime > 300) { target.emit('press', { target: this.touchInfo.target }); target.lastPressTime = now; } } target = target.parentElement; } } }; CTPInfinityVerticalScroller.prototype.ev_pressUpBtn = function (event) { this.makeAnimation(this.offset - 250, 25e3, 'linear'); document.addEventListener('pointerup', this.ev_ReleaseUpDownBtn); event.preventDefault(); }; CTPInfinityVerticalScroller.prototype.ev_pressDownBtn = function (event) { this.makeAnimation(this.offset + 250, 25 * 1000, 'linear'); document.addEventListener('pointerup', this.ev_ReleaseUpDownBtn); event.preventDefault(); }; CTPInfinityVerticalScroller.prototype.ev_ReleaseUpDownBtn = function (event) { this.makeAnimation(this.offset, 0); event.preventDefault(); }; CTPInfinityVerticalScroller.prototype.updateItemPosition = function () { while (this.offset < 0) this.offset += this.$items.length; while (this.offset >= this.$items.length) this.offset -= this.$items.length; var offset = this.offset; this.$items.forEach((itemElt, i) => { var k = i - offset; if (k < -this.$items.length / 2) k += this.$items.length; itemElt.addStyle('top', k * 2 + 'em'); }); }; CTPInfinityVerticalScroller.prototype.ev_wheel = function (event) { event.preventDefault(); var delta = event.deltaY; this.makeAnimation(this.offset + delta / this.buttonHeight, 200); }; CTPInfinityVerticalScroller.prototype.makeAnimation = function (value, inTime, type) { if (inTime <= 0) { this.offset = value; this.updateItemPosition(); this.animation = null; return; } var isNewAnimation = !this.animation; this.animation = { startTime: Date.now(), endTime: Date.now() + inTime, startValue: this.offset, endValue: value, type: type || 'linear' }; if (isNewAnimation) { requestAnimationFrame(this.ev_animationFrame); } }; CTPInfinityVerticalScroller.prototype.ev_animationFrame = function () { if (!this.animation) return; function easeInOutCubic(t) { return t < 0.5 ? 4 * t * t * t : 1 - Math.pow(-2 * t + 2, 3) / 2; } var now = Date.now(); var t = (0,Math_int.map)(Math.min(this.animation.endTime, now), this.animation.startTime, this.animation.endTime, 0, 1); if (this.animation.type === 'easeIn') { t = easeInOutCubic(t / 2); } else if (this.animation.type === 'easeOut') { t = easeInOutCubic(0.5 + t / 2); } else if (this.animation.type === 'pow2') { t = Math.sqrt(t); } this.offset = (0,Math_int.map)(t, 0, 1, this.animation.startValue, this.animation.endValue); this.updateItemPosition(); if (now >= this.animation.endTime) { this.animation = null; } else { requestAnimationFrame(this.ev_animationFrame); } }; /** * @param {ChromeTime24Picker} elt * @param elt * @constructor */ function CTPMinuteListController(elt) { for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.elt = elt; this.minuteScroller = new CTPInfinityVerticalScroller(this.elt.$scrollers[1]); this.$list = (0,ACore.$)('.as-chrome-time-picker-m60', this.elt); this.$list.defineEvent('press'); this.$list.addEventListener('click', function (event) { var now = Date.now(); if (!this.lastPressTime || now - this.lastPressTime > 50) { this.emit('press', { target: event.target }); this.lastPressTime = now; } }, true); this.$list.on('press', this.ev_clickList); this.$items = Array.prototype.slice.call(this.$list.childNodes); this.selectedValue = null; this.itemLength = this.$items.length; } /** * * @param start * @param end - end not include */ CTPMinuteListController.prototype.activeItem = function (start, end) { if (!(0,utils.isNaturalNumber)(start)) start = 0; if (!(0,utils.isNaturalNumber)(end)) end = this.$list.children.length; for (var i = 0; i < this.$list.children.length; ++i) { this.$list.children[i].disabled = i < start || i >= end; } }; CTPMinuteListController.prototype.ev_clickList = function (event) { var value = this.itemValueOf(event.target); if ((0,utils.isNaturalNumber)(value)) { this.minute = value; this.scrollIntoSelected(false); this.elt.flushViewToValue(); } }; CTPMinuteListController.prototype.itemValueOf = function (itemElt) { while (itemElt) { if (itemElt.hasClass && itemElt.hasClass('as-chrome-time-picker-btn')) break; itemElt = itemElt.parentElement; } if (!itemElt) return undefined; return itemElt.__min__; }; CTPMinuteListController.prototype.scrollIntoSelected = function (onTop) { if (this.selectedValue == null) return; var curOffset = this.minuteScroller.offset; var targetOffset = this.selectedValue; var k, minCost = Infinity; var cost; var t; for (k = -2; k <= 2; ++k) { t = this.selectedValue + k * this.itemLength; if (t >= curOffset && t <= curOffset + 3 && !onTop) { minCost = 0; targetOffset = curOffset; } else { cost = Math.abs(t - curOffset); if (cost < minCost) { minCost = cost; targetOffset = t; } cost = Math.abs(t - curOffset - 3); if (cost < minCost && !onTop) { minCost = cost; targetOffset = t - 3; } } } this.minuteScroller.makeAnimation(targetOffset, 200); }; Object.defineProperty(CTPMinuteListController.prototype, 'minute', { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.max(0, Math.min(59, Math.round(value))); } else { value = null; } if (value !== this.selectedValue) { if (this.$items[this.selectedValue]) { this.$items[this.selectedValue].removeClass('as-selected'); } } this.selectedValue = value; if (this.$items[value]) { this.$items[value].addClass('as-selected'); } }, get: function () { return this.selectedValue; } }); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/Time24Input.js /** * @extends AElement * @constructor */ function Time24Input() { var t = LanguageSystem/* default.getText */.ZP.getText('txt_next_day'); if (t) { t = '(' + t + ')'; this.nextDateText = t; } this.domSignal = new DelaySignal/* default */.Z(); this.$clockBtn = (0,ACore.$)('.as-time-input-icon-btn', this) this.$text = (0,ACore.$)('.as-time-input-text', this); this.$clearBtn = (0,ACore.$)('button.as-time-input-clear-btn', this) .on('click', this.clear.bind(this)); this._hour = 0; this._minute = 0; this._nd = false; this._dayOffset = 0; this._format = 'HH:mm ND'; this._firedValue = 'NOT_FIRED'; this.textCtrl = new T24ITextController(this); this.notNull = true; this.dropdownCtn = new T24DropdownController(this); setTimeout(() => { }, 1000); /** * @type {string} * @name format * @memberof Time24Input# */ /** * @type {number|null} * @name hour * @memberof Time24Input# */ /** * @type {number|null} * @name minute * @memberof Time24Input# */ /** * @type {number} always is a number, set dayOffset, keep value * @name dayOffset * @memberof Time24Input# */ /** * computed from other * @type {number|null} * @name value * @memberof Time24Input# */ /** * @type {boolean} * @name nd * @memberof Time24Input# */ } Time24Input.tag = 'Time24Input'.toLowerCase(); Time24Input.prototype.nextDateText = '(Next day)'; Time24Input.render = function () { return (0,ACore._)({ class: ['ac-time-input', 'as-time-24-input'], extendEvent: ['change'], child: [ { tag: 'input', class: 'as-time-input-text', attr: { type: 'text', spellcheck: "false" } }, { tag: 'button', class: 'as-time-input-clear-btn', child: 'span.mdi.mdi-close-circle' }, { tag: 'button', class: 'as-time-input-icon-btn', child: 'span.mdi.mdi-clock-outline' } ] }); }; Time24Input.prototype._notifyChange = function (event) { this._firedValue = this.value; this.emit('change', { type: 'change', originalEvent: (event && (event.originalEvent || event.originEvent)) || event }, this); }; Time24Input.prototype.notifyIfChange = function () { if (this._firedValue !== this.value) { this._notifyChange(); } }; Time24Input.prototype.clear = function (event) { if (this.value !== null && !this.notNull) { this.value = null; this._notifyChange(event); } }; Time24Input.prototype.share = { $picker: null, /*** * @type Time24Input */ $holdingInput: null, $follower: null, $closeBtn: null }; Time24Input.property = {}; Time24Input.property.hour = { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.round(value); if (value < 0) { value = Math.ceil(-value / 24) * 24 + value } value = value % 24; } else { value = null; } this._hour = value; this.textCtrl.updateTextFromValue(); }, get: function () { return this._hour; } }; Time24Input.property.minute = { set: function (value) { if ((0,utils.isRealNumber)(value)) { value = Math.round(value); if (value < 0) { value = Math.ceil(-value / 60) * 60 + value } value = value % 60; } else { value = null; } this._minute = value; this.textCtrl.updateTextFromValue(); }, get: function () { return this._minute; } }; Time24Input.property.nd = { set: function (value) { this._nd = !!value; this.textCtrl.updateTextFromValue(); }, get: function () { var value = this._nd; var hour = this.hour; var minute = this.minute; var dayOffset = this.dayOffset; var mh; if ((0,utils.isRealNumber)(dayOffset)) { if ((0,utils.isNaturalNumber)(hour)) { mh = (0,utils.millisToClock)(dayOffset); if (hour < mh.hour) { value = true; } else if (hour === mh.hour) { if ((0,utils.isRealNumber)(minute) && minute < mh.minute) { value = true; } } } } return value; } } Time24Input.property.dayOffset = { set: function (dayOffset) { var value = this.value; this._dayOffset = (0,utils.isRealNumber)(dayOffset) ? (0,utils.normalizeMinuteOfMillis)(dayOffset) : 0; this.value = value; }, get: function () { if (this.notNull) { return this._dayOffset || 0; } else { return this._dayOffset; } } }; Time24Input.property.value = { set: function (value) { value = (0,utils.isRealNumber)(value) ? (0,utils.normalizeMinuteOfMillis)(Math.min(Math.max(value, 0), datetime.MILLIS_PER_DAY)) : null; var clockTime; if (value !== null) { clockTime = (0,utils.millisToClock)(value + this.dayOffset); this._hour = clockTime.hour; this._minute = clockTime.minute; if (value === datetime.MILLIS_PER_DAY) this._nd = true; } else { this._hour = null; this._minute = null; } this.textCtrl.updateTextFromValue(); this._firedValue = this.value; }, get: function () { if (!(0,utils.isRealNumber)(this._hour) || !(0,utils.isRealNumber)(this._minute)) return null; var mil = (0,utils.clockToMillis)(this._hour, this._minute); if (mil < this.dayOffset||(mil === this.dayOffset && this._nd)) mil += datetime.MILLIS_PER_DAY; mil -= this.dayOffset; return mil; } }; Time24Input.property.displayTime = { get: function () { var value = this.value; if ((0,utils.isRealNumber)(value)) { return value + this.dayOffset; } else { return null; } } }; Time24Input.property.notNull = { set: function (value) { if (value) { if (this.value === null) { this.value = 0; } this.addClass('as-must-not-null'); } else { this.removeClass('as-must-not-null'); } this._firedValue = this.value; }, get: function () { return this.hasClass('as-must-not-null'); } }; Time24Input.property.disabled = { set: function (value) { value = !!value; this._disabled = value; if (value) this.addClass('as-disabled'); else this.removeClass('as-disabled'); this.$text.disabled = value; }, get: function () { return this._disabled; } }; Time24Input.property.readOnly = js_TimeInput.property.readOnly; Time24Input.property.format = { set: function (value) { this._format = value || 'HH:mm'; if (this._format.indexOf('ND') < 0) { this._format = this._format.trimEnd() + ' ND'; } this.textCtrl.updateTextFromValue(); }, get: function () { return this._format; } }; Time24Input.eventHandler = {}; Time24Input.eventHandler.pickerChange = function (event) { if (this.dayOffset === null) this.dayOffset = 0; }; Time24Input.eventHandler.clickClockBtn = function () { this._attachPicker(); }; ACore/* default.install */.Z.install(Time24Input); /* harmony default export */ const js_Time24Input = (Time24Input); /** * * @param {Time24Input} elt * @constructor */ function T24DropdownController(elt) { this.elt = elt; this.$clockBtn = elt.$clockBtn.on('click', this.ev_clickClockBtn.bind(this)); this.disabledButtton = false; this.ev_clickOut = this.ev_clickOut.bind(this); } T24DropdownController.prototype.share = { $picker: null, $holdingInput: null, /** * @type {Follower|null} */ $follower: null, /** * @type {T24DropdownController|null} */ holder: null }; T24DropdownController.prototype.prepare = function () { var share = this.share; if (share.$picker) return; (0,MultiLanguageCSS/* loadLanguageModule */.q)(); share.$picker = (0,ACore._)({ tag: js_ChromeTime24Picker.tag, on: { change: (event) => { if (share.holder) { share.holder.onPickerChange(event); } } } }); share.$picker.nextDateText = this.elt.nextDateText; /** * @type {Follower} */ share.$follower = (0,ACore._)({ tag: 'follower', class: ['as-chrome-time-24-picker-follower', 'as-dropdown-box-common-style'], child: [ this.share.$picker, { class: 'as-dropdown-box-footer', child: [ { class: 'as-dropdown-box-footer-right', child: ['<a data-ml-key="txt_close" class="as-select-list-box-close-btn"></a>'] } ] } ] }); share.$follower.cancelWaiting(); this.share.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this.share.$follower); }; T24DropdownController.prototype.attach = function () { this.prepare(); var share = this.share; if (share.holder) { share.holder.release(); } share.holder = this; this.disabledButtton = true; share.$follower.addTo(document.body); share.$follower.followTarget = this.elt; share.$follower.addStyle('visibility', 'hidden'); var hour = this.elt.hour; var min = this.elt.minute; var dayOffset = this.elt.dayOffset; share.$picker.dayOffset = dayOffset; var offsetClock = (0,utils.millisToClock)(dayOffset); var value = 0; if ((0,utils.isRealNumber)(hour)) { if (!(0,utils.isRealNumber)(min)) { if (hour === offsetClock.hour) { min = offsetClock.hour; } else { min = 0; } } value = (0,utils.clockToMillis)(hour, min) - dayOffset; if (value < 0) value += datetime.MILLIS_PER_DAY; } else if ((0,utils.isRealNumber)(min)) { if (min >= offsetClock.minute) { hour = offsetClock.hour; } else { hour = (offsetClock.hour + 1) % 24; } value = (0,utils.clockToMillis)(hour, min) - dayOffset; if (value < 0) value += datetime.MILLIS_PER_DAY; } if (value === 0 && this.elt.nd) value = datetime.MILLIS_PER_DAY; share.$picker.value = value; setTimeout(() => { document.addEventListener('click', this.ev_clickOut); share.$follower.removeStyle('visibility'); share.$picker.scrollIntoSelected(); }, 10); }; T24DropdownController.prototype.release = function () { var share = this.share; if (share.holder !== this) return; share.$follower.remove(); share.$follower.followTarget = null; share.holder = null; setTimeout(() => { this.disabledButtton = false; document.removeEventListener('click', this.ev_clickOut); }, 100); }; T24DropdownController.prototype.onPickerChange = function (event) { this.elt.value = this.share.$picker.value; this.elt._notifyChange(event); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }; T24DropdownController.prototype.ev_clickClockBtn = function () { if (this.disabledButtton) return; this.attach(); }; T24DropdownController.prototype.ev_clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$follower, event) && !(0,EventEmitter/* hitElement */.EY)(this.share.$closeBtn, event)) return; this.release(); }; var Time24Input_STATE_NEW = 1; var Time24Input_STATE_EDITED = 2; var Time24Input_STATE_NONE = 0; /** * * @param {Time24Input} elt * @constructor */ function T24ITextController(elt) { this.elt = elt; this.domSignal = elt.domSignal; this.$text = this.elt.$text; this.$text.on('keydown', this.ev_keydown.bind(this)).on('pointerup', this.autoSelect.bind(this)) .on('blur', () => { this.loadValueFromInput(); this.elt.notifyIfChange(); }); this.editingData = {}; } T24ITextController.prototype.tokenRegex = /(\([^)]*\))|([^.\/:\-,\\\u0020\u0009\u000D\u200B]+)|([.\/:\-,\\]+)/i; var CHAR_NBSP = '\u00A0'; T24ITextController.prototype.tokenMap = { h: 'h', H: 'H', HH: 'H', hh: 'h', m: 'm', mm: 'm', a: 'a', ND: 'ND' }; T24ITextController.prototype.makeTokenDict = function (s) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var rgxFormat = new RegExp(this.tokenRegex.source, 'g'); var format = this.elt.format + ' ND'; var tokenMap = this.tokenMap; var tokenMatched = rgx.exec(s); var formatToken = rgxFormat.exec(format); var text, ident; var idx; var res = {}; while (tokenMatched && formatToken) { ident = formatToken[2]; if (tokenMap[ident]) { text = tokenMatched[0]; idx = tokenMatched.index; res[tokenMap[ident]] = { text: text, idx: idx, length: text.length, sourceText: s, value: (ident === 'a' || ident === 'ND') ? text : parseInt(text) } if (ident === 'ND') { res[tokenMap[ident]].value = res[tokenMap[ident]].value !== CHAR_NBSP; } } tokenMatched = rgx.exec(s); formatToken = rgxFormat.exec(format); } Object.defineProperty(res, 'minute', { enumerable: false, get: function () { var token = this['m'] || this['mm']; if (token) { return token.value; } else return null; } }); Object.defineProperty(res, 'hour24', { enumerable: false, get: function () { var token = this['H']; if (token && (0,utils.isNaturalNumber)(token.value)) { return token.value; } token = this['h']; var tokenA = this['A']; if (token && (0,utils.isNaturalNumber)(token.value)) { if (tokenA.value === 'PM') { return 12 + (token.value % 12); } else return token.value % 12; } return null; } }); return res; }; T24ITextController.prototype.formatText = function (h, m, nd) { var text = this.elt.format; text = text.replace(new RegExp(this.tokenRegex.source, 'g'), (all) => { switch (all) { case 'm': case 'mm': return (0,utils.isRealNumber)(m) ? (0,utils.zeroPadding)(m, all.length) : all; case 'hh': case 'h': return (0,utils.isRealNumber)(h) ? (0,utils.zeroPadding)(h % 12 ? h : 12, all.length) : all; case 'HH': case 'H': return (0,utils.isRealNumber)(h) ? (0,utils.zeroPadding)(h, all.length) : all; case 'a': return (0,utils.isRealNumber)(h) ? (h > 12 ? 'PM' : 'AM') : 'all'; case 'ND': return nd ? this.elt.nextDateText : CHAR_NBSP; default: return all; } }); return text; }; T24ITextController.prototype.updateTextFromValue = function () { var value = this.elt.value; var hour = this.elt.hour; var minute = this.elt.minute; var nd = this.elt.nd; var text = this.formatText(hour, minute, nd); if ((0,utils.isRealNumber)(value)) { this.elt.removeClass('as-value-null'); } else { this.elt.addClass('as-value-null'); } this.$text.value = text; }; T24ITextController.prototype.loadValueFromInput = function () { var tkDick = this.makeTokenDict(this.$text.value); var hour = NaN; var minute = NaN; var nd = false; if (tkDick.H) { hour = Math.min(23, Math.max(0, tkDick.H.value)); } else if (tkDick.h) { hour = Math.min(12, Math.max(1, tkDick.h.value)); if (tkDick.a && tkDick.a.value === 'PM') { hour += 12; } } if (tkDick.m) { minute = Math.min(59, Math.max(0, tkDick.m.value)); } if (tkDick.nd) { nd = tkDick.nd.value; } this.elt._hour = hour; this.elt._minute = minute; this.elt._nd = nd; }; T24ITextController.prototype.autoSelect = function () { var token = this.tokenAt(this.$text.selectionStart); var tokenEnd = this.tokenAt(this.$text.selectionEnd); if (token) { if (tokenEnd.idx === token.idx) { token.select(); this.editingData.state = Time24Input_STATE_NEW; } else { this.$text.select(); this.editingData.state = Time24Input_STATE_NONE; } } }; T24ITextController.prototype.editPrevToken = function () { var token = this.tokenAt(this.$text.selectionStart); if (!token) return false; var cIdx = token.idx; for (var i = token.idx - 1; i >= 0; --i) { token = this.tokenAt(i); if (token && token.idx !== cIdx) { token.select(); this.editingData.state = Time24Input_STATE_NEW; break; } } }; T24ITextController.prototype.editNextToken = function () { var token = this.tokenAt(this.$text.selectionStart); if (!token) return false; var cIdx = token.idx; var l = this.$text.value.length; for (var i = token.idx + token.length; i < l; ++i) { token = this.tokenAt(i); if (token && token.idx !== cIdx) { token.select(); this.editingData.state = Time24Input_STATE_NEW; break; } } }; T24ITextController.prototype.tokenAt = function (start) { var tokenizedText = new TITokenizedText(this.$text.value, this.elt.format); var nearestDistance = Infinity; var nearestIdx = -1; var n = Math.min(tokenizedText.textTokens.length, tokenizedText.formatTokens.length); var i, textToken, formatToken; var distance; for (i = 0; i < n; ++i) { formatToken = tokenizedText.formatTokens[i]; if (!(0,utils.isDateTimeFormatToken)(formatToken.content)) continue; textToken = tokenizedText.textTokens[i]; if (start >= textToken.idx && start < textToken.idx + textToken.length) { nearestIdx = i; nearestDistance = 0; break; } if (start < textToken.idx) { distance = textToken.idx - start; if (distance < nearestDistance) { nearestDistance = distance; nearestIdx = i; } } if (start >= textToken.idx + textToken.length) { distance = start - textToken.idx - textToken.length; if (distance < nearestDistance) { nearestDistance = distance; nearestIdx = i; } } } if (nearestIdx < 0) return null; formatToken = tokenizedText.formatTokens[nearestIdx]; textToken = tokenizedText.textTokens[nearestIdx]; var self = this; return { idx: textToken.idx, text: textToken.content, length: textToken.length, ident: formatToken.content, input: this.$text, sourceText: tokenizedText.text, // isAvailable: function () { // return this.sourceText === this.input.value; // }, select: function () { this.input.setSelectionRange(this.idx, this.idx + this.length); }, replace: function (newText, selecting) { tokenizedText.setTokenText(this.ident, newText); var hour = tokenizedText.getTokenText('HH') || tokenizedText.getTokenText('H'); var minute = tokenizedText.getTokenText('mm') || tokenizedText.getTokenText('m'); var nd = tokenizedText.getTokenText('ND') !== CHAR_NBSP; var newND = self.isNextDate(parseInt(hour, 10), parseInt(minute, 10), nd); if (newND !== nd) { tokenizedText.setTokenText('ND', newND ? self.elt.nextDateText : CHAR_NBSP); } this.input.value = tokenizedText.getText(true); this.length = newText.length; if (selecting) { this.select(); } } }; }; /** * * @param h * @param m * @param nd - referent result if can not detect * @returns {boolean} */ T24ITextController.prototype.isNextDate = function (h, m, nd) { var dayOffset = this.elt.dayOffset; if (!(0,utils.isNaturalNumber)(dayOffset)) return !!nd; var oH = Math.floor(dayOffset / 36e5); var oM = Math.floor(dayOffset / 6e4) % 60; if (!(0,utils.isNaturalNumber)(h)) return !!nd; if (h < oH) return true; if (!(0,utils.isNaturalNumber)(m)) return !!nd; if (h === oH) { if (m < oM) return true; if (m === oM) return !!nd; return false; } }; T24ITextController.prototype.correctingInput = function () { //nothing todo now }; T24ITextController.prototype.ev_keydown = function (event) { var token = this.tokenAt(this.$text.selectionStart); var endToken = this.tokenAt(this.$text.selectionEnd); // var tokenDict = this.makeTokenDict(this.$text.value); var format = this.elt.format; if (!token) { if (event.key === 'Enter') { this.correctingInput(); this.loadValueFromInput(); this.elt.notifyIfChange(event); } return; } var newTokenText; var value; if (event.key.startsWith('Arrow')) { event.preventDefault(); switch (event.key) { case 'ArrowLeft': this.editPrevToken(); break; case 'ArrowRight': this.editNextToken(); break; case 'ArrowUp': case 'ArrowDown': switch (token.ident) { case "H": case "HH": value = parseInt(token.text); if (isNaN(value)) { this.editingData.H = event.key === 'ArrowUp' ? 0 : 23; } else { this.editingData.H = (value + (event.key === 'ArrowUp' ? 1 : 23)) % 24; } newTokenText = (0,utils.zeroPadding)(this.editingData.H, token.ident.length); token.replace(newTokenText, true); break; case "hh": case 'h': value = parseInt(token.text); if (isNaN(value)) { this.editingData.h = event.key === 'ArrowUp' ? 1 : 12; } else { this.editingData.h = 1 + (value + (event.key === 'ArrowUp' ? 0 : 10)) % 12; } newTokenText = this.editingData.h + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case "mm": case 'm': value = parseInt(token.text); if (isNaN(value)) { this.editingData.m = event.key === 'ArrowUp' ? 0 : 59; } else { this.editingData.m = (value + (event.key === 'ArrowUp' ? 1 : 59)) % 60; } newTokenText = this.editingData.m + ''; while (newTokenText.length < token.ident.length) newTokenText = '0' + newTokenText; token.replace(newTokenText, true); break; case 'a': value = token.text; this.editingData.a = value === 'PM' ? "AM" : "PM"; newTokenText = this.editingData.a; token.replace(newTokenText, true); break; case 'ND': value = token.text !== CHAR_NBSP; this.editingData.nd = !value; newTokenText = this.editingData.nd ? this.elt.nextDateText : CHAR_NBSP; token.replace(newTokenText, true); break; } break; } } else if (event.key === "Delete" || event.key === 'Backspace') { event.preventDefault(); if (endToken.idx !== token.idx) { if (this.elt.notNull) { this.$text.value = (0,datetime.formatDateTime)((0,datetime.beginOfDay)(new Date()), format).replace('ND', CHAR_NBSP); } else { this.$text.value = format.replace('ND', CHAR_NBSP); } this.$text.select(); } else { if (this.elt.notNull) { if (token.ident === 'ND') { token.replace(CHAR_NBSP, true); } else token.replace(token.ident === 'a' ? 'AM' : (0,utils.zeroPadding)((token.ident === 'hh' || token.ident === 'h') ? 12 : 0, token.ident.length), true); } else { token.replace(token.ident, true); } if (event.key === "Delete") this.editNextToken(); else this.editPrevToken(); } } else if (event.key === "Enter" || event.key === 'Tab') { this.correctingInput(); this.loadValueFromInput(); this.elt.notifyIfChange(event); } else if (event.ctrlKey) { switch (event.key) { case 'a': case 'A': break; case 'c': case 'C': break; case 'x': case 'X': this.domSignal.once('clear_value', function () { this.$text.value = format; this.$text.select(); }.bind(this)); this.domSignal.emit('clear_value'); break; default: event.preventDefault(); } } else if (event.key.match(/^[0-9]$/g)) { event.preventDefault(); var dVal = parseInt(event.key); if (this.editingData.state === Time24Input_STATE_NEW) { switch (token.ident) { case 'm': case 'mm': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editingData.state = Time24Input_STATE_EDITED; if (dVal > 5) { this.editNextToken(); } break; case 'h': case 'hh': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editingData.state = Time24Input_STATE_EDITED; if (dVal > 1) { this.editNextToken(); } break; case 'H': case 'HH': token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editingData.state = Time24Input_STATE_EDITED; if (dVal > 2) { this.editNextToken(); } break; case 'ND': value = token.text !== CHAR_NBSP; this.editingData.nd = !value; newTokenText = this.editingData.nd ? this.elt.nextDateText : CHAR_NBSP; token.replace(newTokenText, true); break; } } else { switch (token.ident) { case 'm': case 'mm': dVal = (parseInt(token.text.split('').pop(), 10) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(59, dVal)); this.editingData.m = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editNextToken(); break; case 'h': case 'hh': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(1, Math.min(12, dVal)); this.editingData.h = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editNextToken(); break; case 'H': case 'HH': dVal = (parseInt(token.text.split('').pop()) || 0) * 10 + dVal; dVal = Math.max(0, Math.min(23, dVal)); this.editingData.H = dVal; token.replace((0,utils.zeroPadding)(dVal, token.ident.length), true); this.editNextToken(); break; } } } else if (event.key.match(/^[aApPSCsc]$/) && token.ident === 'a') { event.preventDefault(); if (event.key.match(/^[aAsS]$/)) { token.replace('AM', true); this.editingData.a = "AM"; } else { token.replace('PM', true); this.editingData.a = "PM"; } this.editNextToken(); } else if (token.ident === 'ND') { event.preventDefault(); value = token.text !== CHAR_NBSP; this.editingData.nd = !value; newTokenText = this.editingData.nd ? this.elt.nextDateText : CHAR_NBSP; token.replace(newTokenText, true); } else { event.preventDefault(); } }; function TITokenizedText(text, format) { this.text = text; this.format = format; /** * * @type {{content: string, idx: number, length: number}[]} */ this.formatTokens = this.makeTokens(format); /** * * @type {{content: string, idx: number, length: number}[]} */ this.textTokens = this.makeTokens(text); } TITokenizedText.prototype.tokenRegex = /(\([^)]*\))|([^.\/:\-,\\\u0020\u0009\u000D\u200B]+)|([.\/:\-,\\]+)/i; // var CHAR_NBSP = '\u00A0'; TITokenizedText.prototype.spaceRegex = /[\u0020\u0009\u000D\u200B]+/; TITokenizedText.prototype.tokenMap = { h: 'h', H: 'H', HH: 'H', hh: 'h', m: 'm', mm: 'm', a: 'a', ND: 'ND' }; /** * * @param {string} text * @returns {{content: string, idx: number, length: number}[]} */ TITokenizedText.prototype.makeTokens = function (text) { var rgx = new RegExp(this.tokenRegex.source, 'g'); var matched = rgx.exec(text); var res = []; while (matched) { res.push({ content: matched[0], idx: matched.index, length: matched[0].length }); matched = rgx.exec(text); } return res; }; TITokenizedText.prototype.setTokenText = function (tkName, content) { tkName = this.tokenMap[tkName] || tkName; var di = 0; var formatToken; var textToken; var found = false; for (var i = 0; i < this.formatTokens.length; ++i) { formatToken = this.formatTokens[i]; textToken = this.textTokens[i]; if (!textToken) { textToken = { content: formatToken.content, idx: formatToken.idx, length: formatToken.length }; this.textTokens.push(textToken); di = this.text.length - textToken.idx; this.text += textToken.content; } if (di !== 0) { textToken.idx += di; } if ((this.tokenMap[formatToken.content] || formatToken.content) === tkName) { found = true; this.text = this.text.substring(0, textToken.idx + di) + content + this.text.substring(textToken.idx + di + textToken.length); di += content.length - textToken.length; textToken.length = content.length; textToken.content = content; } } return this; }; TITokenizedText.prototype.getTokenText = function (tkName) { var res = null; tkName = this.tokenMap[tkName] || tkName; for (var i = 0; i < this.formatTokens.length; ++i) { if ((this.tokenMap[this.formatTokens[i].content] || this.formatTokens[i].content) === tkName) { res = this.textTokens[i].content; break; } } return res; }; TITokenizedText.prototype.getToken = function (tkName) { var res = null; tkName = this.tokenMap[tkName] || tkName; for (var i = 0; i < this.formatTokens.length; ++i) { if ((this.tokenMap[this.formatTokens[i].content] || this.formatTokens[i].content) === tkName) { res = Object.assign({}, this.textTokens[i]); break; } } return res; }; TITokenizedText.prototype.getText = function (extractByFormat) { var res = this.text; if (extractByFormat) { if (this.formatTokens.length < this.textTokens.length) { res = res.substring(0, this.textTokens[this.formatTokens.length - 1].idx + this.textTokens[this.formatTokens.length - 1].length); } else if (this.formatTokens.length > this.textTokens.length) { res += this.format.substring(this.textTokens[this.textTokens.length - 1].idx + this.textTokens[this.textTokens.length - 1].length); } } return res; }; // EXTERNAL MODULE: ./node_modules/absol-acomp/css/timerange24input.css var timerange24input = __webpack_require__(4697); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TimeRange24Input.js /*** * @extends AElement * @constructor */ function TimeRange24Input() { var t = LanguageSystem/* default.getText */.ZP.getText('txt_next_day'); if (t) { t = '(' + t + ')'; this.nextDateText = t; } /*** * * @type {TimeInput} */ this.$offset = (0,ACore.$)(js_TimeInput.tag, this); this.$offset.on('change', this.eventHandler.offsetChange); /*** * * @type {Time24Input} */ this.$duration = (0,ACore.$)(js_Time24Input.tag, this); this.$duration.on('change', this.eventHandler.durationChange); /*** * @type {number} * @name dayOffset * @memberOf TimeRange24Input# */ /*** * @type {number} * @name duration * @memberOf TimeRange24Input# */ /*** * @type {string} * @name format * @memberOf TimeRange24Input# */ } TimeRange24Input.tag = 'TimeRange24Input'.toLowerCase(); TimeRange24Input.render = function () { return (0,ACore._)({ extendEvent: ['change'], class: 'as-time-range-24-input', child: [{ tag: js_TimeInput.tag, props: { format: 'HH:mm' } }, js_Time24Input.tag ] }); }; TimeRange24Input.prototype.nextDateText = '(Next day)' TimeRange24Input.prototype.init = function (props) { props = props || {}; var cpProps = Object.assign(props); if ('notNull' in props) { this.notNull = props.notNull; delete cpProps.notNull; } if ('dayOffset' in props) { this.dayOffset = props.dayOffset; delete cpProps.dayOffset; } Object.assign(this, cpProps); }; TimeRange24Input.prototype._updateTextData = function () { var dayOffset = this.dayOffset; var duration = this.duration; var format = this.format; var bD = (0,datetime.beginOfDay)(new Date()).getTime(); var startD = new Date(bD + dayOffset) var text = (0,datetime.formatDateTime)(startD, format || 'HH:mm'); var endD = new Date(bD + dayOffset + duration); text += ' - ' + (0,datetime.formatDateTime)(endD, format || 'HH:mm'); if ((0,datetime.compareDate)(endD, startD) > 0) { text += ' ' + this.nextDateText; } this.attr('data-text', text); }; TimeRange24Input.property = {}; TimeRange24Input.property.notNull = { /*** * @this TimeRange24Input * @param value */ set: function (value) { value = !!value; this.$offset.notNull = value; this.$duration.notNull = value; this._updateTextData(); }, get: function () { return this.$offset.notNull; } }; TimeRange24Input.property.disabled = { set: function (value) { value = !!value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } this.$offset.disabled = value; this.$duration.disabled = value; }, get: function () { return this.hasClass('as-disabled'); } }; TimeRange24Input.property.dayOffset = { set: function (value) { var notNull = this.notNull; if ((0,utils.isRealNumber)(value)) { value = (0,utils.normalizeMinuteOfMillis)(value); } else { value = notNull ? 0 : null; } this.$offset.dayOffset = value; this.$duration.dayOffset = value; this._updateTextData(); }, get: function () { return this.$offset.dayOffset; } }; TimeRange24Input.property.duration = { /*** * @this TimeRange24Input * @param value */ set: function (value) { var notNull = this.notNull; if ((0,utils.isRealNumber)(value)) { value = Math.floor(Math.min(datetime.MILLIS_PER_DAY, Math.max(0, value))); value = Math.floor(value / datetime.MILLIS_PER_MINUTE) * datetime.MILLIS_PER_MINUTE; } else { value = notNull ? 0 : null; } this.$duration.value = value; this._updateTextData(); }, get: function () { return this.$duration.value; } }; TimeRange24Input.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); this.$offset.readOnly = true; this.$duration.readOnly = true; } else { this.removeClass('as-read-only'); this.$offset.readOnly = false; this.$duration.readOnly = false; } }, get: function () { return this.containsClass('as-read-only'); } }; TimeRange24Input.property.value = { set: function (value) { var rangeValue = null; if ((0,utils.isRealNumber)(value)) rangeValue = { dayOffset: value, duration: 0 }; else if (!value) { } else if (typeof rangeValue === "object") { if ((0,utils.isRealNumber)(value.dayOffset)) { rangeValue = { dayOffset: value.dayOffset, duration: 0 }; } else { rangeValue = { dayOffset: 0, duration: 0 }; } if ((0,utils.isRealNumber)(value.duration)) { rangeValue.duration = value.duration; } } if (rangeValue) { this.dayOffset = rangeValue.dayOffset; this.duration = rangeValue.duration; } else { this.dayOffset = null; this.duration = null; } return rangeValue; }, get: function () { if (!(0,utils.isRealNumber)(this.dayOffset) && !(0,utils.isRealNumber)(this.duration)) return null; return { dayOffset: this.dayOffset || 0, duration: this.duration || 0 }; } }; TimeRange24Input.eventHandler = {}; TimeRange24Input.eventHandler.offsetChange = function (event) { var prevOffset = this.$duration.dayOffset; var preDuration = this.$duration.value; var prevEnd = prevOffset + preDuration; var newEnd; var newStart = this.$offset.dayOffset; if ((0,utils.isRealNumber)(newStart)) { if ((0,utils.isRealNumber)(prevEnd)) { newEnd = Math.max(newStart, Math.min(newStart + datetime.MILLIS_PER_DAY - datetime.MILLIS_PER_MINUTE, prevEnd)); } else { newEnd = newStart; } this.$duration.dayOffset = newStart; this.$duration.value = newEnd - newStart; } else { this.$duration.dayOffset = 0; this.$duration.value = (0,utils.isRealNumber)(prevEnd) ? Math.min(prevEnd, datetime.MILLIS_PER_DAY - datetime.MILLIS_PER_MINUTE) : null; } this._updateTextData(); this.emit('change', { type: 'change', property: 'dayOffset', originalEvent: event.originalEvent || event.originEvent || event }); }; TimeRange24Input.eventHandler.durationChange = function (event) { if (!(0,utils.isRealNumber)(this.$offset.dayOffset) ) { this.$offset.dayOffset = this.$duration.dayOffset; } this._updateTextData(); this.emit('change', { type: 'change', property: 'duration', originalEvent: event.originalEvent || event.originEvent || event }); }; ACore/* default.install */.Z.install(TimeRange24Input); /* harmony default export */ const js_TimeRange24Input = (TimeRange24Input); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/checktreeitem.css var checktreeitem = __webpack_require__(785); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckTreeItem.js /*** * @extends ExpNode * @constructor */ function CheckTreeItem() { this._itemData = null; this.$name = (0,ACore.$)('span.absol-exp-node-name', this); this.$desc = (0,ACore.$)('span.absol-exp-node-desc', this); this.$iconCtn = (0,ACore.$)('div.absol-exp-node-ext-icon', this); this.$level = (0,ACore.$)('.absol-exp-node-level', this); this.$checkbox = (0,ACore.$)('checkboxbutton', this) .on('change', this.eventHandler.checkboxChange); this.$toggleIcon = (0,ACore.$)('toggler-ico', this); this.on('click', this.eventHandler.click); } CheckTreeItem.tag = 'CheckTreeItem'.toLowerCase(); CheckTreeItem.render = function () { return (0,ACore._)({ tag: 'button', extendEvent: ['select', 'presstoggle'], class: ['as-check-tree-item', 'absol-exp-node'], child: [ '.absol-exp-node-level', 'toggler-ico', 'checkboxbutton', 'img.absol-exp-node-ext-icon', 'div.absol-exp-node-ext-icon', 'span.absol-exp-node-name', 'span.absol-exp-node-desc' ] }); }; CheckTreeItem.property = {}; CheckTreeItem.property.icon = ExpTree/* ExpNode.property.icon */.$P.property.icon; CheckTreeItem.property.text = ExpTree/* ExpNode.property.name */.$P.property.name; CheckTreeItem.property.level = ExpTree/* ExpNode.property.level */.$P.property.level; CheckTreeItem.property.desc = ExpTree/* ExpNode.property.desc */.$P.property.desc; CheckTreeItem.property.status = ExpTree/* ExpNode.property.status */.$P.property.status; CheckTreeItem.property.data = { set: function (itemData) { this._itemData = itemData; var text = (0,SelectListItem/* getTextOfListItem */.sk)(itemData); this.text = text; this.attr('title', itemData.value + '') var desc = (0,SelectListItem/* getDescriptionOfListItem */._l)(itemData); this.desc = desc; if (itemData && itemData.icon) { this.icon = itemData.icon; } else { this.icon = null; } this.noSelect = itemData.noSelect; }, get: function () { return this._itemData; } }; CheckTreeItem.property.selected = { set: function (value) { this._selected = value; this.$checkbox.disabled = value === 'empty'; if (value === 'all') { this.$checkbox.minus = false; this.$checkbox.checked = true; } else if (value === 'child') { this.$checkbox.checked = false; this.$checkbox.minus = true; } else if (value === 'empty') { this.$checkbox.minus = false; this.$checkbox.checked = false; } else { this.$checkbox.minus = false; this.$checkbox.checked = false; } }, get: function () { if ( this.$checkbox.disabled) return 'empty'; if (this.$checkbox.checked) return 'all'; else if (this.$checkbox.minus) return 'child'; return 'none'; } }; CheckTreeItem.property.noSelect = { set: function (value) { if (value) { this.addClass('as-no-select'); } else { this.removeClass('as-no-select'); } }, get: function () { return this.hasClass('as-no-select'); } }; CheckTreeItem.eventHandler = {}; CheckTreeItem.eventHandler.checkboxChange = function (event) { this.emit('select', { type: 'select', target: this, originalEvent: event.originalEvent || event.originEvent || event }); }; CheckTreeItem.eventHandler.click = function (event) { var tBound; if (this.status === 'open' || this.status === 'close') { tBound = this.$toggleIcon.getBoundingClientRect(); if (event.clientX <= tBound.right || this.noSelect) { this.emit('presstoggle', { type: 'presstoggle', target: this, originalEvent: event }, this); } else if (!(0,EventEmitter/* hitElement */.EY)(this.$checkbox, event) && !this.$checkbox.disabled) { this.$checkbox.checked = !this.$checkbox.checked; this.eventHandler.checkboxChange(event); } } else { if (!(0,EventEmitter/* hitElement */.EY)(this.$checkbox, event) && !this.noSelect && !this.$checkbox.disabled) { this.$checkbox.checked = !this.$checkbox.checked; this.eventHandler.checkboxChange(event); } } }; ACore/* default.install */.Z.install(CheckTreeItem); /* harmony default export */ const js_CheckTreeItem = (CheckTreeItem); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/checktreebox.css var checktreebox = __webpack_require__(254); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckTreeBox.js /*** * @extends Follower * @constructor */ function CheckTreeBox() { if (this.cancelWaiting) this.cancelWaiting(); /** * * @type {CTBItemListController} */ this.listCtrl = new (this.ListControllerClass)(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.listCtrl, ['viewHolders', '$checkAll', 'estimateSize']); this.dropdownCtrl = new CTBDropdownController(this); this.actionCtrl = new CTBActionController(this); this.searchCtrl = new CTBSearchController(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.searchCtrl, ['$searchInput']); this._initDomHook(); this._initProperty(); if (!this.updatePosition) { this.updatePosition = noop/* default */.Z; } /** * @name mobile * @type {boolean} * @memberof CheckTreeBox# */ /*** * @name strictValue * @memberof CheckTreeBox# * @type {boolean} */ /** * @name values * @memberof CheckTreeBox# * @type {Array} */ /** * @name viewValues * @memberof CheckTreeBox# * @type {Array} */ } CheckTreeBox.tag = 'CheckTreeBox'.toLowerCase(); CheckTreeBox.prototype.preLoadN = 3; CheckTreeBox.prototype.itemHeight = 28; CheckTreeBox.prototype.itemInPage = 36; CheckTreeBox.prototype._initDomHook = function () { }; CheckTreeBox.prototype._initProperty = function () { this.scale14 = (0,ACore.$)(document.body).getFontSize() / 14; this.initOpened = 0; this.enableSearch = true; }; CheckTreeBox.prototype.focus = js_SelectListBox.prototype.focus; CheckTreeBox.prototype.addStyle = function (name, value) { var ms; if (name === 'minWidth' || name === 'min-width') { ms = (0,attribute.parseMeasureValue)(value); if (ms.unit === 'px') { value = Math.max(240, ms.value) + 'px'; } return AElement/* default.prototype.addStyle.call */.Z.prototype.addStyle.call(this, name, value); } return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } CheckTreeBox.render = function () { var mobile = (arguments[1] && arguments[1].forceMobile) || BrowserDetector/* default.isMobile */.Z.isMobile; var footer = { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { "data-ml-key": 'txt_cancel' } } ].concat(mobile ? [] : [{ tag: 'a', class: 'as-select-list-box-close-btn', attr: { "data-ml-key": 'txt_close' } }]) } ] }; var content = { class: ['as-check-tree-box-scroller', 'as-bscroller', 'as-select-list-box-scroller'], child: { class: ['as-check-tree-box-content', 'as-select-list-box-content'], child: Array(this.prototype.preLoadN).fill('.as-select-list-box-page') } }; if (mobile) { return (0,ACore._)({ props: { mobile: true }, extendEvent: ['change', 'close', 'toggleitem', 'cancel'], class: ['am-check-tree-box-modal', 'am-modal', 'am-dropdown-box-modal'], child: { class: ['am-check-tree-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, content, footer ] } }) } return (0,ACore._)({ tag: 'follower', extendEvent: ['change', 'toggleitem', 'cancel', 'close'], class: ['as-check-tree-box', 'as-select-list-box', 'as-anchor-1'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, content, footer ], props: { anchor: [1, 6, 2, 5], mobile: false } }); }; CheckTreeBox.prototype.HolderClass = TreeNodeHolder; CheckTreeBox.prototype.findItemHoldersByValue = function (value) { return this.listCtrl.findItemHoldersByValue(value); }; CheckTreeBox.prototype.findItemByValue = function (value) { var holders = this.listCtrl.findItemHoldersByValue(value); if (holders && holders.length > 0) { return holders[0].item; } else return null; }; CheckTreeBox.prototype.viewListAt = function (offset) { this.listCtrl.viewListAt(offset); }; CheckTreeBox.prototype.noTransition = function () { if (this.hasClass('as-no-transition')) return; this.addClass('as-no-transition'); setTimeout(function () { this.removeClass('as-no-transition'); }.bind(this), 100); }; CheckTreeBox.prototype.resetSearchState = function () { this.listCtrl.resetView(); }; CheckTreeBox.prototype.updateContentSize = function () { this.listCtrl.updateContentSize(); }; CheckTreeBox.prototype._implicit = function (values) { return values || []; }; CheckTreeBox.property = {}; CheckTreeBox.property.items = { /*** * @this CheckTreeBox * @param items */ set: function (items) { items = items || []; this._items = items; this.listCtrl.setItems(items); }, get: function () { return this._items; } }; CheckTreeBox.property.values = { /*** * @this CheckTreeBox * @param values */ set: function (values) { this.listCtrl.setValues(values); }, get: function () { return this.listCtrl.getValues(); } }; CheckTreeBox.property.viewValues = { get: function () { return this.listCtrl.getViewValues(); } }; CheckTreeBox.property.enableSearch = { set: function (value) { if (value) this.addClass('as-enable-search'); else this.removeClass('as-enable-search'); }, get: function () { return this.hasClass('as-enable-search'); } }; CheckTreeBox.eventHandler = {}; CheckTreeBox.eventHandler.toggleItem = function (item, event) { this.noTransition(); var nodeHolder = item.nodeHolder; if (!nodeHolder) { console.error("Load error, item was not assigned TreeNodeHolder!") } else nodeHolder.toggle(); }; CheckTreeBox.eventHandler.selectItem = function (item, event) { var nodeHolder = item.nodeHolder; if (!nodeHolder) { console.error("Load error, item was not assigned TreeNodeHolder!"); return; } this.noTransition(); var ref = nodeHolder.findReferenceNode(); var targetNode = ref || nodeHolder; var selected = item.selected; if (selected === 'all' && (targetNode.canSelectAll || targetNode.selected === 'none')) { targetNode.selectAll(); } else { targetNode.unselectAll(); } if (ref) { nodeHolder.getRoot().updateSelectedFromRef(); } this.emit('change', { type: 'change', target: this }, this); }; /*** * @this CheckTreeBox */ CheckTreeBox.eventHandler.searchModify = function () { }; CheckTreeBox.prototype.updateSelectedInViewIfNeed = function () { if (this.rootViewHolder !== this.rootHolder) { this.rootViewHolder.updateSelectedFromRef(); } }; CheckTreeBox.eventHandler.clickCancelBtn = function (event) { this.emit('cancel', { type: 'cancel', target: this, originalEvent: event }, this); }; CheckTreeBox.eventHandler.clickCloseBtn = function (event) { this.emit('close', { type: 'close', target: this, originalEvent: event }, this); }; ACore/* default.install */.Z.install(CheckTreeBox); /* harmony default export */ const js_CheckTreeBox = (CheckTreeBox); /*** * * @param {CheckTreeBox} boxElt * @param items * @constructor */ function TreeRootHolder(boxElt, items) { this.boxElt = boxElt; this.items = items; this.selected = 'none'; var Clazz = this.SubHolderClass; this.child = []; this.idx = -1;//root this.tailIdx = this.idx; if (items && items.length > 0) { items.reduce((ac, it) => { var child = new Clazz(boxElt, it, ac.idx + 1, this); ac.idx = child.tailIdx; ac.arr.push(child); return ac; }, { idx: this.idx, arr: this.child }); this.tailIdx = this.child[this.child.length - 1].tailIdx; } this.canSelectAll = this.child.every(c => c.canSelectAll); this.canSelect = (this.child.length === 0 || this.child.some(c => c.canSelect)); } CheckTreeBox.prototype.RootHolderClass = TreeRootHolder; TreeRootHolder.prototype.level = -1; TreeRootHolder.prototype.reset = function () { this.child.forEach(c => c.reset()); this.selected = "none"; }; /*** * * @param {Array=} ac */ TreeRootHolder.prototype.toArray = function (ac) { ac = ac || []; this.child.forEach(c => c.toArray(ac)); return ac; }; TreeRootHolder.prototype.updateFromChild = function () { var childSelectAll = 0; var childSelectChild = 0; var isCheckAll = true; this.traverse(hd => { if (hd.selected === 'none' && !hd.item.noSelect) { isCheckAll = false; } }); if (this.canSelectAll) { this.boxElt.$checkAll.checked = isCheckAll; this.boxElt.$checkAll.minus = false; this.selected = isCheckAll ? 'all' : 'none'; } else { this.boxElt.$checkAll.checked = false; this.boxElt.$checkAll.minus = isCheckAll; this.selected = isCheckAll ? 'child' : 'none'; } }; TreeRootHolder.prototype.updateUp = function () { this.updateFromChild(); }; /*** * * @param {Array=} ac */ TreeRootHolder.prototype.getValues = function (ac) { ac = ac || []; this.child.forEach(c => c.getValues(ac)); return (0,DataStructure_Array.arrayUnique)(ac); }; TreeRootHolder.prototype.getViewValues = function (ac) { ac = ac || []; this.child.forEach(c => c.getViewValues(ac)); return (0,DataStructure_Array.arrayUnique)(ac); }; /*** * * @param {Array} values */ TreeRootHolder.prototype.setValues = function (values) { this.reset(); values = values.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr)] = true; return ac; }, values.slice()); this.child.forEach(c => c.setValues(values)); }; TreeRootHolder.prototype.calcEstimateSize = function () { var res = { width: 0, height: this.boxElt.itemHeight + (this.tailIdx + 1) }; var holders = this.child; var n = holders.length; var holder; var longestHolder = null; var longest = 0; var w; for (var i = 0; i < n; ++i) { holder = holders[i]; holder.traverse((hd) => { w = hd.calcEstimateWidth(); if (w > longest) { longest = w; longestHolder = hd; } }) } if (longestHolder) { res.width = longestHolder.calcWidth() * this.boxElt.scale14; } return res; }; TreeRootHolder.prototype.selectAll = function () { this.child.forEach(c => c.selectAll()); }; TreeRootHolder.prototype.unselectAll = function () { this.child.forEach(c => c.unselectAll()); }; TreeRootHolder.prototype.findReferenceNode = function () { if (this.boxElt.listCtrl.rootHolder === this) return null; return this.boxElt.listCtrl.rootHolder; } TreeRootHolder.prototype.updateSelectedFromRef = function () { if (this.boxElt.listCtrl.rootHolder === this) return; this.child.forEach(c => c.updateSelectedFromRef()); }; TreeRootHolder.prototype.traverse = function (cb) { this.child.forEach(c => c.traverse(cb)); }; TreeRootHolder.prototype.getRoot = function () { return this; }; /*** * * @param {Object<string, TreeNodeHolder>|{}=}ac * @returns {Object<string, TreeNodeHolder>|{}} */ TreeRootHolder.prototype.depthIndexing = function (ac) { ac = ac || {}; this.child.forEach(c => c.depthIndexing(ac)); return ac; }; /*** * * @param {CheckTreeBox} boxElt * @param {SelectionItem} item * @param {number} idx * @param {TreeNodeHolder | TreeRootHolder} parent * @constructor */ function TreeNodeHolder(boxElt, item, idx, parent) { this.boxElt = boxElt; this.item = item; this.idx = idx; this.tailIdx = idx;//last child index this.parent = parent; this.status = (item.items && item.items.length > 0) ? 'close' : 'none'; this.selected = 'none'; this.level = parent ? parent.level + 1 : 0; if (this.status === 'close' && this.level < this.boxElt.initOpened) { this.status = 'open'; } this._elt = null; var Clazz = this.constructor; /*** * * @type {this[]} */ this.child = []; if (item.items && item.items.length > 0) { item.items.reduce((ac, it) => { var child = new Clazz(boxElt, it, ac.idx + 1, this); ac.idx = child.tailIdx; ac.arr.push(child); return ac; }, { idx: this.idx, arr: this.child }); this.tailIdx = this.child[this.child.length - 1].tailIdx; } this.canSelectAll = !this.item.noSelect && this.child.every(c => c.canSelectAll); this.canSelect = !this.item.noSelect && (this.child.length === 0 || this.child.some(c => c.canSelect)); } TreeRootHolder.prototype.SubHolderClass = TreeNodeHolder; /*** * * @param {Object<string, TreeNodeHolder>|{}}ac * @returns {Object<string, TreeNodeHolder>|{}} */ TreeNodeHolder.prototype.depthIndexing = function (ac) { ac = ac || {}; var key = (0,utils.keyStringOf)(this.item.value); if (!ac[key]) ac[key] = []; ac[key].push(this); // if (ac[key].length === 2) {//allow // console.warn("Duplicate value", ac[key]); // } this.child.forEach(c => c.depthIndexing(ac)); return ac; }; TreeNodeHolder.prototype.findIdxInView = function () { var holders = this.boxElt.listCtrl.viewHolders; var start = 0; var end = holders.length - 1; var mid; var idx = this.idx; var holderIdx; while (start < end) { mid = (start + end) >> 1; holderIdx = holders[mid].idx; if (holderIdx < idx) { start = mid + 1; } else if (holderIdx > idx) { end = mid - 1; } else { return mid; } } holderIdx = holders[start].idx; if (holderIdx === idx) return start; return -1; }; TreeNodeHolder.prototype.getValues = function (ac) { ac = ac || []; if (this.selected === 'all') { ac.push(this.item.value); } else if (this.selected === 'child') { this.child.forEach(c => c.getValues(ac)); } return ac; }; TreeNodeHolder.prototype.getViewValues = function (ac) { return this.getValues(ac); }; TreeNodeHolder.prototype.setValues = function (values) { if (values[(0,utils.keyStringOf)(this.item.value)]) { this.selectAll(true); } else { this.child.forEach(c => c.setValues(values)); } this.updateFromChild(); }; TreeNodeHolder.prototype.toggle = function () { var idx = this.findIdxInView(); var status = this.status; if (status === 'close') { this.itemElt.status = 'open'; this.status = 'open'; var arr = this.toArray(); arr.shift(); this.boxElt.listCtrl.viewHolders.splice.apply(this.boxElt.listCtrl.viewHolders, [idx + 1, 0].concat(arr)); this.boxElt.listCtrl.updateContentSize(); this.boxElt.listCtrl.viewListAt(idx); this.boxElt.emit('toggleitem', { type: 'toggleitem', target: this.boxElt, nodeHolder: this, status: 'open' }, this.boxElt); } else if (status === 'open') { this.itemElt.status = 'close'; this.status = 'close'; var l = 0; while (this.boxElt.viewHolders[idx + 1 + l] && this.boxElt.listCtrl.viewHolders[idx + 1 + l].isDescendantOf(this)) ++l; this.boxElt.listCtrl.viewHolders.splice(idx + 1, l); this.boxElt.listCtrl.updateContentSize(); this.boxElt.listCtrl.viewListAt(idx); this.boxElt.emit('toggleitem', { type: 'toggleitem', target: this.boxElt, nodeHolder: this, status: 'close' }, this.boxElt); } }; /*** * * @param {boolean=} isDownUpdate */ TreeNodeHolder.prototype.selectAll = function (isDownUpdate) { if (this.selected === 'all') return; if (!this.canSelect) return; if (this.canSelectAll) this.selected = 'all'; else this.selected = 'child'; if (this.itemElt) this.itemElt.selected = this.selected; this.child.forEach(function (child) { child.selectAll(true); }); if (!isDownUpdate) { if (this.parent) this.parent.updateUp(); } }; /*** * * @param {boolean=} isDownUpdate */ TreeNodeHolder.prototype.unselectAll = function (isDownUpdate) { if (this.selected === 'none') return; this.selected = 'none'; if (this.itemElt) this.itemElt.selected = this.selected; this.child.forEach(function (child) { child.unselectAll(true); }); if (!isDownUpdate) { if (this.parent) this.parent.updateUp(); } }; TreeNodeHolder.prototype.reset = function () { if (this.selected !== "empty") this.selected = 'none'; if (this.itemElt) this.itemElt.selected = this.selected; this.child.forEach(function (child) { child.reset(true); }); } TreeNodeHolder.prototype.updateFromChild = function () { if (this.child.length === 0) return; var childSelectAll = 0; var childSelectChild = 0; for (var i = 0; i < this.child.length; ++i) { if (this.child[i].selected === 'all') { childSelectAll++; } else if (this.child[i].selected === 'child') { childSelectChild++; } } if (childSelectAll === this.child.length) { this.selected = 'all'; } else if (childSelectChild + childSelectAll > 0) { this.selected = 'child'; } else { this.selected = 'none'; } if (this.itemElt) { this.itemElt.selected = this.selected; } }; TreeNodeHolder.prototype.updateUp = function () { this.updateFromChild(); if (this.parent) this.parent.updateUp(); }; TreeNodeHolder.prototype.calcEstimateWidth = function () { return this.calcWidth();//because new version use TextMeasure.measureWidth, better performance }; TreeNodeHolder.prototype.calcWidth = function () { var width = 12;//padding width += 43; //cheat for some size with checklistbox width += 1.75 * 14 * this.level; width += 14.7 + 5;//toggle icon width += 16;//checkbox if (this.item.icon) width += 21;//icon width += 7 + TextMeasure/* default.measureWidth */.Z.measureWidth(this.item.text||'', TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14);//margin-text if (this.item.desc) width += 6 + TextMeasure/* default.measureWidth */.Z.measureWidth(this.item.desc||'',TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 11.9); return width; }; TreeNodeHolder.prototype.isDescendantOf = function (parent) { var cr = this.parent; while (cr) { if (parent === cr) return true; cr = cr.parent; } return false; }; /*** * * @param {TreeNodeHolder[]=} ac * @return {TreeNodeHolder[]} */ TreeNodeHolder.prototype.toArray = function (ac) { ac = ac || []; ac.push(this); if (this.status === 'open') { for (var i = 0; i < this.child.length; ++i) { this.child[i].toArray(ac); } } return ac; }; TreeNodeHolder.prototype.traverse = function (cb) { cb(this); this.child.forEach(c => c.traverse(cb)); }; Object.defineProperty(TreeNodeHolder.prototype, 'itemElt', { set: function (elt) { if (this._elt === elt) return; if (this._elt) { if (this._elt.nodeHolder === this) { this._elt.nodeHolder = null; } } if (elt) { if (elt.nodeHolder) { elt.nodeHolder.itemElt = null; } elt.nodeHolder = this; this._elt = elt; elt.data = this.item; elt.level = this.level; elt.status = this.status; elt.selected = this.selected; if (this.item.noSelect || !this.canSelect) { elt.noSelect = true; } else { elt.noSelect = false; } } else { this._elt = null; } }, get: function () { return this._elt; }, configurable: true }); TreeNodeHolder.prototype.findReferenceNode = function () { var value = this.item.value; var holders = this.boxElt.findItemHoldersByValue(value); var holder; for (var i = 0; i < holders.length; ++i) { holder = holders[i]; if ((holder.item === this.item.ref || holder.item === this.item) && holder !== this) return holder; } return null; }; TreeNodeHolder.prototype.getRoot = function () { if (!this.parent) return this; return this.parent.getRoot(); }; TreeNodeHolder.prototype.updateSelectedFromRef = function () { var ref = this.findReferenceNode(); if (!ref) return; var selected = ref.selected; this.selected = selected; if (this.itemElt) this.itemElt.selected = selected; this.child.forEach(function (c) { c.updateSelectedFromRef(); }); }; /** * * @param {CheckTreeBox} elt * @constructor */ function CTBItemListController(elt) { this.elt = elt; var RootHolderClass = this.elt.RootHolderClass; this._items = []; this._values = []; this.itemHolderByValue = {}; this.rootHolder = new RootHolderClass(this.elt, []); // this.rootHolders = []; /*** * * @type {TreeRootHolder} */ this.rootViewHolder = this.rootHolder; /*** * * @type {TreeNodeHolder[]} */ this.viewHolders = [];//toArray this.$checkAll = (0,ACore.$)('.as-select-list-box-check-all', this.elt) .on('change', this.ev_checkAllChange.bind(this)); this.$scroller = (0,ACore.$)('.as-check-tree-box-scroller', elt) .on('scroll', this.ev_scroll.bind(this)); this.itemInPage = Math.max(36, Math.ceil((0,Dom/* getScreenSize */.tE)().height / this.itemHeight)); this.$content = (0,ACore.$)('.as-check-tree-box-content', elt); this.$pages = (0,ACore.$$)('.as-select-list-box-page', elt); this.$pages.forEach(function (p) { p.__viewOffset__ = -1; }); } CheckTreeBox.prototype.ListControllerClass = CTBItemListController; CTBItemListController.prototype.preLoadN = 3; CTBItemListController.prototype.itemHeight = 28; CTBItemListController.prototype.itemInPage = 36; CTBItemListController.prototype.resetView = function () { this.elt.$searchInput.value = ''; this.viewHolders = this.rootHolder.toArray(); this.rootViewHolder = this.rootHolder; this.updateContentSize(); this.viewListAt(0); } CTBItemListController.prototype.setItems = function (items) { if (!(items instanceof Array)) items = []; (0,search/* prepareSearchForList */.Lb)(items); this._items = items; var RootHolderClass = this.elt.RootHolderClass; this.rootHolder = new RootHolderClass(this.elt, items); this.itemHolderByValue = this.rootHolder.depthIndexing(); this.estimateSize = this.rootHolder.calcEstimateSize(); this.elt.addStyle('--select-list-estimate-width', this.estimateSize.width + 'px'); this.resetView(); this.rootHolder.setValues(this._values); }; CTBItemListController.prototype.setValues = function (values) { if (values instanceof Array) { values = values.slice(); } else if (values === undefined || values === null) { values = []; } else values = [values]; this._values = values; this.rootHolder.setValues(values); }; CTBItemListController.prototype.getValues = function () { return this.rootHolder.getValues(); }; CTBItemListController.prototype.getViewValues = function () { return this.rootHolder.getViewValues() }; CTBItemListController.prototype.updateContentSize = function () { this.$content.addStyle('height', this.viewHolders.length * this.itemHeight / 14 + 'em'); }; CTBItemListController.prototype.viewListAt = function (offset) { offset = offset || 0; this.elt.noTransition(); var midPage = this.$pages.length >> 1; var startOffset = Math.max(0, offset - midPage * this.itemInPage); var cOffset; var itemN = this.viewHolders.length; for (var i = 0; i < this.$pages.length; ++i) { cOffset = startOffset + i * this.itemInPage; if (cOffset < itemN) { this.$pages[i].__viewOffset__ = cOffset; this.$pages[i].removeStyle('display') .addStyle('top', cOffset * this.itemHeight / 14 + 'em'); this._fillPage(this.$pages[i], Math.min(this.itemInPage, itemN - cOffset)); this._assignItems(this.$pages[i], cOffset); } else { this.$pages[i].__viewOffset__ = -1; this.$pages[i].addStyle('display', 'none'); } } }; CTBItemListController.prototype._fillPage = function (pageElt, n) { while (pageElt.childNodes.length > n) { this._releaseItem(pageElt.lastChild); pageElt.removeChild(pageElt.lastChild); } while (pageElt.childNodes.length < n) { pageElt.addChild(this._requestItem()); } }; CTBItemListController.prototype._assignItems = function (pageElt, offset) { for (var i = 0; i < pageElt.childNodes.length; ++i) { this.viewHolders[offset + i].itemElt = pageElt.childNodes[i]; } }; CTBItemListController.prototype._requestItem = function () { var res = this._pool.pop() || (0,ACore._)({ tag: js_CheckTreeItem.tag, props: { menuElt: this }, on: { presstoggle: function (event) { this.menuElt.eventHandler.toggleItem(this, event); }, select: function (event) { this.menuElt.eventHandler.selectItem(this, event); } } }); res.menuElt = this.elt; return res; }; CTBItemListController.prototype._pool = []; CTBItemListController.prototype._releaseItem = function (item) { if (item.nodeHolder && item.nodeHolder.itemElt === item) { item.nodeHolder.itemElt = null; } this._pool.push(item); }; CTBItemListController.prototype.findItemHoldersByValue = function (value) { return (this.itemHolderByValue[(0,utils.keyStringOf)(value)] || []).slice(); }; CTBItemListController.prototype.isSelectedAll = function () { return this.rootHolder.selected; }; /* CTBItemListController.prototype.selectAll = function (selected){ var preValues = this.getValues(); switch (selected) { case 'all': this.rootHolder.unselectAll(); break; case 'child': if (this.rootHolder.canSelectAll) { this.rootHolder.selectAll(); } else { this.rootHolder.unselectAll(); } break; case 'none': this.rootHolder.selectAll(); break; } if (this.rootViewHolder !== this.rootHolder) { this.rootViewHolder.updateSelectedFromRef(); } var newValues = this.getValues(); if (!arrayCompare(preValues, newValues)) { this.elt.emit('change', { type: 'change', target: this }, this); } };*/ CTBItemListController.prototype.ev_scroll = function (event) { var itemHeight = this.itemHeight * this.elt.getFontSize() / 14; var scrollTop = this.$scroller.scrollTop; var scrollBottom = scrollTop + this.$scroller.clientHeight; var startOffset = this.$pages[0].__viewOffset__; var endOffset = this.$pages[this.$pages.length - 1].__viewOffset__; if (endOffset === -1) { endOffset = this.viewHolders.length; } else { endOffset += this.$pages[this.$pages.length - 1].childNodes.length; } var needLoad = 0; if (startOffset > 0 && startOffset * itemHeight + 200 > scrollTop) needLoad = -1; if (needLoad === 0 && this.viewHolders.length > endOffset && endOffset * itemHeight - 200 < scrollBottom) { needLoad = 1; } var page2Load; if (needLoad < 0) { page2Load = this.$pages.pop(); this.$pages.unshift(page2Load); page2Load.__viewOffset__ = Math.max(0, startOffset - this.itemInPage); this._fillPage(page2Load, startOffset - page2Load.__viewOffset__); this._assignItems(page2Load, page2Load.__viewOffset__); page2Load.removeStyle('display'); page2Load.addStyle('top', page2Load.__viewOffset__ * itemHeight + 'px'); } else if (needLoad > 0) { for (var i = 0; i < this.$pages.length; ++i) { if (this.$pages[i].__viewOffset__ === -1) { page2Load = this.$pages[i]; break; } } if (!page2Load) { page2Load = this.$pages.shift(); this.$pages.push(page2Load); } page2Load.__viewOffset__ = endOffset; this._fillPage(page2Load, Math.min(this.itemInPage, this.viewHolders.length - endOffset)); this._assignItems(page2Load, page2Load.__viewOffset__); page2Load.removeStyle('display'); page2Load.addStyle('top', page2Load.__viewOffset__ * itemHeight + 'px'); } }; CTBItemListController.prototype.ev_checkAllChange = function (event) { var selected = this.rootHolder.selected; var preValues = this.getValues(); switch (selected) { case 'all': this.rootHolder.unselectAll(); break; case 'child': if (this.rootHolder.canSelectAll) { this.rootHolder.selectAll(); } else { this.rootHolder.unselectAll(); } break; case 'none': this.rootHolder.selectAll(); break; } if (this.rootViewHolder !== this.rootHolder) { this.rootViewHolder.updateSelectedFromRef(); } var newValues = this.getValues(); if (!(0,DataStructure_Array.arrayCompare)(preValues, newValues)) { this.elt.emit('change', { type: 'change', target: this }, this); } }; /** * * @param {CheckTreeBox} elt * @constructor */ function CTBActionController(elt) { this.elt = elt; this.$cancelBtn = (0,ACore.$)('.as-select-list-box-cancel-btn', this.elt) .on('click', this.ev_clickCancelBtn.bind(this)); this.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this.elt) || (0,ACore.$)('.am-dropdown-box-close-btn', this.elt); this.$closeBtn.on('click', this.ev_clickCloseBtn.bind(this)); } CTBActionController.prototype.ev_clickCancelBtn = function (event) { this.elt.emit('cancel', { type: 'cancel', target: this, originalEvent: event }, this); }; CTBActionController.prototype.ev_clickCloseBtn = function (event) { this.elt.emit('close', { type: 'close', target: this, originalEvent: event }, this); }; function CTBSearchController(elt) { this.elt = elt; this.cache = {}; this.$searchInput = (0,ACore.$)('searchtextinput', this.elt) .on('stoptyping', this.ev_searchModify.bind(this)); } CTBSearchController.prototype.ev_searchModify = function () { var text = this.$searchInput.value.trim(); if (text.length === 0) { this.elt.listCtrl.resetView(); return; } var searchData; if (this.cache[text]) { searchData = this.cache[text]; } else { searchData = {}; searchData.items = (0,search/* searchTreeListByText */.$l)(text, this.elt.listCtrl._items); searchData.rootViewHolder = new TreeRootHolder(this.elt, searchData.items); searchData.items.forEach(function visit(it) { if (it.ref.items && it.ref.items.length > 0 && (!it.items || it.items.length === 0)) { it.items = it.ref.items; it.doNotInitOpen = true; } else if (it.items && it.items.length > 0) { it.items.forEach(visit); } }); } searchData.rootViewHolder.traverse(hd => { if (hd.status === 'close') { if (!hd.item.doNotInitOpen) hd.status = 'open'; } }); //todo: short command this.elt.listCtrl.rootViewHolder = searchData.rootViewHolder; this.elt.listCtrl.viewHolders = this.elt.listCtrl.rootViewHolder.toArray(); this.elt.listCtrl.rootViewHolder.updateSelectedFromRef(); this.elt.listCtrl.updateContentSize(); this.elt.listCtrl.viewListAt(0); this.elt.dropdownCtrl.updatePosition(); }; /** * * @param {CheckTreeBox} elt * @constructor */ function CTBDropdownController(elt) { this.elt = elt; } CTBDropdownController.prototype.updatePosition = function () { if (this.elt.updatePosition) { this.elt.updatePosition(); } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckTreeLeafOnlyBox.js var normalizeItem = item => { var nItem = Object.assign({}, item); if (!nItem.isLeaf && nItem.noSelect) { delete nItem.noSelect; } if (nItem.items && nItem.items.map) nItem.items = normalizeItems(nItem.items); return nItem; } var normalizeItems = (items) => { return items.map(it => normalizeItem(it)); }; var verifyItems = items => { var leafDict = {}; var subTreeDict = {}; var visit = () => { } items.forEach(visit); } /*** * Only tree has leaf can be selected * @extends CheckTreeBox * @constructor */ function CheckTreeLeafOnlyBox() { js_CheckTreeBox.apply(this, arguments); } CheckTreeLeafOnlyBox.tag = 'CheckTreeLeafOnlyBox'.toLowerCase(); CheckTreeLeafOnlyBox.render = function () { var mobile = (arguments[1] && arguments[1].forceMobile) || BrowserDetector/* default.isMobile */.Z.isMobile; var footer = { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { "data-ml-key": 'txt_cancel' } } ].concat(mobile ? [] : [{ tag: 'a', class: 'as-select-list-box-close-btn', attr: { "data-ml-key": 'txt_close' } }]) } ] }; var content = { class: ['as-check-tree-box-scroller', 'as-bscroller', 'as-select-list-box-scroller'], child: { class: ['as-check-tree-box-content', 'as-select-list-box-content'], child: Array(this.prototype.preLoadN).fill('.as-select-list-box-page') } }; if (mobile) { return (0,ACore._)({ props: { mobile: true }, extendEvent: ['change', 'close', 'toggleitem', 'cancel'], class: ['am-check-tree-box-modal', 'am-modal', 'am-dropdown-box-modal'], child: { class: ['am-check-tree-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, content, footer ] } }) } return (0,ACore._)({ tag: 'follower', extendEvent: ['change', 'toggleitem', 'cancel', 'close'], class: ['as-check-tree-leaf-only-box', 'as-check-tree-box', 'as-select-list-box', 'as-anchor-1'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, content, footer ], props: { anchor: [1, 6, 2, 5] } }); }; Object.assign(CheckTreeLeafOnlyBox.prototype, js_CheckTreeBox.prototype); CheckTreeLeafOnlyBox.property = Object.assign({}, js_CheckTreeBox.property); CheckTreeLeafOnlyBox.eventHandler = Object.assign({}, js_CheckTreeBox.eventHandler); CheckTreeLeafOnlyBox.prototype._pool = []; CheckTreeLeafOnlyBox.prototype.findItemByValue = function (value) { var holders = this.listCtrl.findItemHoldersByValue(value); if (holders && holders.length > 0) { return holders[0].item; } else { return null; } }; CheckTreeLeafOnlyBox.property.items = { get: js_CheckTreeBox.property.items.get, set: function (items) { items = normalizeItems(items || []); verifyItems(items); js_CheckTreeBox.property.items.set.call(this, items); } }; CheckTreeLeafOnlyBox.prototype._requestItem = function () { var res = this._pool.pop() || (0,ACore._)({ tag: js_CheckTreeItem.tag, class: 'as-check-tree-leaf-only-item', props: { menuElt: this }, on: { presstoggle: function (event) { this.menuElt.eventHandler.toggleItem(this, event); }, select: function (event) { this.menuElt.eventHandler.selectItem(this, event); } } }); res.menuElt = this; return res; }; CheckTreeLeafOnlyBox.prototype.HolderClass = TreeLeafOnlyNodeHolder; ACore/* default.install */.Z.install(CheckTreeLeafOnlyBox); /* harmony default export */ const js_CheckTreeLeafOnlyBox = (CheckTreeLeafOnlyBox); /*** * @extends TreeRootHolder * @param {CheckTreeLeafOnlyBox} boxElt * @param items * @constructor */ function TreeLeafOnlyRootHolder(boxElt, items) { TreeRootHolder.apply(this, arguments); } CheckTreeLeafOnlyBox.prototype.RootHolderClass = TreeLeafOnlyRootHolder; OOP/* default.mixClass */.ZP.mixClass(TreeLeafOnlyRootHolder, TreeRootHolder); /*** * @extends TreeNodeHolder * @constructor */ function TreeLeafOnlyNodeHolder() { TreeNodeHolder.apply(this, arguments); /*** * @memberOf TreeLeafOnlyNodeHolder# * @type {number} */ this.leafCount = 0; if (this.item.isLeaf) { this.leafCount = 1; } else { this.leafCount = this.child.reduce((ac, c) => ac + c.leafCount, 0); } if (this.child.length > 0) { this.item.noSelect = this.child.every(c => c.item.noSelect);//all child is noSelect=> noSelect } this.canSelect = this.canSelect && this.leafCount > 0; this.canSelectAll = this.canSelect && !this.item.noSelect && this.child.every(c => c.canSelectAll || c.leafCount === 0); if (this.leafCount === 0) this.selected = 'empty'; } OOP/* default.mixClass */.ZP.mixClass(TreeLeafOnlyNodeHolder, TreeNodeHolder); TreeLeafOnlyRootHolder.prototype.SubHolderClass = TreeLeafOnlyNodeHolder; TreeLeafOnlyNodeHolder.prototype.setValues = function (values) { if (values[(0,utils.keyStringOf)(this.item.value)]) { this.selectAll(true); } else { this.child.forEach(c => c.setValues(values)); } this.updateFromChild(); }; TreeLeafOnlyNodeHolder.prototype.getValues = function (ac) { ac = ac || []; if (this.selected === 'all' && this.item.isLeaf) { ac.push(this.item.value); } else { this.child.forEach(c => c.getValues(ac)); } return ac; }; TreeLeafOnlyNodeHolder.prototype.getViewValues = function (ac) { ac = ac || []; if (this.selected === 'all') { ac.push(this.item.value); } else if (this.selected === 'child') { this.child.forEach(c => c.getViewValues(ac)); } return ac; }; /*** * * @param {boolean=} isDownUpdate */ TreeLeafOnlyNodeHolder.prototype.selectAll = function (isDownUpdate) { if (this.selected === 'empty') return; return TreeNodeHolder.prototype.selectAll.apply(this, arguments); }; TreeLeafOnlyNodeHolder.prototype.unselectAll = function (isDownUpdate) { if (this.selected === 'empty') return; return TreeNodeHolder.prototype.unselectAll.apply(this, arguments); }; TreeLeafOnlyNodeHolder.prototype.updateFromChild = function () { if (this.child.length === 0) return; var count = this.child.reduce((ac, cr) => { ac[cr.selected]++; return ac; }, { all: 0, child: 0, none: 0, empty: 0 }); // if (this.boxElt.debug) // console.log( this.item, count.empty , count.all, this.child.length);//0, 9, 10 if (count.empty === this.child.length) { this.selected = 'empty'; } else if (count.empty + count.all === this.child.length) { this.selected = 'all'; } else if (count.all + count.child > 0) { this.selected = 'child'; } else if (this.selected !== "empty") { this.selected = 'none'; } if (this.itemElt) { this.itemElt.selected = this.selected; } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CheckUnsafeTreeLeafOnlyBox.js var CheckUnsafeTreeLeafOnlyBox_normalizeItem = item => { var nItem = Object.assign({}, item); if (!nItem.isLeaf && nItem.noSelect) { delete nItem.noSelect; } if (nItem.items && nItem.items.map) nItem.items = CheckUnsafeTreeLeafOnlyBox_normalizeItems(nItem.items); return nItem; } var CheckUnsafeTreeLeafOnlyBox_normalizeItems = (items) => { return items.map(it => CheckUnsafeTreeLeafOnlyBox_normalizeItem(it)); }; var CheckUnsafeTreeLeafOnlyBox_verifyItems = items => { var leafDict = {}; var subTreeDict = {}; var visit = () => { } items.forEach(visit); } /** * @extends AElement * @constructor */ function CheckUnsafeTreeItem() { js_CheckTreeItem.apply(this, arguments); this.$actionCtn = (0,ACore.$)('.as-check-unsafe-tree-item-action-ctn', this); this.$actionBtns = (0,ACore.$$)('button', this.$actionCtn); this.$actionBtns[0].on('click', this.eventHandler.clickAction.bind(this, 'check_all')); this.$actionBtns[1].on('click', this.eventHandler.clickAction.bind(this, 'uncheck_all')); } CheckUnsafeTreeItem.tag = 'CheckUnsafeTreeItem'.toLowerCase(); CheckUnsafeTreeItem.render = function () { return (0,ACore._)({ tag: 'button', extendEvent: ['select', 'presstoggle'], class: ['as-check-tree-item', 'as-check-unsafe-tree-item', 'absol-exp-node'], child: [ '.absol-exp-node-level', 'toggler-ico', 'checkboxbutton', 'img.absol-exp-node-ext-icon', 'div.absol-exp-node-ext-icon', 'span.absol-exp-node-name', 'span.absol-exp-node-desc', { class: 'as-check-unsafe-tree-item-action-ctn', child: [ { tag: 'button', class: 'as-transparent-button', child: 'span.mdi.mdi-check-all' }, { tag: 'button', class: 'as-transparent-button', child: 'span.mdi.mdi-close' }, ] } ] }); }; CheckUnsafeTreeItem.eventHandler = Object.assign({}, js_CheckTreeItem.eventHandler); CheckUnsafeTreeItem.property = Object.assign({}, js_CheckTreeItem.property); CheckUnsafeTreeItem.eventHandler.click = function (event) { var tBound; if (this.status === 'open' || this.status === 'close') { tBound = this.$toggleIcon.getBoundingClientRect(); if ((0,EventEmitter/* hitElement */.EY)(this.$actionCtn, event)) { } else if (event.clientX <= tBound.right || this.noSelect) { this.emit('presstoggle', { type: 'presstoggle', target: this, originalEvent: event }, this); } else if (!(0,EventEmitter/* hitElement */.EY)(this.$checkbox, event) && !this.$checkbox.disabled) { this.$checkbox.checked = !this.$checkbox.checked; this.eventHandler.checkboxChange(event); } } else { if (!(0,EventEmitter/* hitElement */.EY)(this.$checkbox, event) && !this.noSelect && !this.$checkbox.disabled) { this.$checkbox.checked = !this.$checkbox.checked; this.eventHandler.checkboxChange(event); } } }; CheckUnsafeTreeItem.eventHandler.clickAction = function (action, event) { console.log(action); }; /*** * Only tree has leaf can be selected * @extends CheckTreeBox * @constructor */ function CheckUnsafeTreeLeafOnlyBox() { js_CheckTreeBox.apply(this, arguments); } CheckUnsafeTreeLeafOnlyBox.tag = 'CheckUnsafeTreeLeafOnlyBox'.toLowerCase(); CheckUnsafeTreeLeafOnlyBox.render = function () { var mobile = (arguments[1] && arguments[1].forceMobile) || BrowserDetector/* default.isMobile */.Z.isMobile; var footer = { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { "data-ml-key": 'txt_cancel' } } ].concat(mobile ? [] : [{ tag: 'a', class: 'as-select-list-box-close-btn', attr: { "data-ml-key": 'txt_close' } }]) } ] }; var content = { class: ['as-check-tree-box-scroller', 'as-bscroller', 'as-select-list-box-scroller'], child: { class: ['as-check-tree-box-content', 'as-select-list-box-content'], child: Array(this.prototype.preLoadN).fill('.as-select-list-box-page') } }; if (mobile) { return (0,ACore._)({ props: { mobile: true }, extendEvent: ['change', 'close', 'toggleitem', 'cancel'], class: ['am-check-tree-box-modal', 'am-modal', 'am-dropdown-box-modal'], child: { class: ['am-check-tree-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, content, footer ] } }) } return (0,ACore._)({ tag: 'follower', extendEvent: ['change', 'toggleitem', 'cancel', 'close'], class: ['as-check-tree-leaf-only-box', 'as-check-tree-box', 'as-select-list-box', 'as-anchor-1'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, content, footer ], props: { anchor: [1, 6, 2, 5] } }); }; Object.assign(CheckUnsafeTreeLeafOnlyBox.prototype, js_CheckTreeBox.prototype); CheckUnsafeTreeLeafOnlyBox.property = Object.assign({}, js_CheckTreeBox.property); CheckUnsafeTreeLeafOnlyBox.eventHandler = Object.assign({}, js_CheckTreeBox.eventHandler); CheckUnsafeTreeLeafOnlyBox.prototype._pool = []; CheckUnsafeTreeLeafOnlyBox.property.items = { get: js_CheckTreeBox.property.items.get, set: function (items) { items = CheckUnsafeTreeLeafOnlyBox_normalizeItems(items || []); CheckUnsafeTreeLeafOnlyBox_verifyItems(items); js_CheckTreeBox.property.items.set.call(this, items); } }; CheckUnsafeTreeLeafOnlyBox.prototype._requestItem = function () { var res = this._pool.pop() || (0,ACore._)({ tag: js_CheckTreeItem.tag, class: 'as-check-tree-leaf-only-item', props: { menuElt: this }, on: { presstoggle: function (event) { this.menuElt.eventHandler.toggleItem(this, event); }, select: function (event) { this.menuElt.eventHandler.selectItem(this, event); } } }); res.menuElt = this; return res; }; CheckUnsafeTreeLeafOnlyBox.prototype.HolderClass = CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder; ACore/* default.install */.Z.install(CheckUnsafeTreeLeafOnlyBox); /* harmony default export */ const js_CheckUnsafeTreeLeafOnlyBox = (CheckUnsafeTreeLeafOnlyBox); /** * * @constructor */ function CSTBItemListController() { CTBItemListController.apply(this, arguments); console.log(this._requestItem) } (0,OOP/* mixClass */.Jx)(CSTBItemListController, CTBItemListController); CheckUnsafeTreeLeafOnlyBox.prototype.ListControllerClass = CSTBItemListController; CSTBItemListController.prototype._pool = []; CSTBItemListController.prototype._requestItem = function () { var res = this._pool.pop() || (0,ACore._)({ tag: CheckUnsafeTreeItem, // tag: CheckTreeItem, props: { menuElt: this }, on: { presstoggle: function (event) { this.menuElt.eventHandler.toggleItem(this, event); }, select: function (event) { this.menuElt.eventHandler.selectItem(this, event); } } }); res.menuElt = this.elt; console.log(res) return res; }; /*** * @extends TreeRootHolder * @param {CheckUnsafeTreeLeafOnlyBox} boxElt * @param items * @constructor */ function CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyRootHolder(boxElt, items) { TreeRootHolder.apply(this, arguments); } CheckUnsafeTreeLeafOnlyBox.prototype.RootHolderClass = CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyRootHolder; OOP/* default.mixClass */.ZP.mixClass(CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyRootHolder, TreeRootHolder); /*** * @extends TreeNodeHolder * @constructor */ function CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder() { TreeNodeHolder.apply(this, arguments); /*** * @memberOf TreeLeafOnlyNodeHolder# * @type {number} */ this.leafCount = 0; if (this.item.isLeaf) { this.leafCount = 1; } else { this.leafCount = this.child.reduce((ac, c) => ac + c.leafCount, 0); } if (this.child.length > 0) { this.item.noSelect = this.child.every(c => c.item.noSelect);//all child is noSelect=> noSelect } this.canSelect = this.canSelect && this.leafCount > 0; this.canSelectAll = this.canSelect && !this.item.noSelect && this.child.every(c => c.canSelectAll || c.leafCount === 0); if (this.leafCount === 0) this.selected = 'empty'; } OOP/* default.mixClass */.ZP.mixClass(CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder, TreeNodeHolder); CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyRootHolder.prototype.SubHolderClass = CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder; CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.setValues = function (values) { if (values[(0,utils.keyStringOf)(this.item.value)]) { this.selectAll(true); } else { this.child.forEach(c => c.setValues(values)); } this.updateFromChild(); }; CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.getValues = function (ac) { ac = ac || []; if (this.selected === 'all' && this.item.isLeaf) { ac.push(this.item.value); } else { this.child.forEach(c => c.getValues(ac)); } return ac; }; CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.getViewValues = function (ac) { ac = ac || []; if (this.selected === 'all') { ac.push(this.item.value); } else if (this.selected === 'child') { this.child.forEach(c => c.getViewValues(ac)); } return ac; }; /*** * * @param {boolean=} isDownUpdate */ CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.selectAll = function (isDownUpdate) { if (this.selected === 'empty') return; return TreeNodeHolder.prototype.selectAll.apply(this, arguments); }; CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.unselectAll = function (isDownUpdate) { if (this.selected === 'empty') return; return TreeNodeHolder.prototype.unselectAll.apply(this, arguments); }; CheckUnsafeTreeLeafOnlyBox_TreeLeafOnlyNodeHolder.prototype.updateFromChild = function () { if (this.child.length === 0) return; var count = this.child.reduce((ac, cr) => { ac[cr.selected]++; return ac; }, { all: 0, child: 0, none: 0, empty: 0 }); // if (this.boxElt.debug) // console.log( this.item, count.empty , count.all, this.child.length);//0, 9, 10 if (count.empty === this.child.length) { this.selected = 'empty'; } else if (count.empty + count.all === this.child.length) { this.selected = 'all'; } else if (count.all + count.child > 0) { this.selected = 'child'; } else if (this.selected !== "empty") { this.selected = 'none'; } if (this.itemElt) { this.itemElt.selected = this.selected; } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiCheckTreeMenu.js /*** * @extends AElement * @constructor */ function MultiCheckTreeMenu() { this._items = []; this._values = [];//commited value this._viewValues = []; /*** * @type {CheckTreeBox|CheckTreeLeafOnlyBox} */ this.$checkTreeBox = (0,ACore._)({ tag: this.renderProps.leafOnly ? (this.attr('data-version') === '2.0' ? js_CheckUnsafeTreeLeafOnlyBox.tag : js_CheckTreeLeafOnlyBox.tag) : js_CheckTreeBox.tag, // forceMobile: true, on: { change: this.eventHandler.boxChange, preupdateposition: this.eventHandler.preUpdateListPosition, toggleitem: this.eventHandler.boxToggleItem, cancel: this.eventHandler.boxCancel, close: this.eventHandler.boxClose }, props: { initOpened: this.renderProps.initOpened, enableSearch: this.renderProps.enableSearch } }); this.$itemCtn = (0,ACore.$)('.as-multi-select-menu-item-ctn', this); this.$checkTreeBox.followTarget = this; this.$checkTreeBox.sponsorElement = this; this.on('mousedown', this.eventHandler.click); this.dropdownCtrl = new MCTMDropController(this); // this.placeholder = LangSys.getText('txt_select_value') || '-- Select values --'; /** * @name readOnly * @type {boolean} * @memberOf MultiCheckTreeMenu# */ /** * @name disabled * @type {boolean} * @memberOf MultiCheckTreeMenu# */ /** * parent will be selected if all off leaf selected, sub tree can not select if had no leaf * @name leafOnly * @type {boolean} * @memberOf MultiCheckTreeMenu# */ /** * parent will be selected if all off leaf selected, sub tree can not select if had no leaf * @name initOpened * @type {number} * @memberOf MultiCheckTreeMenu# */ /*** * todo: TREE has noSelect */ } MultiCheckTreeMenu.tag = 'MultiCheckTreeMenu'.toLowerCase(); MultiCheckTreeMenu.render = function (data, domDesc) { var leafOnly = domDesc.props && domDesc.props.leafOnly; var props = domDesc.props || {}; /** * @name renderProps * @memberof MultiCheckTreeMenu# */ var res = (0,ACore._)({ class: ['as-multi-select-menu', 'as-multi-check-tree-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { class: ['as-multi-select-menu-item-ctn', 'as-bscroller'], attr: { "data-ml-key": 'txt_select_value' }, }, { tag: 'button', class: 'as-multi-select-menu-toggle-btn', child: 'dropdown-ico' }, 'attachhook' ], props: { renderProps: props } }); if (props.version === 2) { res.attr('data-version', '2'); } if (leafOnly) res.addClass('as-leaf-only'); if (BrowserDetector/* default.isMobile */.Z.isMobile) res.addClass('am-multi-select-menu'); return res; }; MultiCheckTreeMenu.prototype.tokenPool = []; MultiCheckTreeMenu.prototype.styleHandlers = {}; MultiCheckTreeMenu.prototype.styleHandlers.maxWidth = function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (parsedValue.unit === 'px') { this.addClass('as-has-max-width'); this.addStyle('--max-width', value); } else { this.removeClass('as-has-max-width'); } }; MultiCheckTreeMenu.prototype.styleHandlers['max-width'] = MultiCheckTreeMenu.prototype.styleHandlers.maxWidth; MultiCheckTreeMenu.prototype.styleHandlers.width = function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (parsedValue.unit === 'px') { this.addClass('as-has-max-width'); this.addStyle('--max-width', value); this.style.width = value; } else { this.removeClass('as-has-max-width'); } }; MultiCheckTreeMenu.prototype.styleHandlers.overflow = function (value) { if (value === 'hidden') { this.style.overflow = 'hidden'; } else { this.style.overflow = ''; } }; MultiCheckTreeMenu.prototype.addStyle = function (arg0, arg1) { if ((typeof arg0 === "string") && (this.styleHandlers[arg0])) { this.styleHandlers[arg0].apply(this, Array.prototype.slice.call(arguments, 1)); return this; } else { return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } }; MultiCheckTreeMenu.prototype.removeStyle = function (arg0) { if ((typeof arg0 === "string") && (this.styleHandlers[arg0])) { this.styleHandlers[arg0].call(this, ''); return this; } else { return AElement/* default.prototype.removeStyle.apply */.Z.prototype.removeStyle.apply(this, arguments); } }; MultiCheckTreeMenu.prototype._requestToken = function () { var token = this.tokenPool.pop(); if (!token) { token = (0,ACore._)({ tag: js_SelectBoxItem.tag, props: { menu: this }, on: { close: function (event) { setTimeout(function () { if (this.menu) this.menu.eventHandler.pressCloseToken(this, event); }.bind(this), 1) } } }); } return token; }; MultiCheckTreeMenu.prototype._releaseToken = function (token) { token.menu = null; this.tokenPool.push(token); }; MultiCheckTreeMenu.prototype._filToken = function (n) { while (this.$itemCtn.childNodes.length > n) { this.$itemCtn.removeChild(this.$itemCtn.lastChild); } while (this.$itemCtn.childNodes.length < n) { this.$itemCtn.addChild(this._requestToken()); } }; MultiCheckTreeMenu.prototype._assignTokens = function (items) { for (var i = 0; i < items.length; ++i) { this.$itemCtn.childNodes[i].data = items[i]; } }; MultiCheckTreeMenu.prototype.findItemsByValues = function (values) { return values.map(function (value) { var holders = this.$checkTreeBox.findItemHoldersByValue(value); if (holders.length > 0) return holders[0].item; return null; }.bind(this)).filter(function (it) { return !!it; }); }; MultiCheckTreeMenu.prototype.findItemByValue = function (value) { return this.$checkTreeBox.findItemByValue(value); }; MultiCheckTreeMenu.prototype.viewValues = function (values) { values = values.slice(); var items = this.findItemsByValues(values); this._filToken(items.length); this._assignTokens(items); this._viewValues = values; if (this.isFocus) { var bound = this.getBoundingClientRect(); this.$checkTreeBox.addStyle('min-width', bound.width + 'px'); ResizeSystem/* default.update */.Z.update(); } setTimeout(this._updateOverflow.bind(this), 100) }; MultiCheckTreeMenu.prototype._updateOverflow = function () { var bound; if (this.getComputedStyleValue('overflow') === 'hidden') { bound = this.getBoundingClientRect(); if (bound.width === 0) return; this.$itemCtn.removeClass('as-has-more'); var hasMore = false; var elt; for (var i = 0; i < this.$itemCtn.childNodes.length; ++i) { elt = this.$itemCtn.childNodes[i]; if (!hasMore) { elt.removeStyle('display'); var cBound = elt.getBoundingClientRect(); if (cBound.bottom > bound.bottom) { hasMore = true; } } if (hasMore) { elt.addStyle('display', 'none'); } } if (hasMore) this.$itemCtn.addClass('as-has-more'); } }; MultiCheckTreeMenu.prototype.commitView = function () { var values = this._values; var newValues = this.$checkTreeBox.values.slice(); if (!(0,DataStructure_Array.arrayCompare)(values, newValues)) { this._values = this.$checkTreeBox.values.slice(); this.emit('change', { type: 'change', target: this }, this); } }; MultiCheckTreeMenu.prototype.cancelView = function () { this.$checkTreeBox.values = this._values.slice(); this.viewValues(this.$checkTreeBox.viewValues); }; MultiCheckTreeMenu.prototype.init = function (props) { props = props || {}; var cProps = Object.assign({}, props); if ('initOpened' in props) { this.initOpened = props.initOpened; delete cProps.initOpened; } if ('leafOnly' in props) { this.leafOnly = props.leafOnly; delete cProps.leafOnly; } if ('items' in props) { this.items = props.items; delete cProps.items; } if ('values' in props) { this.values = props.values; delete cProps.values; } Object.assign(this, cProps); } MultiCheckTreeMenu.property = {}; MultiCheckTreeMenu.property.initOpened = { set: function (value) { if (value === true) value = 100; if ((0,utils.isNaturalNumber)(value)) { this._initOpened = value; } else { this._initOpened = 0; } this.$checkTreeBox.initOpened = this._initOpened; }, get: function () { return this._initOpened; } } MultiCheckTreeMenu.property.isFocus = { /*** * @this MultiCheckTreeMenu * @param value */ set: function (value) { this.dropdownCtrl.isFocus = value; }, get: function () { return this.dropdownCtrl.isFocus; } }; MultiCheckTreeMenu.property.items = { set: function (items) { this._items = (0,utils.copySelectionItemArray)(items || [], { removeNoView: true }); this.$checkTreeBox.items = this._items; this.addStyle('--list-min-width', Math.max(145 + 20, this.$checkTreeBox.estimateSize.width) + 'px'); this.viewValues(this.$checkTreeBox.viewValues); this._values = this.$checkTreeBox.values.slice(); }, get: function () { return this.$checkTreeBox.items ||[]; } }; MultiCheckTreeMenu.property.values = { /*** * @this MultiCheckTreeMenu * @param values */ set: function (values) { if (!(values instanceof Array)) values = []; values = (0,DataStructure_Array.arrayUnique)(values); this.$checkTreeBox.values = values; this.viewValues(this.$checkTreeBox.viewValues); this._values = this.$checkTreeBox.values.slice(); }, /*** * @this MultiCheckTreeMenu */ get: function () { if (this.isFocus) return this._values.slice(); return this.$checkTreeBox.values.slice(); } }; MultiCheckTreeMenu.property.checkedValues = { get: function () { return this.$checkTreeBox.viewValues.slice(); } }; MultiCheckTreeMenu.property.leafOnly = { set: function (value) { if (!!value === this.hasClass('as-leaf-only')) return; throw Error("Can not change leafOnly value!"); }, get: function () { return this.hasClass('as-leaf-only'); } }; MultiCheckTreeMenu.property.placeholder = { set: function (value) { if (value) { this.$itemCtn.attr('data-placeholder', value + ''); } else { this.$itemCtn.attr('data-placeholder', null); } }, get: function () { return this.$itemCtn.attr('data-placeholder'); } }; MultiCheckTreeMenu.property.disabled = js_MultiSelectMenu.property.disabled; MultiCheckTreeMenu.property.readOnly = js_MultiSelectMenu.property.readOnly; MultiCheckTreeMenu.eventHandler = {}; /*** * @this MultiCheckTreeMenu * @param event */ MultiCheckTreeMenu.eventHandler.clickOut = function (event) { if ((event.target.hasClass && event.target.hasClass('am-modal')) || event.target === this || event.target === this.$itemCtn || (!(0,EventEmitter/* hitElement */.EY)(this, event) && !(0,EventEmitter/* hitElement */.EY)(this.$checkTreeBox, event))) { this.isFocus = false; this.commitView(); } }; /*** * @this MultiCheckTreeMenu * @param event */ MultiCheckTreeMenu.eventHandler.boxClose = function (event) { this.commitView(); this.isFocus = false; }; /*** * @this MultiCheckTreeMenu * @param event */ MultiCheckTreeMenu.eventHandler.click = function (event) { if (!this.readOnly && (event.target === this || event.target === this.$itemCtn)) { this.isFocus = true; } }; /*** * @this MultiCheckTreeMenu * @param event */ MultiCheckTreeMenu.eventHandler.boxChange = function (event) { this.viewValues(this.$checkTreeBox.viewValues); ResizeSystem/* default.update */.Z.update(); }; MultiCheckTreeMenu.eventHandler.boxCancel = function (event) { this.cancelView(); this.isFocus = false; }; /*** * @this MultiCheckTreeMenu * @param {SelectBoxItem} tokenElt * @param event */ MultiCheckTreeMenu.eventHandler.pressCloseToken = function (tokenElt, event) { var value = tokenElt.value; var holders = this.$checkTreeBox.findItemHoldersByValue(value); holders.forEach(function (holder) { holder.unselectAll(); }); this.$checkTreeBox.updateSelectedInViewIfNeed(); var newValues = this.$checkTreeBox.viewValues.slice(); this.viewValues(newValues); console.log(this._values, newValues) if (!(0,DataStructure_Array.arrayCompare)(this._values, newValues)) { this._values = newValues; this.emit('change', { type: 'change', target: this }, this); } }; MultiCheckTreeMenu.eventHandler.preUpdateListPosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom - 50; this.$checkTreeBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { this.isFocus = false; } }; MultiCheckTreeMenu.eventHandler.boxToggleItem = function (event) { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$checkTreeBox.addStyle('--max-height', (this.$checkTreeBox._lastAnchor < 4 ? availableBot : availableTop) + 'px'); this.$checkTreeBox.updatePosition(); }; MultiCheckTreeMenu.property.enableSearch = { set: function (value) { this.$checkTreeBox.enableSearch = !!value; }, get: function () { return this.$checkTreeBox.enableSearch; } }; ACore/* default.install */.Z.install(MultiCheckTreeMenu); /* harmony default export */ const js_MultiCheckTreeMenu = (MultiCheckTreeMenu); /** * @constructor * @param {MultiCheckTreeMenu} elt * @constructor */ function MCTMDropController(elt) { this.elt = elt; } MCTMDropController.prototype.open = function () { if (this.elt.readOnly || this.elt.disabled) return; if (this.elt.hasClass('as-focus')) return; this.elt.addClass('as-focus'); this.elt.off('mousedown', this.elt.eventHandler.click); var bound = this.elt.getBoundingClientRect(); this.elt.$checkTreeBox.addStyle('min-width', bound.width + 'px'); // Set dropdown width this.elt.$checkTreeBox.addTo(document.body); // Attach dropdown to the body this.elt.$checkTreeBox.updatePosition(); // Update dropdown position if (this.elt._focusTimeout > 0) { clearTimeout(this.elt._focusTimeout); // Clear any existing timeout } // Set a timeout to handle focus and add event listener for clicking outside this.elt._focusTimeout = setTimeout(() => { document.addEventListener('mousedown', this.elt.eventHandler.clickOut); this.elt._focusTimeout = -1; this.elt.$checkTreeBox.focus(); // Focus on the dropdown }, 5); }; MCTMDropController.prototype.close = function () { if (!this.elt.hasClass('as-focus')) return; this.elt.removeClass('as-focus'); this.elt.$checkTreeBox.selfRemove(); // Detach dropdown from the body this.elt.$checkTreeBox.resetSearchState(); // Reset search state document.removeEventListener('mousedown', this.elt.eventHandler.clickOut); // Remove click-out listener // Re-enable the click event after a delay const waitMouseUp = () => { document.removeEventListener('mouseup', waitMouseUp); setTimeout(() => { this.elt.on('mousedown', this.elt.eventHandler.click); }, 5); }; setTimeout(waitMouseUp, 100); }; MCTMDropController.prototype.ev_clickOut = function (event) { }; Object.defineProperty(MCTMDropController.prototype, "isFocus", { set: function (value) { if (value) this.open(); else this.close(); }, get: function () { return this.elt.hasClass('as-focus'); } }); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/fileinputbox.css var fileinputbox = __webpack_require__(5252); // EXTERNAL MODULE: ./node_modules/absol-acomp/assets/exticons/catalog.json var catalog = __webpack_require__(2398); // EXTERNAL MODULE: ./node_modules/absol/src/Network/FileSaver.js var FileSaver = __webpack_require__(5447); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FileInputBox.js /*** * @extends AElement * @constructor */ function FileInputBox() { this.$fileSize = (0,ACore.$)('.as-file-input-box-file-size', this); this.$fileName = (0,ACore.$)('.as-file-input-box-file-name', this); this.$bg = (0,ACore.$)('.as-file-input-box-background', this); this.$input = (0,ACore.$)('input', this) .on('change', this.eventHandler.input_fileChange); this.$trigger = (0,ACore._)({ elt: (0,ACore.$)('.as-file-input-box-trigger', this), tag: DropZone/* default.tag */.Z.tag, on: { fileenter: this.eventHandler.input_fileEnter, fileleave: this.eventHandler.input_fileLeave, filedrop: this.eventHandler.input_fileDrop, } }); this.$downloadBtn = (0,ACore.$)('.as-file-input-box-download-btn', this) .on('click', this.download.bind(this)); this.$removeBtn = (0,ACore.$)('.as-file-input-box-remove-btn', this) .on('click', this.clearValue.bind(this, true)); this._value = null; this._fileSize = null; this._fileName = null; this._fileType = null; this._valueInfo = null; this._thumbnail = null; /*** * default true * @name allowUpload * @type {boolean} * @memberOf FileInputBox# */ this.allowUpload = true; /*** * @name value * @type {null|any} * @memberOf FileInputBox# */ /*** * @name thumbnail * @type {null|any} * @memberOf FileInputBox# */ /*** * @name fileSize * @type {null|number} * @memberOf FileInputBox# */ /*** * @name fileType * @type {null|string} * @memberOf FileInputBox# */ /*** * @name fileName * @type {null|string} * @memberOf FileInputBox# */ /*** * default: false * @name downloadable * @type {boolean} * @memberOf FileInputBox# */ } FileInputBox.tag = 'FileInputBox'.toLowerCase(); FileInputBox.render = function () { return (0,ACore._)({ extendEvent: ['change'], class: 'as-file-input-box', child: [ '.as-file-input-box-background', { tag: 'label', class: 'as-file-input-box-trigger', child: { tag: 'input', attr: { type: 'file', accept: '*', title: null } } }, { class: 'as-file-input-box-upload-overlay', child: 'span.mdi.mdi-upload' }, { class: 'as-file-input-box-info', child: [ { tag: 'span', class: 'as-file-input-box-file-name', child: { text: '' } }, 'br', { tag: 'span', class: 'as-file-input-box-file-size', child: { text: '' } }, ] }, { class: 'as-file-input-box-action-left', child: { tag: 'button', class: 'as-file-input-box-remove-btn', child: 'span.mdi.mdi-close' } }, { class: 'as-file-input-box-action-right', child: { tag: 'button', class: 'as-file-input-box-download-btn', child: 'span.mdi.mdi-download' } }, { class: 'as-file-input-box-checked', child: 'span.mdi.mdi-check-bold' }, ] }); }; FileInputBox.prototype.download = function () { var value = this.value; if (value) { if (value && value.name && value.url) { (0,FileSaver.saveAs)(value.url, value.name); } else { (0,FileSaver.saveAs)(value, this.fileName); } } }; FileInputBox.prototype.clearValue = function (userAction, event) { if (this.value) { this.value = null; if (userAction) { this.emit('change', { type: 'change', originalEvent: event, action: 'clear', target: this }, this); } } }; FileInputBox.prototype._updateThumbnail = function () { var previewUrl; var thumbnail = this.thumbnail; var fileType = this.fileType; if (thumbnail) { if (typeof thumbnail === "string") { previewUrl = thumbnail; } else if (thumbnail instanceof Blob || thumbnail instanceof File) { thumbnail.url = thumbnail.url || URL.createObjectURL(thumbnail); previewUrl = thumbnail.url; } } if (!previewUrl) { if (catalog.indexOf(fileType) >= 0) { previewUrl = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + fileType + '.svg'; } else { previewUrl = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + 'blank' + '.svg'; } } if (previewUrl) { this.$bg.addStyle('backgroundImage', 'url("' + encodeURI(previewUrl) + '")'); } else { this.$bg.removeStyle('backgroundImage') } }; FileInputBox.prototype._updateFileName = function () { var fileName = this.fileName; if (fileName) { this.$fileName.firstChild.data = fileName; this.addClass('as-has-file-name'); } else { this.$fileName.firstChild.data = ''; this.removeClass('as-has-file-name'); } }; FileInputBox.prototype._updateFileSize = function () { var fileSize = this.fileName; if (fileSize === null) { this.$fileSize.firstChild.data = ''; this.removeClass('as-has-file-size'); } else { this.$fileSize.firstChild.data = (0,utils.fileSize2Text)(fileSize); this.addClass('as-has-file-size'); } }; FileInputBox.property = {}; FileInputBox.property.value = { set: function (value) { value = value || null; this._value = value; this._valueInfo = (0,utils.fileInfoOf)(value); this._updateThumbnail(); this._updateFileName(); this._updateFileSize(); if (value) { this.addClass('as-has-value'); } else { this.removeClass('as-has-value'); } }, get: function () { return this._value; } }; FileInputBox.property.fileType = { set: function (value) { this._fileType = value; this._updateThumbnail(); }, /*** * @this FileInputBox * @return {*} */ get: function () { return this._fileType || (this._valueInfo && this._valueInfo.type) || null; } }; FileInputBox.property.fileName = { set: function (value) { value = typeof value === 'string' ? value : null; this._fileName = value; this._updateFileName(); }, get: function () { return this._fileName || (this._valueInfo && this._valueInfo.name) || null; } }; FileInputBox.property.fileSize = { set: function (value) { if ((0,utils.isRealNumber)(value)) value = Math.max(0, value); else value = null; this._fileSize = value; this._updateFileSize(); }, get: function () { if (typeof this._fileSize === "number") return this._fileSize; if (this._valueInfo && typeof this._valueInfo.size === "number") return this._valueInfo.size; return null; } }; FileInputBox.property.thumbnail = { set: function (value) { this._thumbnail = value || null; this._updateThumbnail(); }, get: function () { return this._thumbnail; } }; FileInputBox.property.allowUpload = { set: function (value) { if (value) { this.addClass('as-allow-upload'); } else { this.removeClass('as-allow-upload'); } }, get: function () { return this.hasClass('as-allow-upload'); } }; FileInputBox.property.downloadable = { set: function (value) { if (value) { this.addClass('as-downloadable'); } else { this.removeClass('as-downloadable'); } }, get: function () { return this.hasClass('as-downloadable'); } }; FileInputBox.property.removable = { set: function (value) { if (value) { this.addClass('as-removable'); } else { this.removeClass('as-removable'); } }, get: function () { return this.hasClass('as-removable'); } }; FileInputBox.property.accept = { set: function (value) { if (!value) value = null; this.$input.attr('accept', value + ''); }, get: function () { return this.$input.attr('accept') || null; } }; FileInputBox.property.checked = { set: function (value) { if (value) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } }, get: function () { return this.hasClass('as-checked'); } }; FileInputBox.eventHandler = {}; FileInputBox.eventHandler.input_fileChange = function (event) { var files = Array.prototype.slice.call(this.$input.files); if (files.length > 0) { this.value = files[0]; this.emit('change', { type: 'change', originalEvent: event, file: files[0], action: 'file_dialog', target: this }, this); } }; FileInputBox.eventHandler.input_fileEnter = function (event) { }; FileInputBox.eventHandler.input_fileLeave = function (event) { }; FileInputBox.eventHandler.input_fileDrop = function (event) { var files = Array.prototype.slice.call(event.files); var accept = this.accept; var file; if (files.length > 0) { file = files[0]; if (!(0,utils.fileAccept)(accept, file.type) && !(0,utils.fileAccept)(accept, file.name)) file = null; } if (file) { this.value = file; this.emit('change', { type: 'change', originalEvent: event, file: file, action: 'drop', target: this }, this); } }; ACore/* default.install */.Z.install(FileInputBox); /* harmony default export */ const js_FileInputBox = (FileInputBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/countdowntext.css var countdowntext = __webpack_require__(9803); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CountdownText.js var CountdownText_ = ACore/* default._ */.Z._; var CountdownText_$ = ACore/* default.$ */.Z.$; var tokenCache = {}; function remainSecondToText(remainSecond, format) { var tokens = tokenCache[format]; if (!tokens) { tokens = (format.match(new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g')) || []).reduce(function (ac, cr) { ac[cr] = true; return ac; }, {}); tokenCache[format] = tokens; } var newText; var sec, min, hour; sec = Math[(tokens['ms'] || tokens['mss']) ? 'floor' : 'ceil'](remainSecond); min = Math.floor(remainSecond / 60); hour = Math.floor(remainSecond / 60 / 60); newText = format.replace(new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g'), function (all) { switch (all) { case 'D': return Math.floor(remainSecond / 60 / 60 / 24) + ''; case 'HH': case 'H': case 'hh': if (tokens['D']) { return (0,utils.zeroPadding)(hour % 24, all.length); } else { return (0,utils.zeroPadding)(hour, all.length); } case 'mm': case 'M': case 'MM': if (tokens['HH'] || tokens['hh']) { return (0,utils.zeroPadding)(min % 60, all.length); } else { return (0,utils.zeroPadding)(min, all.length); } case 'ss': case 'S': case 'SS': if (tokens['m'] || tokens['mm']) { return (0,utils.zeroPadding)(sec % 60, all.length); } else { return (0,utils.zeroPadding)(sec, all.length); } case 'cs': return (0,utils.zeroPadding)(Math.ceil(remainSecond * 100) % 100, 2); case 'ms': return (0,utils.zeroPadding)(Math.ceil(remainSecond * 1000) % 1000, 3); default: return all; } }); return newText; } /*** * @extends AElement * @constructor */ function CountdownText() { this.addClass('as-countdown-text'); this.defineEvent('update'); this.defineEvent('finish'); this.text = ''; this._format = 'HH:mm'; this.format = 'HH:mm'; this.fps = 5; this._finishTime = null; this.finishTime = null; this['_tick'] = this._tick.bind(this); setTimeout(this.start.bind(this), 0);//auto start /*** * @type {number} * @name remainSecond * @memberOf CountdownText# */ /*** * @type {Date} * @name finishTime * @memberOf CountdownText# */ /*** * @type {string} * @name format * @memberOf CountdownText# */ } CountdownText.tag = 'CountdownText'.toLowerCase(); CountdownText.render = function () { return CountdownText_('span'); }; CountdownText.prototype.buildinFormat = { 'standard': function (remainSecond) { if (remainSecond >= 24 * 3600) { return remainSecondToText(remainSecond, 'D ngày HH:mm:ss'); } else { return remainSecondToText(remainSecond, 'HH:mm:ss'); } } }; CountdownText.prototype._tick = function () { var remainSecond = this.remainSecond; var prevText = this.text; var newText; var format = this._format; if (this.buildinFormat[format]) format = this.buildinFormat[format]; if (typeof format === "function") { newText = format.call(this, remainSecond); } else if (typeof format === "string") { newText = remainSecondToText(remainSecond, format); } if (prevText !== newText) { this.text = newText; this.innerHTML = newText; this.emit('update', { target: this, type: 'update' }, this); } if (remainSecond <= 0) { this.stop(); this.emit('finish', { target: this, type: 'update' }, this); } }; CountdownText.prototype.start = function () { this.resume(); }; CountdownText.prototype.resume = function () { if (this._intvId > 0) return; this._intvId = setInterval(this._tick, 1000 / this.fps); }; CountdownText.prototype.pause = function () { if (this._intvId > 0) { clearInterval(this._intvId); this._intvId = -1; } }; CountdownText.prototype.stop = function () { this.pause(); }; CountdownText.property = {}; CountdownText.property.format = { set: function (value) { if (typeof value === "string" || typeof value === 'function') { this._format = value || 'HH:mm'; } else { this._format = 'HH:mm'; } }, get: function () { return this._format; } }; CountdownText.property.remainSecond = { set: function (value) { if (!(value >= 0)) { value = 0; } this.finishTime = new Date(new Date().getTime() + value) }, get: function () { if (this.finishTime !== null) { return Math.max(0, (this.finishTime.getTime() - new Date().getTime()) / 1000); } else return null; } }; CountdownText.property.finishTime = { set: function (value) { if (typeof value === "number" || typeof value === 'string') { value = new Date(value); } if (!value || !value.getTime) value = null; if (value && value.getTime && isNaN(value.getTime())) value = null; this._finishTime = value; }, get: function () { return this._finishTime; } }; CountdownText.property.fps = { set: function (value) { this._fps = (0,utils.isRealNumber)(value) ? value : 200; if (this._intvId > 0) { clearInterval(this._intvId); this._intvId = setInterval(this._tick, 1000 / this._fps); } }, get: function () { return this._fps; } }; ACore/* default.install */.Z.install(CountdownText); /* harmony default export */ const js_CountdownText = (CountdownText); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/YesNoQuestionDialog.js var YesNoQuestionDialog = __webpack_require__(5466); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LoadingCubeModal.js /*** * @extends Modal * @constructor */ function LoadingCubeModal() { } LoadingCubeModal.tag = 'LoadingCubeModal'.toLowerCase(); LoadingCubeModal.render = function () { return (0,ACore._)({ tag:'modal', class: 'as-loading-cube-modal', child: '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin: auto; background: rgb(241, 242, 243); display: block; shape-rendering: auto;" width="200px" height="200px" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid">\n' + '<g transform="translate(26.666666666666668,26.666666666666668)">\n' + ' <rect x="-20" y="-20" width="40" height="40" fill="#13a9df">\n' + ' <animateTransform attributeName="transform" type="scale" repeatCount="indefinite" dur="1s" keyTimes="0;1" values="1.1500000000000001;1" begin="-0.3s"></animateTransform>\n' + ' </rect>\n' + '</g>\n' + '<g transform="translate(73.33333333333333,26.666666666666668)">\n' + ' <rect x="-20" y="-20" width="40" height="40" fill="#4be44c">\n' + ' <animateTransform attributeName="transform" type="scale" repeatCount="indefinite" dur="1s" keyTimes="0;1" values="1.1500000000000001;1" begin="-0.2s"></animateTransform>\n' + ' </rect>\n' + '</g>\n' + '<g transform="translate(26.666666666666668,73.33333333333333)">\n' + ' <rect x="-20" y="-20" width="40" height="40" fill="#e2d58b">\n' + ' <animateTransform attributeName="transform" type="scale" repeatCount="indefinite" dur="1s" keyTimes="0;1" values="1.1500000000000001;1" begin="0s"></animateTransform>\n' + ' </rect>\n' + '</g>\n' + '<g transform="translate(73.33333333333333,73.33333333333333)">\n' + ' <rect x="-20" y="-20" width="40" height="40" fill="#e1e7e7">\n' + ' <animateTransform attributeName="transform" type="scale" repeatCount="indefinite" dur="1s" keyTimes="0;1" values="1.1500000000000001;1" begin="-0.1s"></animateTransform>\n' + ' </rect>\n' + '</g>\n' + '</svg>' }); }; LoadingCubeModal.share = { token: null, $elt: null }; /*** * * @return {String} */ LoadingCubeModal.show = function (){ if (!LoadingCubeModal.share.$elt) LoadingCubeModal.share.$elt = (0,ACore._)(LoadingCubeModal.tag); if (!LoadingCubeModal.share.$elt.isDescendantOf(document.body)){ document.body.appendChild(LoadingCubeModal.share.$elt); } LoadingCubeModal.share.token = (0,stringGenerate.randomIdent)(9); return LoadingCubeModal.share.token; }; /*** * * @param {String} token * @return {Boolean} */ LoadingCubeModal.close = function (token){ if (LoadingCubeModal.share.$elt &&LoadingCubeModal.share.$elt.isDescendantOf(document.body) && (!token || token ===LoadingCubeModal.share.token)){ this.share.$elt.remove(); LoadingCubeModal.share.token = null; return true; } return false; }; ACore/* default.install */.Z.install(LoadingCubeModal); /* harmony default export */ const js_LoadingCubeModal = (LoadingCubeModal); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selecttreeleafmenu.css var selecttreeleafmenu = __webpack_require__(9953); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTreeLeafBox.js function isBranchStatus(status) { return status === 'open' || status === 'close'; } function invertStatus(status) { return { open: 'close', close: 'open' }[status] || 'none'; } /*** * @extends Follower * @constructor */ function SelectTreeLeafBox() { this._initControl(); this._searchCache = {}; this._value = null; this._items = []; this.strictValue = true; this.$items = []; this.$itemByValue = {}; this.$selectedItem = null; this.$dislayItems = this.$items; this.$dislayItemByValue = this.$itemByValue; this.$content = (0,ACore.$)('.as-select-tree-leaf-box-content', this); this._savedStatus = {}; this.estimateSize = { width: 0, height: 0 }; if (this.cancelWaiting) this.cancelWaiting(); /** * @name items * @memberof MSelectTreeLeafBox# * @type {Array} */ /** * @name value * @memberof MSelectTreeLeafBox# */ /** * @name strictMode * @type {boolean} * @memberof MSelectTreeLeafBox# */ /** * @name selectedItem * @memberof MSelectTreeLeafBox# */ } SelectTreeLeafBox.tag = 'SelectTreeLeafBox'.toLowerCase(); SelectTreeLeafBox.render = function () { return (0,ACore._)({ tag: Follower/* default */.Z, attr: { tabindex: 0 }, class: ['as-select-tree-leaf-box', 'as-select-list-box'], extendEvent: ['pressitem'], child: [{ class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller', 'as-select-tree-leaf-box-content'], child: [] }, 'attachhook.as-dom-signal'], props: { anchor: [1, 6, 2, 5] } }); }; SelectTreeLeafBox.prototype._initControl = function () { this.$searchInput = (0,ACore.$)('searchtextinput', this) .on('stoptyping', this.eventHandler.searchModify); }; SelectTreeLeafBox.prototype.resetSearchState = function () { var value = this.$searchInput.value; if (value.length > 0) { this.$searchInput.value = ''; if (value.trim().length) { this.$content.clearChild(); this.$content.addChild(this.$items); this.$dislayItems = this.$items; this.$dislayItemByValue = this.$itemByValue; this._updateSelectedItem(); } } }; SelectTreeLeafBox.prototype._findFirstLeaf = function () { var found = false; function visit(item) { if (item.isLeaf) { found = item; return true; } if (item.items && item.items.length > 0) { item.items.some(visit); } return !!found; } this._items.some(visit); return found; }; SelectTreeLeafBox.prototype._makeTree = function (item, dict, savedStatus) { var self = this; var status = 'none'; var isLeaf = item.isLeaf; if (item.items && item.items.length > 0) { status = 'close'; } if (isBranchStatus(status) && isBranchStatus(savedStatus[(0,utils.keyStringOf)(item.value)])) { status = savedStatus[(0,utils.keyStringOf)(item.value)]; } var nodeElt = (0,ACore._)({ tag: ExpTree/* default.tag */.ZP.tag, class: 'as-select-tree-leaf-item', props: { name: item.text, desc: item.desc, icon: item.icon, status: status, itemData: item }, on: { 'statuschange': this.updatePosition.bind(this) } }); if (item.noSelect) { nodeElt.addClass('as-no-select'); } nodeElt.getNode().on({ press: function (event) { if (isBranchStatus(nodeElt.status)) { nodeElt.status = invertStatus(nodeElt.status) savedStatus[(0,utils.keyStringOf)(item.value)] = nodeElt.status; self.updatePosition(); } else if (isLeaf && !item.noSelect) { self.emit('pressitem', { item: item, target: self, itemElt: nodeElt, originalEvent: event }, self); } } }); if (dict) { if (dict[(0,utils.keyStringOf)(item.value)] && !this.warned) { this.warned = true; console.warn(this, 'has duplicated value, element will not work correctly!', item); } dict[(0,utils.keyStringOf)(item.value)] = nodeElt; } if (item.isLeaf) { nodeElt.addClass('as-is-leaf'); } if (item.items && item.items.length > 0) { item.items.forEach(function (item1) { nodeElt.addChild(self._makeTree(item1, dict, savedStatus)); }); } return nodeElt; }; SelectTreeLeafBox.prototype._estimateItemWidth = function (item, level) { var width = 12;//padding width += 12 * level; width += 14.7 + 5;//toggle icon if (item.icon) width += 21;//icon width += 7 + (0,utils.estimateWidth14)(item.text) + 5 + 7;//margin-text if (item.desc) width += 6 + (0,utils.estimateWidth14)(item.desc) * 0.85; return width; }; SelectTreeLeafBox.prototype.viewToSelected = function () { var selectedNode = this.$selectedItem; if (!selectedNode) return; selectedNode.scrollIntoView(); var parent = selectedNode.getParent(); while (parent && parent.getParent) { if (parent.status === 'close') { parent.getNode().emit('press'); } parent = parent.getParent(); } }; SelectTreeLeafBox.prototype.viewToValue = function (value) { var viewNode = this.$itemByValue[(0,utils.keyStringOf)(value)]; if (!viewNode) return; viewNode.scrollIntoView(); while (viewNode && viewNode.getParent) { if (viewNode.status === 'close') { viewNode.getNode().emit('press'); } viewNode = viewNode.getParent(); } }; SelectTreeLeafBox.prototype._calcEstimateSize = function (items) { var self = this; var width = 0; var height = 0; function visit(item, level) { var itemWidth = self._estimateItemWidth(item, level); width = Math.max(width, itemWidth); height += 28; if (item.items && item.items.length) { item.items.forEach(function (item) { visit(item, level + 1); }); } } items.forEach(function (item) { visit(item, 0); }); return { width: width, height: height }; }; SelectTreeLeafBox.prototype._updateSelectedItem = function () { if (this.$selectedItem) { this.$selectedItem.removeClass('as-selected'); this.$selectedItem = null; } this.$selectedItem = this.$dislayItemByValue[(0,utils.keyStringOf)(this.value)]; if (this.$selectedItem) { this.$selectedItem.addClass('as-selected'); } }; SelectTreeLeafBox.prototype.findItemByValue = function (value) { var holder = this.$itemByValue[(0,utils.keyStringOf)(value)]; if (holder) return holder.itemData; return null; }; SelectTreeLeafBox.prototype.focus = js_SelectListBox.prototype.focus; SelectTreeLeafBox.property = {}; SelectTreeLeafBox.eventHandler = {}; SelectTreeLeafBox.property.items = { /*** * @this SelectTreeLeafBox * @param items */ set: function (items) { var self = this; this._savedStatus = {}; this._searchCache = {}; items = items || []; this._items = items; (0,search/* prepareSearchForList */.Lb)(items); this.$content.clearChild(); this.$itemByValue = {}; this.$dislayItemByValue = this.$itemByValue; this.$items = items.map(function (item) { return self._makeTree(item, self.$itemByValue, self._savedStatus); }); this.$dislayItems = this.$items; this.$content.addChild(this.$items); this.estimateSize = this._calcEstimateSize(items); this.addStyle('--select-list-estimate-width', this.estimateSize.width + 'px'); this._updateSelectedItem(); self.updatePosition(); }, get: function () { return this._items; } }; SelectTreeLeafBox.property.value = { set: function (value) { this._value = value; this._updateSelectedItem(); }, get: function () { var firstLeaf; if (!this.strictValue || this.$itemByValue[(0,utils.keyStringOf)(this._value)]) { return this._value; } else { firstLeaf = this._findFirstLeaf(); if (firstLeaf) return firstLeaf.value; else return this._value; } } }; SelectTreeLeafBox.property.selectedItem = { get: function () { var key = (0,utils.keyStringOf)(this._value); var firstLeaf; if (this.$itemByValue[key]) { return this.$itemByValue[key].itemData; } else if (!this.strictValue) { return null; } else { firstLeaf = this._findFirstLeaf(); if (firstLeaf) return firstLeaf; else return null; } } }; SelectTreeLeafBox.property.enableSearch = js_SelectListBox.property.enableSearch; SelectTreeLeafBox.prototype._search = function (query) { var self = this; var queryItem = (0,search/* default */.ZP)({ text: query }); var minScore = Infinity; var maxScore = -Infinity; function makeScoreTree(item) { var holder = { item: item, score: (0,search/* calcItemMatchScore */.lk)(queryItem, item), childrenScore: 0, children: [] }; minScore = Math.min(minScore, holder.score); maxScore = Math.max(maxScore, holder.score); var children; if (item.items && item.items.length > 0) { children = item.items.map(makeScoreTree); holder.children = children; holder.childrenScore = holder.children.reduce(function (ac, cr) { return Math.max(ac, cr.score, cr.childrenScore); }, 0); } return holder; } var treeScores = this._items.map(makeScoreTree); var midScore = (maxScore + minScore) / 2; var savedStatus = {}; function filterTree(scoredTrees, ignore) { return scoredTrees.filter(function (holder) { return ignore || holder.score >= midScore || holder.childrenScore >= midScore; }).map(function makeTree(holder) { var item = Object.assign({}, holder.item); if (!ignore && holder.children && holder.children.length > 0) { if (holder.childrenScore >= midScore) { savedStatus[(0,utils.keyStringOf)(item.value)] = 'open'; item.items = filterTree(holder.children, false); } else { savedStatus[(0,utils.keyStringOf)(item.value)] = 'close'; item.items = filterTree(holder.children, true); } } return item; }); } var resultItems = filterTree(treeScores, false); var dict = {}; var $items = resultItems.map(function (item) { return self._makeTree(item, dict, savedStatus); }); return { $items: $items, items: resultItems, savedStatus: Object.assign({}, savedStatus), originSavedStatus: savedStatus, dict: dict }; } /*** * @this SelectTreeLeafBox */ SelectTreeLeafBox.eventHandler.searchModify = function () { var query = this.$searchInput.value.trim(); if (query.length === 0) { this.$content.clearChild().addChild(this.$items); this.$dislayItemByValue = this.$itemByValue; this.$dislayItems = this.$items; this._updateSelectedItem(); this.updatePosition(); return; } if (!this._searchCache[query]) { this._searchCache[query] = this._search(query); } var searchData = this._searchCache[query]; searchData.savedStatus = Object.assign(searchData.savedStatus, searchData.originSavedStatus); console.log(searchData) for (var val in searchData.dict) { if (isBranchStatus(searchData.dict[val].status)) { if (searchData.savedStatus[val]) { searchData.dict[val].status = searchData.savedStatus[val] } } } this.$content.clearChild() .addChild(searchData.$items); this.$dislayItemByValue = searchData.dict; this.$dislayItems = searchData.$items; this._updateSelectedItem(); this.updatePosition(); }; ACore/* default.install */.Z.install(SelectTreeLeafBox); /* harmony default export */ const js_SelectTreeLeafBox = (SelectTreeLeafBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/selecttreeeleafbox.css var selecttreeeleafbox = __webpack_require__(4946); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreebox/CTIPropHandlers.js var CTIPropHandlers = {}; CTIPropHandlers.data = { /*** * @this MCheckTreeItem|CheckTreeItem * @param data */ set: function (data) { this._data = data; this._updateData(); }, get: function () { return this._data; } }; CTIPropHandlers.text = { get: function () { if (!this._data) return ''; if (this._data.charAt) return this._data; var text = this._data.text; if (text === undefined || text === null) return ''; return this._data.text + ''; } }; CTIPropHandlers.value = { get: function () { if (!this._data) return null; if (this._data.charAt) return this._data; return this._data.value; } }; CTIPropHandlers.desc = { get: function () { if (!this._data) return ''; var desc = this._data.desc; if (desc === undefined || desc === null) return ''; return desc + ''; } }; CTIPropHandlers.level = { set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 0; this._level = value; this.addStyle('--level', value + ''); }, get: function () { return this._level; } }; CTIPropHandlers.status = { set: function (value) { value = value === 'open' || value === 'close' ? value : 'none'; this._status = value; this.removeClass('as-status-open') .removeClass('as-status-close'); if (value !== "none") { this.addClass('as-status-' + value); } }, get: function () { return this._status || 'none'; } }; CTIPropHandlers.selected = { set: function (value) { if (value === 'all') { this.$checkbox.checked = true; this.$checkbox.removeClass('as-has-minus'); } else if (value === 'child') { this.$checkbox.checked = false; this.$checkbox.addClass('as-has-minus'); } else { this.$checkbox.checked = false; this.$checkbox.removeClass('as-has-minus'); } }, get: function () { if (this.$checkbox.checked) { return 'all'; } else { if (this.$checkbox.hasClass('as-has-minus')) { return 'child'; } else { return 'none'; } } } }; CTIPropHandlers.hasLeaf = { set: function (value) { if (value) { this.addClass('as-has-leaf'); } else { this.removeClass('as-has-leaf'); } }, get: function () { return this.hasClass('as-has-leaf'); } }; CTIPropHandlers.noSelect = { set: function (value) { if (value) { this.addClass('as-no-select'); } else { this.removeClass('as-no-select'); } this.$checkbox.disabled = !!value; }, get: function () { return this.hasClass('as-no-select'); } }; /* harmony default export */ const checktreebox_CTIPropHandlers = (CTIPropHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/STLIPropHandlers.js var STLIPropHandlers = {}; STLIPropHandlers.data = { set: function (data) { this._data = data; this._updateData(); }, get: function () { return this._data; } }; STLIPropHandlers.text = { get: function () { var data = this._data; if (data === undefined || data === null) return ''; if (typeof data === 'string') return data; if (data && data.text) return data.text + ''; return data + ''; } }; STLIPropHandlers.value = { get: function () { var data = this._data; if (data === undefined || data === null) return data; if (data && ('value' in data)) return data.value; return data; } }; STLIPropHandlers.level = checktreebox_CTIPropHandlers.level; STLIPropHandlers.status = checktreebox_CTIPropHandlers.status; STLIPropHandlers.selected = { set: function (value) { if (value) { this.addClass('as-selected'); } else { this.removeClass('as-selected'); } }, get: function () { return this.hasClass('as-selected'); } }; /**** * @name text * @type {string} * @memberOf SelectTreeLeafItem# */ /**** * @name value * @type {string|number} * @memberOf SelectTreeLeafItem# */ /**** * @name data * @type {*} * @memberOf SelectTreeLeafItem# */ /**** * @name selected * @type {boolean} * @memberOf SelectTreeLeafItem# */ /* harmony default export */ const selecttreeleafbox_STLIPropHandlers = (STLIPropHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/SelectTreeLeafItem.js /*** * @extends AElement * @constructor */ function SelectTreeLeafItem() { this.$text = (0,ACore.$)('.am-select-tree-leaf-item-text', this); this.$desc = (0,ACore.$)('.am-select-tree-leaf-item-desc', this); this.$iconCtn = (0,ACore.$)('.am-select-tree-leaf-item-icon-ctn', this); this.addEventListener('click', this.eventHandler.click); } SelectTreeLeafItem.tag = 'SelectTreeLeafItem'.toLowerCase(); SelectTreeLeafItem.render = function () { return (0,ACore._)({ extendEvent: ['click', 'statuschange'], class: ['am-select-tree-leaf-item', 'am-dropdown-box-item'], child: [ { class: 'am-select-tree-leaf-item-toggle-ctn', child: 'toggler-ico' }, { class: 'am-select-tree-leaf-item-icon-ctn' }, { class: 'am-select-tree-leaf-item-text', child: { text: '' } }, { class: 'am-select-tree-leaf-item-desc', child: { text: '' } } ] }); }; SelectTreeLeafItem.prototype._updateData = function () { this.$text.firstChild.data = this.text; this.attr('data-key', (0,utils.keyStringOf)(this.value)); this.$iconCtn.clearChild(); var icon = this.data && this.data.icon; if (icon) { icon = (0,ACore._)(icon); if (icon.parentElement) icon = (0,ACore.$)(icon.cloneNode(true)); this.$iconCtn.addChild(icon); this.addClass('as-has-icon'); } else { this.removeClass('as-has-icon'); } if (this.data && this.data.isLeaf) { this.addClass('as-is-leaf'); } else { this.removeClass('as-is-leaf'); } }; SelectTreeLeafItem.property = selecttreeleafbox_STLIPropHandlers; SelectTreeLeafItem.eventHandler = {}; SelectTreeLeafItem.eventHandler.click = function (event) { if (this._data && this._data.isLeaf) { this.emit('click', { type: 'click', target: this, originalEvent: event }, this); } else { if (this.status !== 'none') { this.status = this.status === 'open' ? 'close' : 'open'; this.emit('statuschange', { type: 'statuschange', target: this, originalEvent: event }, this); } } }; /* harmony default export */ const selecttreeleafbox_SelectTreeLeafItem = (SelectTreeLeafItem); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dropdownbox.css var dropdownbox = __webpack_require__(8618); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreebox/CTBPropHandlers.js var CTBPropHandlers = {}; CTBPropHandlers.items = { /*** * @this MCheckTreeBox * @param items */ set: function (items) { this.itemListCtrl.setItems(items); var values = this.pendingValues || this.values; this.modes.normal.setValues(values); if (this.mode !== this.modes.normal) { this.mode.updateSelectedFromRef(); } }, get: function () { return this.itemListCtrl.getItems(); } }; CTBPropHandlers.values = { /*** * @this CheckTreeBox|MCheckTreeBox * @param values */ set: function (values) { this.pendingValues = values || []; this.modes.normal.setValues(values); if (this.mode !== this.modes.normal) { this.mode.updateSelectedFromRef(); } }, get: function () { return this.modes.normal.getValues(); } }; CTBPropHandlers.viewValues = { get: function (){ return this.modes.normal.getViewValues(); } }; CTBPropHandlers.enableSearch = { /*** * @this CheckTreeBox|MCheckTreeBox * @param value */ set: function (value) { if (value) { this.$box.addClass('as-enable-search'); } else { this.$box.removeClass('as-enable-search'); } }, get: function () { return this.$box.hasClass('as-enable-search'); } }; CTBPropHandlers.leafOnly = { /*** * @this CheckTreeBox|MCheckTreeBox * @param value */ set: function (value) { if (value) { this.$box.addClass('as-leaf-only'); } else { this.$box.removeClass('as-leaf-only'); } var values = this.pendingValues || this.values; this.modes.normal.setValues(values); }, get: function () { return this.$box.hasClass('as-leaf-only'); } }; /* harmony default export */ const checktreebox_CTBPropHandlers = (CTBPropHandlers); /*** * * @type {boolean} * @name enableSearch * @memberOf MCheckTreeBox# */ ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreebox/CTBModes.js /*** * * @param {MCheckTreeBox} elt * @param {[]} items * @constructor */ function CTBModeNormal(elt, items) { this.level = -1; this.selected = 'none'; this.elt = elt; this.$list = this.elt.$list; /*** * * @type {MCTBItemHolder[]} */ this.children = items.map(item => new this.elt.classes.ItemHolder(elt, this, item)); this.hasLeaf = this.children.some(holder => holder.hasLeaf); this.hasNoSelect = this.children.some(holder => holder.hasNoSelect); this.hasDesc = this.children.some(holder => holder.hasDesc); this.hasIcon = this.children.some(holder => holder.hasIcon); if (this.hasLeaf) { this.elt.addClass('as-has-leaf'); } else { this.elt.removeClass('as-has-leaf'); } if (this.hasNoSelect) { this.elt.addClass('as-has-no-select'); this.elt.$chekAll.disabled = true; } else { this.elt.removeClass('as-has-no-select'); this.elt.$chekAll.disabled = false; } this.dict = this.children.reduce(function visit(ac, child) { var key = (0,utils.keyStringOf)(child.data.value); if (ac[key]) { console.error('Duplicate value:', ac[key].data, child.data) } ac[key] = child; if (child.children) { child.children.reduce(visit, ac); } return ac; }, {}); } CTBModeNormal.prototype.onStart = function () { this.$list.clearChild(); var rootHolders = this.children; var viewElements = []; rootHolders.forEach(holder => { holder.getViewElements(viewElements) }, []); this.$list.addChild(viewElements); }; CTBModeNormal.prototype.onStop = function () { }; CTBModeNormal.prototype.updateUp = function () { var selected = { child: 0, all: 0, none: 0, /*dont: 0*/ }; var childN = this.children.length; this.children.reduce((ac, child) => { ac[child.selected]++; return ac; }, selected); if (childN === selected.all) { this.selected = 'all'; } else if (childN === selected.none) { this.selected = "none"; } else { this.selected = 'child'; } this.elt.$chekAll.checked = this.selected === 'all'; }; CTBModeNormal.prototype.select = function (flag) { this.children.forEach(child => child.select(flag, true)); this.updateUp(); }; CTBModeNormal.prototype.getHolderByValue = function (value) { return this.dict[(0,utils.keyStringOf)(value)] || null; }; CTBModeNormal.prototype.setValues = function (values) { this.children.forEach(node => node.select(false)); values.forEach((value) => { var holder = this.getHolderByValue(value); if (holder) holder.select(true); }); }; CTBModeNormal.prototype.getValues = function () { var values = []; var leafOnly = this.elt.leafOnly; this.children.forEach(function visit(node) { if (node.selected === 'all' && !node.hasNoSelect) { if (leafOnly) { if (node.data.isLeaf) { values.push(node.data.value); } else if (node.data.items) { node.data.items.forEach(function visitLeaf(item) { if (item.isLeaf) { values.push(item.value); } else if (item.items) { item.items.forEach(visitLeaf); } }); } } else { values.push(node.data.value); } } else if (node.children) { node.children.forEach(visit); } }); return values; }; CTBModeNormal.prototype.getViewValues = function () { var values = []; this.children.forEach(function visit(node) { if (node.selected === 'all' && !node.hasNoSelect) { values.push(node.data.value); } else if (node.children) { node.children.forEach(visit); } }); return values; }; /*** * * @param {MCheckTreeBox} elt * @param {[]} items * @constructor */ function CTBModeSearch(elt, items) { this.level = -1; this.selected = 'none'; this.elt = elt; this.$list = this.elt.$list; this.children = items.map(item => new this.elt.classes.ItemHolder(elt, this, item)); } CTBModeSearch.prototype.onStart = function () { CTBModeNormal.prototype.onStart.call(this); this.updateSelectedFromRef(); }; CTBModeSearch.prototype.onStop = function () { }; CTBModeSearch.prototype.updateSelectedFromRef = function () { var normalMode = this.elt.modes.normal; this.children.forEach(function visit(holder) { holder.selected = holder.ref.selected; if (holder._elt) { holder._elt.selected = holder.selected; } if (holder.children) holder.children.forEach(visit); }); }; // EXTERNAL MODULE: ./node_modules/absol-acomp/js/list/ListDictionary.js var ListDictionary = __webpack_require__(103); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreebox/MCheckTreeBox.js /*** * not optimize * @param {MCheckTreeBox} elt * @constructor */ function MCTBItemListController(elt) { this.elt = elt; this.items = []; ListDictionary/* default.call */.Z.call(this, this.items, { depth: true }); } OOP/* default.mixClass */.ZP.mixClass(MCTBItemListController, ListDictionary/* default */.Z); MCTBItemListController.prototype.setItems = function (items) { items = items || []; if (!items.forEach || !items.map) items = []; this.items = (0,utils.copySelectionItemArray)(items, { removeNoView: true }); this.arr = this.items; this.update(); }; MCTBItemListController.prototype.update = function () { ListDictionary/* default.prototype.update.call */.Z.prototype.update.call(this); var mode = new this.elt.classes.ModeNormal(this.elt, this.items); this.elt.modes.normal = mode; if (mode.hasDesc) { this.elt.$list.addClass('as-has-desc'); } else { this.elt.$list.removeClass('as-has-desc'); } if (mode.hasIcon) { this.elt.$list.addClass('as-has-icon'); } else { this.elt.$list.removeClass('as-has-icon'); } this.elt.mode = mode; mode.onStart(); this._searchItems = (0,search/* prepareSearchForList */.Lb)((0,utils.copySelectionItemArray)(this.items)); this._searchCache = {}; }; MCTBItemListController.prototype.getItems = function () { return (0,utils.copySelectionItemArray)(this.items||[]); }; MCTBItemListController.prototype.makeSearch = function (query) { if (this._searchCache[query]) return this._searchCache[query].resetAndGet(); var searchItem = (0,search/* default */.ZP)({ text: query }); var minScore = Infinity; var maxScore = -Infinity; var scoredHolders = this._searchItems.map(function visit(item) { var holder = { item: item, score: (0,search/* calcItemMatchScore */.lk)(searchItem, item), childMaxScore: -Infinity }; minScore = Math.min(minScore, holder.score); maxScore = Math.max(maxScore, holder.score); if (item.items && item.items.length > 0) { holder.children = item.items.map(visit); holder.childMaxScore = holder.children.reduce((ac, cr) => { return Math.max(ac, cr.score, cr.childMaxScore); }, 0) } return holder; }); var threshHold = maxScore - (maxScore - minScore) / 3; var result = scoredHolders.reduce(function filterVisit(ac, cr) { var subItems; if (Math.max(cr.score, cr.childMaxScore) >= threshHold) { ac.items.push(cr.item); if (cr.children && cr.childMaxScore >= cr.score) { ac.status[(0,utils.keyStringOf)(cr.item.value)] = 'open'; subItems = cr.children.reduce(filterVisit, { items: [], status: ac.status }).items; cr.item.items = subItems; } else { if (cr.children && cr.children.length > 0) { ac.status[(0,utils.keyStringOf)(cr.item.value)] = 'open'; } } } return ac; }, { items: [], status: {} }); var normalMode = this.elt.modes.normal; result.mode = new this.elt.classes.ModeSearch(this.elt, result.items); result.resetAndGet = function () { this.mode.children && this.mode.children.forEach(function resetVisit(holder) { var key = (0,utils.keyStringOf)(holder.data.value); holder.ref = normalMode.getHolderByValue(holder.data.value); if (holder.status === 'open' && result.status[key] !== 'open') { holder.status = 'close'; if (holder._elt) { holder._elt.status = 'close'; } } else if (holder.status === 'close' && result.status[key] === 'open') { holder.status = 'open'; if (holder._elt) { holder._elt.status = 'open'; } } if (holder.children) holder.children.forEach(resetVisit); }); return this.mode; }; this._searchCache[query] = result; return result.resetAndGet(); }; /*** * @extends AElement * @constructor */ function MCheckTreeItem() { this._data = null; this._status = 'none'; this.$text = (0,ACore.$)('.am-check-tree-item-text', this).firstChild; this.$desc = (0,ACore.$)('.am-check-tree-item-desc', this).firstChild; this.$iconCtn = (0,ACore.$)('.am-check-tree-item-icon-ctn', this); this.$checkbox = (0,ACore.$)('checkboxinput', this) .on('change', this.eventHandler.checkboxChange); this.addEventListener('click', this.eventHandler.click); } MCheckTreeItem.tag = 'MCheckTreeItem'.toLowerCase(); MCheckTreeItem.render = function () { return (0,ACore._)({ extendEvent: ['checkedchange', 'click', 'statuschange'], class: ['am-check-tree-item', 'am-dropdown-box-item'], child: [ { class: 'am-check-tree-item-toggle-ctn', child: 'toggler-ico' }, { class: 'am-check-tree-item-icon-ctn' }, { class: 'am-check-tree-item-checkbox-ctn', child: 'checkboxinput' }, { class: 'am-check-tree-item-text', child: { text: '' } }, { class: 'am-check-tree-item-desc', child: { text: '' } } ] }); }; MCheckTreeItem.prototype._updateData = function () { this.$text.data = this.text; this.$desc.data = this.desc; this.$iconCtn.clearChild(); this.$icon = null; this.attr('data-key', (0,utils.keyStringOf)(this.value)) if (this._data && this._data.icon) { this.$icon = (0,ACore._)(this._data.icon); if (this.$icon.parentElement) { this.$icon = this.$icon.cloneNode(true); } this.$iconCtn.addChild(this.$icon); this.addClass('as-has-icon'); } else { this.removeClass('as-has-icon'); } if (this._data && this._data.isLeaf) { this.addClass('as-is-leaf'); } else { this.removeClass('as-is-leaf'); } }; MCheckTreeItem.eventHandler = {}; MCheckTreeItem.eventHandler.click = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$checkbox, event)) return; var checkboxBound = this.$checkbox.getBoundingClientRect(); var canCheck = this.$checkbox.getComputedStyleValue('pointer-events') !== 'none' && !this.$checkbox.disabled && checkboxBound.width > 0; if (this.status === 'none' && canCheck) { this.$checkbox.checked = !this.$checkbox.checked; this.$checkbox.notifyChange(); } else if (this.status !== 'none') { if (!checkboxBound.width) { checkboxBound = this.$iconCtn.getBoundingClientRect(); } if (!checkboxBound.width) { checkboxBound = { left: this.getBoundingClientRect().left + parseFloat(this.$text.parentElement.getComputedStyleValue('padding-left').replace('px')) }; } if (event.clientX < checkboxBound.left || !canCheck) { this.status = this.status === 'open' ? 'close' : 'open'; this.emit('statuschange', { type: 'statuschange', target: this }, this); } else if (canCheck) { this.$checkbox.checked = !this.$checkbox.checked; this.$checkbox.notifyChange(); } } }; MCheckTreeItem.eventHandler.checkboxChange = function () { this.emit('checkedchange', { type: 'checkedchange' }, this); }; MCheckTreeItem.property = checktreebox_CTIPropHandlers; /*** * @name data * @memberOf MCheckTreeItem# */ /*** * @name text * @type {string} * @memberOf MCheckTreeItem# */ /*** * @name desc * @type {string} * @memberOf MCheckTreeItem# */ /*** * @name value * @memberOf MCheckTreeItem# */ /*** * @extends AElement * @constructor */ function MCheckTreeBox() { this.$box = (0,ACore.$)('.am-check-tree-box', this); this.$body = (0,ACore.$)('.am-check-tree-box-body', this); this.$list = (0,ACore.$)('.am-check-tree-box-list', this); this.$chekAll = (0,ACore.$)('.as-select-list-box-check-all', this) .on('change', function () { this.modes.normal.select(this.$chekAll.checked); if (this.mode.updateSelectedFromRef) this.mode.updateSelectedFromRef(); this.notifyChange(); }.bind(this)); this.$searchInput = (0,ACore.$)(Searcher/* default.tag */.Z.tag, this).on('stoptyping', this.eventHandler.searchTextInputModify); this.$cancelBtn = (0,ACore.$)('.as-select-list-box-cancel-btn', this) .on('click', function () { this.emit('cancel', { type: 'cancel', target: this }, this); }.bind(this)); this.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this); this.$boxCloseBtn = (0,ACore.$)('.am-dropdown-box-close-btn', this); this.on('click', function (event) { if (event.target === this || (0,EventEmitter/* hitElement */.EY)(this.$closeBtn, event) || (0,EventEmitter/* hitElement */.EY)(this.$boxCloseBtn, event)) { this.emit('close', { type: 'close', target: this }, this); } }.bind(this)); this.pendingValues = null; this.modes = { normal: new this.classes.ModeNormal(this, []) }; /*** * * @type {CTBModeNormal | CTBModeSearch} */ this.mode = this.modes.normal; this.itemListCtrl = new this.classes.ListController(this); } MCheckTreeBox.prototype.classes = { ListController: MCTBItemListController, ModeSearch: CTBModeSearch, ModeNormal: CTBModeNormal, ItemHolder: MCTBItemHolder, ItemElement: MCheckTreeItem }; MCheckTreeBox.tag = 'MCheckTreeBox'.toLowerCase(); MCheckTreeBox.render = function () { return (0,ACore._)({ extendEvent: ['change', 'close', 'cancel'], class: ['am-modal', 'am-dropdown-box-modal'], child: { class: ['am-check-tree-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: ['am-dropdown-box-body', 'am-check-tree-box-body'], child: { class: 'am-check-tree-box-list', } }, { class: 'as-dropdown-box-footer', child: [ { tag: 'checkbox', class: 'as-select-list-box-check-all', props: { checked: false, text: LanguageSystem/* default.getText */.ZP.getText('txt_check_all') || LanguageSystem/* default.getText */.ZP.getText('txt_all') || 'Check All' } }, { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-cancel-btn', attr: { "data-ml-key": 'txt_cancel' } }, { tag: 'a', class: 'as-select-list-box-close-btn', attr: { "data-ml-key": 'txt_close' } }] } ] } ] } }); }; MCheckTreeBox.prototype.getHolderByValue = function (value) { return this.modes.normal.getHolderByValue(value); }; MCheckTreeBox.prototype.select = function (value, flag) { var holder = this.modes.normal.getHolderByValue(value); if (holder) { holder.select(flag); if (this.mode !== this.modes.normal) { this.mode.updateSelectedFromRef(); } return true; } return false; }; MCheckTreeBox.prototype.getItemByValue = function (value) { var holder = this.modes.normal.getHolderByValue(value); if (holder) return holder.data; return null; }; MCheckTreeBox.prototype.focus = function () { if (this.enableSearch) { this.$searchInput.focus(); } }; MCheckTreeBox.prototype.resetSearchState = function () { this.$searchInput.value = ''; this.eventHandler.searchTextInputModify(); }; MCheckTreeBox.prototype.notifyChange = function () { this.pendingValues = null; this.emit('change', { type: 'change', target: this }, this); }; /*** * @name eventHandler * @type {{}} * @memberOf MCheckTreeBox# */ MCheckTreeBox.eventHandler = {}; MCheckTreeBox.eventHandler.searchTextInputModify = function () { var query = this.$searchInput.value.trim().replace(/\s+/g, ' '); if (query.length > 0) { if (this.mode === this.modes.normal) { this.mode.onStop(); } this.mode.search = this.itemListCtrl.makeSearch(query); this.mode = this.mode.search; this.mode.onStart(); } else { if (this.mode !== this.modes.normal) { this.mode.onStop(); this.mode = this.modes.normal; this.mode.onStart(); } } }; MCheckTreeBox.property = checktreebox_CTBPropHandlers; /* harmony default export */ const checktreebox_MCheckTreeBox = (MCheckTreeBox); /*********************************** ADAPT OLD VERSION ***************************************************************/ MCheckTreeBox.prototype.findItemHoldersByValue = function (value) { var holder = this.getHolderByValue(value); if (holder) { return [holder]; } else { return []; } }; /*** * * @param {MCheckTreeBox} boxElt * @param {MCTBItemHolder|CTBModeNormal|CTBModeSearch}parent * @param data * @constructor */ function MCTBItemHolder(boxElt, parent, data) { this.ref = null; this.boxElt = boxElt; this.$list = this.boxElt.$list; this.data = data; this.parent = parent; this.level = parent ? parent.level + 1 : 0; this._elt = null; this.children = null; this.hasIcon = !!data.icon; this.hasDesc = !!data.desc; this.status = 'none'; this.selected = 'none'; this.hasLeaf = data.isLeaf; this.noSelect = data.noSelect; this.hasNoSelect = this.noSelect; if (data.items && data.items.map && data.items.length > 0) { this.children = data.items.map(it => new MCTBItemHolder(boxElt, this, it)); this.hasIcon = this.hasIcon || this.children.some(child => child.hasIcon); this.hasDesc = this.hasDesc || this.children.some(child => child.hasDesc); this.hasLeaf = this.hasLeaf || this.children.some(child => child.hasLeaf); this.hasNoSelect = this.hasNoSelect || this.children.some(child => child.hasNoSelect); this.status = 'close'; } } MCTBItemHolder.prototype.getViewElements = function (ac) { ac = ac || []; ac.push(this.elt); if (this.status === 'open' && this.children) { this.children.forEach(child => child.getViewElements(ac)); } return ac; }; Object.defineProperty(MCTBItemHolder.prototype, 'elt', { get: function () { if (!this._elt) { this._elt = (0,ACore._)({ tag: this.boxElt.classes.ItemElement, props: { data: this.data, level: this.level, status: this.status, selected: this.selected, hasLeaf: this.hasLeaf, noSelect: this.hasNoSelect }, on: { checkedchange: this.ev_checkedChange.bind(this), statuschange: this.ev_statusChange.bind(this), } }); } return this._elt; } }); MCTBItemHolder.prototype.ev_checkedChange = function () { var selected = this._elt.selected; if (this.ref) { if (selected === 'all') { this.ref.select(true); } else { this.ref.select(false); } this.getRoot().updateSelectedFromRef(); } else { if (selected === 'all') { this.select(true); } else { this.select(false); } } this.boxElt.notifyChange(); }; MCTBItemHolder.prototype.ev_statusChange = function () { if (this._elt.status === this.status) return; var viewElements; if (this.status === 'open') { viewElements = this.getViewElements(); viewElements.shift(); viewElements.forEach((elt) => { elt.remove(); }); this.status = this._elt.status; } else if (this.status === 'close') { this.status = this._elt.status; viewElements = this.getViewElements(); viewElements.shift(); (0,utils.addElementAfter)(this.$list, viewElements, this._elt); } }; MCTBItemHolder.prototype.updateUp = function () { var selected = { child: 0, all: 0, none: 0, /*dont: 0*/ }; var childN = this.children.length; this.children.reduce((ac, child) => { ac[child.selected]++; return ac; }, selected); if (childN === selected.all) { this.selected = 'all'; } else if (childN === selected.none) { this.selected = "none"; } else { this.selected = 'child'; } if (this._elt) { this._elt.selected = this.selected; } if (this.parent) this.parent.updateUp(); } MCTBItemHolder.prototype.select = function (flag, isDownUpdate) { var leafOnly = this.boxElt.leafOnly; if (flag && ((leafOnly && !this.hasLeaf))) return; var selected = { child: 0, all: 0, none: 0, exclude: 0/*dont: 0*/ }; var childN = 0; if (this.children && this.children.length > 0) { childN = this.children.length; this.children.reduce((ac, child) => { child.select(flag, true); if (leafOnly && !child.hasLeaf) { ac.exclude++; } else { ac[child.selected]++; } return ac; }, selected); if (leafOnly) { if (this.hasLeaf) { if (childN === selected.all + selected.exclude) { this.selected = 'all'; } else if (selected.all + selected.child > 0) { this.selected = 'child'; } else { this.selected = 'none'; } } else { this.selected = "none"; } } else { if (childN === selected.all) { this.selected = 'all'; } else if (childN === selected.none) { this.selected = "none"; } else { this.selected = 'child'; } } } else { if (flag && (!leafOnly ||this.hasLeaf)) { this.selected = 'all'; } else { this.selected = 'none'; } } if (this._elt) { this._elt.selected = this.selected; } if (!isDownUpdate && this.parent) { this.parent.updateUp(); } }; MCTBItemHolder.prototype.getRoot = function () { var c = this; while (c.parent) { c = c.parent; } return c; } /*********************************** ADAPT OLD VERSION ***************************************************************/ Object.defineProperty(MCTBItemHolder.prototype, 'item', { get: function (){ return this.data; } }); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/MSTBItemHolder.js function MSTBItemHolder(boxElt, parent, data) { this.ref = null; this.$list = boxElt.$list; this.level = parent.level + 1; this.status = 'none'; this.boxElt = boxElt; this.parent = parent; this.data = data; this._elt = null; this.hasDesc = !!data.desc; this.hasIcon = !!data.icon; this.selected = false; if (data.items && data.items.length > 0) { this.children = data.items.map(item => new MSTBItemHolder(boxElt, this, item)); this.hasDesc = this.hasDesc || this.children.some(child => child.hasDesc); this.hasIcon = this.hasIcon || this.children.some(child => child.hasIcon); this.status = 'close'; } } MSTBItemHolder.prototype.ev_statusChange = MCTBItemHolder.prototype.ev_statusChange; MSTBItemHolder.prototype.getViewElements = MCTBItemHolder.prototype.getViewElements; MSTBItemHolder.prototype.select = function (flag) { this.selected = flag; if (this._elt) { this._elt.selected = flag; } }; MSTBItemHolder.prototype.ev_click = function (event) { if (this.ref) { this.ref.ev_click(event); } else { this.boxElt.modes.normal.setValue(this.data.value); if (this.boxElt.mode !== this.boxElt.modes.normal) { this.boxElt.mode.updateSelectedFromRef(); } this.boxElt.notifyPressItem({ item: this.data }); } }; Object.defineProperty(MSTBItemHolder.prototype, 'elt', { get: function () { if (!this._elt) { this._elt = (0,ACore._)({ tag: selecttreeleafbox_SelectTreeLeafItem, props: { data: this.data, level: this.level, status: this.status, selected: this.selected }, on: { statuschange: this.ev_statusChange.bind(this), click: this.ev_click.bind(this) } }); } return this._elt; } }); /* harmony default export */ const selecttreeleafbox_MSTBItemHolder = (MSTBItemHolder); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/STLBModes.js function STLBModeNormal(elt, items) { this.level = -1; this.elt = elt; this.$list = elt.$list; this.children = items.map(item => new selecttreeleafbox_MSTBItemHolder(elt, this, item)); this.hasDesc = this.hasDesc || this.children.some(child => child.hasDesc); this.hasIcon = this.hasIcon || this.children.some(child => child.hasIcon); this.dict = this.children.reduce(function visit(ac, child) { var key = (0,utils.keyStringOf)(child.data.value); if (ac[key]) { console.error('Duplicate value:', ac[key].data, child.data) } ac[key] = child; if (child.children) { child.children.reduce(visit, ac); } return ac; }, {}); this.selectedHolder = null; } STLBModeNormal.prototype.getHolderByValue = CTBModeNormal.prototype.getHolderByValue; STLBModeNormal.prototype.getItemByValue = function (value) { var holder = this.getHolderByValue(value); if (holder) return holder.data; return null; }; STLBModeNormal.prototype.getFirstLeafHolder = function () { var res = null; if (this.children) { this.children.some(function visit(node) { if (node.data.isLeaf) { res = node; return true; } if (node.children) { return node.children.some(visit) } return false; }); } return res; }; STLBModeNormal.prototype.onStart = function () { this.$list.clearChild(); var rootHolders = this.children; var viewElements = []; rootHolders.forEach(holder => { holder.getViewElements(viewElements) }, []); this.$list.addChild(viewElements); }; STLBModeNormal.prototype.setValue = function (value, strict) { var holder = this.selectedHolder; if (holder) { holder.select(false); } holder = this.getHolderByValue(value); if (holder && !holder.data.isLeaf) holder = null; if (!holder && strict) { holder = this.getFirstLeafHolder(); } if (holder && holder.data.isLeaf) { holder.select(true); } this.selectedHolder = holder; }; STLBModeNormal.prototype.getValue = function (strict) { var holder = this.selectedHolder; if (strict && !holder) holder = this.getFirstLeafHolder(); if (holder) { return holder.data.value; } else { throw new Error('Not selected!'); } }; STLBModeNormal.prototype.viewToSelected = function () { if (!this.selectedHolder) return; var visitUp = (node) => { var parent = node.parent; if (parent !== this) { visitUp(parent); } if (node.status === 'close') { node.elt.status = 'open'; node.ev_statusChange(); } } visitUp(this.selectedHolder); (0,utils.vScrollIntoView)(this.selectedHolder.elt); }; STLBModeNormal.prototype.onStop = function () { }; function STLBModeSearch(elt, items) { this.level = -1; this.elt = elt; this.$list = this.elt.$list; this.children = items.map(item => new selecttreeleafbox_MSTBItemHolder(elt, this, item)); this.dict = this.children.reduce(function visit(ac, child) { var key = (0,utils.keyStringOf)(child.data.value); if (ac[key]) { console.error('Duplicate value:', ac[key].data, child.data) } ac[key] = child; if (child.children) { child.children.reduce(visit, ac); } return ac; }, {}); this.selectedHolder = null; } STLBModeSearch.prototype.updateSelectedFromRef = function () { if (this.selectedHolder) this.selectedHolder.select(false); this.selectedHolder = null; var value = this.elt.value; var holder = this.dict[(0,utils.keyStringOf)(value)]; if (holder) { holder.select(true); this.selectedHolder = holder; } }; STLBModeSearch.prototype.onStart = function () { STLBModeNormal.prototype.onStart.call(this); this.updateSelectedFromRef(); }; STLBModeSearch.prototype.onStop = function () { }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/MSTLBItemListController.js function MSTLBItemListController(elt) { this.elt = elt; this.items = []; this._searchCache = {}; } MSTLBItemListController.prototype.setItems = function (items) { if (!items || !items.forEach || !items.map) items = []; this.items = (0,utils.copySelectionItemArray)(items, { removeNoView: true }); this.update(); }; MSTLBItemListController.prototype.update = function () { var mode = new STLBModeNormal(this.elt, this.items); this.elt.modes.normal = mode; this.elt.mode = mode; if (mode.hasDesc) { this.elt.$list.addClass('as-has-desc'); } else { this.elt.$list.removeClass('as-has-list'); } if (mode.hasIcon) { this.elt.$list.addClass('as-has-icon'); } else { this.elt.$list.removeClass('as-has-icon'); } this.elt.mode = mode; mode.onStart(); this._searchItems = (0,search/* prepareSearchForList */.Lb)((0,utils.copySelectionItemArray)(this.items)); this._searchCache = {}; }; MSTLBItemListController.prototype.getItems = function () { return (0,utils.copySelectionItemArray)(this.items); }; MSTLBItemListController.prototype.makeSearch = function (query) { if (this._searchCache[query]) return this._searchCache[query].resetAndGet(); var searchItem = (0,search/* default */.ZP)({ text: query }); var minScore = Infinity; var maxScore = -Infinity; var scoredHolders = this._searchItems.map(function visit(item) { var holder = { item: item, score: (0,search/* calcItemMatchScore */.lk)(searchItem, item), childMaxScore: -Infinity }; minScore = Math.min(minScore, holder.score); maxScore = Math.max(maxScore, holder.score); if (item.items && item.items.length > 0) { holder.children = item.items.map(visit); holder.childMaxScore = holder.children.reduce((ac, cr) => { return Math.max(ac, cr.score, cr.childMaxScore); }, 0) } return holder; }); var threshHold = maxScore - (maxScore - minScore) / 3; var result = scoredHolders.reduce(function filterVisit(ac, cr) { var subItems; if (Math.max(cr.score, cr.childMaxScore) >= threshHold) { ac.items.push(cr.item); if (cr.children && cr.childMaxScore >= cr.score) { ac.status[(0,utils.keyStringOf)(cr.item.value)] = 'open'; subItems = cr.children.reduce(filterVisit, { items: [], status: ac.status }).items; cr.item.items = subItems; } else { if (cr.children && cr.children.length > 0) { ac.status[(0,utils.keyStringOf)(cr.item.value)] = 'open'; } } } return ac; }, { items: [], status: {} }); var normalMode = this.elt.modes.normal; result.mode = new STLBModeSearch(this.elt, result.items); result.resetAndGet = function () { this.mode.children && this.mode.children.forEach(function resetVisit(holder) { var key = (0,utils.keyStringOf)(holder.data.value); holder.ref = normalMode.getHolderByValue(holder.data.value); if (holder.status === 'open' && result.status[key] !== 'open') { holder.status = 'close'; if (holder._elt) { holder._elt.status = 'close'; } } else if (holder.status === 'close' && result.status[key] === 'open') { holder.status = 'open'; if (holder._elt) { holder._elt.status = 'open'; } } if (holder.children) holder.children.forEach(resetVisit); }); return this.mode; }; this._searchCache[query] = result; return result.resetAndGet(); }; /* harmony default export */ const selecttreeleafbox_MSTLBItemListController = (MSTLBItemListController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/STLBPropsHandlers.js var STLBPropsHandlers = {}; STLBPropsHandlers.enableSearch = { set: function (value) { if (value) { this.$box.addClass('as-enable-search'); } else { this.$box.removeClass('as-enable-search'); } }, get: function () { return this.$box.hasClass('as-enable-search'); } }; /* harmony default export */ const selecttreeleafbox_STLBPropsHandlers = (STLBPropsHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafbox/MSelectTreeLeafBox.js /**** * @extends AElement * @constructor */ function MSelectTreeLeafBox() { this.estimateSize = { width: 0, height: 0 }; this.$box = (0,ACore.$)('.am-dropdown-box', this); this.$list = (0,ACore.$)('.am-select-tree-leaf-box-list', this); this.itemListCtrl = new selecttreeleafbox_MSTLBItemListController(this); this.$searchInput = (0,ACore.$)(Searcher/* default.tag */.Z.tag, this).on('stoptyping', this.eventHandler.searchTextInputModify); this.$boxCloseBtn = (0,ACore.$)('.am-dropdown-box-close-btn', this); this.on('click', function (event) { if (event.target === this || (0,EventEmitter/* hitElement */.EY)(this.$boxCloseBtn, event)) { this.emit('close', { type: 'close', target: this }, this); } }.bind(this)); this.modes = { normal: new STLBModeNormal(this, []), search: null }; this.mode = this.modes.normal; this.strictValue = true; /** * @name items * @memberof MSelectTreeLeafBox# * @type {Array} */ /** * @name value * @memberof MSelectTreeLeafBox# */ /** * @name strictMode * @type {boolean} * @memberof MSelectTreeLeafBox# */ /** * @name selectedItem * @memberof MSelectTreeLeafBox# */ } MSelectTreeLeafBox.tag = 'MSelectTreeLeafBox'.toString(); MSelectTreeLeafBox.render = function () { return (0,ACore._)({ extendEvent: ['pressitem', 'close'], class: ['am-modal', 'am-dropdown-box-modal'], child: { class: ['am-select-tree-leaf-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: ['am-dropdown-box-body', 'am-select-tree-leaf-box-body'], child: { class: 'am-select-tree-leaf-box-list' } } ] } }); }; MSelectTreeLeafBox.prototype._calcEstimateSize = js_SelectTreeLeafBox.prototype._calcEstimateSize; MSelectTreeLeafBox.prototype._estimateItemWidth = function (item, level) { var width = 12;//padding width += 12 * level; width += 14.7 + 5;//toggle icon // if (item.icon) width += 21;//icon width += 7 + (0,utils.estimateWidth14)(item.text) + 5 + 7;//margin-text if (item.desc) width += 6 + (0,utils.estimateWidth14)(item.desc) * 0.85; return width; }; MSelectTreeLeafBox.prototype._findFirstLeaf = js_SelectTreeLeafBox.prototype._findFirstLeaf; MSelectTreeLeafBox.prototype.viewToSelected = function () { this.modes.normal.viewToSelected(); }; MSelectTreeLeafBox.prototype.notifyPressItem = function (eventData) { delete this.pendingValue; this.emit('pressitem', Object.assign({ type: 'pressitem', target: this }, eventData), this); }; MSelectTreeLeafBox.prototype.getItemByValue = function (value) { return this.modes.normal.getItemByValue(value); }; MSelectTreeLeafBox.prototype.findItemByValue = function (value) { return this.modes.normal.getItemByValue(value); }; MSelectTreeLeafBox.prototype.resetSearchState = checktreebox_MCheckTreeBox.prototype.resetSearchState; MSelectTreeLeafBox.property = selecttreeleafbox_STLBPropsHandlers; MSelectTreeLeafBox.property.items = { set: function (items) { var curValue; var selected = true; if ('pendingValue' in this) { curValue = this.pendingValue; } else { try { curValue = this.modes.normal.getValue(this.strictValue); } catch (err) { selected = false; } } this.estimateSize = this._calcEstimateSize(items); this._items = items;//todo: check usage this.itemListCtrl.setItems(items); if (selected || this.strictValue) this.modes.normal.setValue(curValue, this.strictValue); if (this.mode !== this.modes.normal) { this.mode.updateSelectedFromRef(); } }, get: function () { return this.itemListCtrl.getItems(); } }; MSelectTreeLeafBox.property.value = { /*** * @this MSelectTreeLeafBox * @param value */ set: function (value) { this.pendingValue = value; this._value = value; this.modes.normal.setValue(this.pendingValue, this.strictValue); }, get: function () { if ('pendingValue' in this) { return this.pendingValue; } else { try { return this.modes.normal.getValue(this.strictValue); } catch (err) { return undefined; } } } }; MSelectTreeLeafBox.property.selectedItem = { get: function () { return this.modes.normal.getItemByValue(this.value); } }; MSelectTreeLeafBox.property.strictValue = { set: function (value) { if (value) { this.$box.addClass('as-strict-value'); } else { this.$box.removeClass('as-strict-value'); } this.modes.normal.setValue(this.pendingValue, this.strictValue); if (this.mode !== this.modes.normal) { this.mode.updateSelectedFromRef(); } }, get: function () { return this.$box.hasClass('as-strict-value'); } }; MSelectTreeLeafBox.eventHandler = {}; MSelectTreeLeafBox.eventHandler.searchTextInputModify = checktreebox_MCheckTreeBox.eventHandler.searchTextInputModify; ACore/* default.install */.Z.install(MSelectTreeLeafBox); /* harmony default export */ const selecttreeleafbox_MSelectTreeLeafBox = (MSelectTreeLeafBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectTreeLeafMenu.js /*** * @extends AElement * @constructor */ function SelectTreeLeafMenu_SelectTreeLeafMenu() { this.$selectBox = (0,ACore._)({ tag: this.mobile ? selecttreeleafbox_MSelectTreeLeafBox : js_SelectTreeLeafBox.tag, on: { pressitem: this.eventHandler.pressItem, preupdateposition: this.eventHandler.preUpdateListPosition, close: () => { this.isFocus = false; } } }); this.$selectBox.sponsorElement = this; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectBox, ['enableSearch', 'selectedItem']); this.$holderItem = (0,ACore.$)('selectlistitem', this); // this.on('click', this.eventHandler.click.bind(this)); this.boxCtrl = new STLBoxController(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.boxCtrl, 'isFocus'); /** * @name items * @type {Array} * @memberof SelectTreeLeafMenu# */ /** * @name value * @memberof SelectTreeLeafMenu# */ /** * @name mobile * @type {boolean} * @memberof SelectTreeLeafMenu# */ /** * @name disabled * @type {boolean} * @memberof SelectTreeLeafMenu# */ /** * @name readOnly * @type {boolean} * @memberof SelectTreeLeafMenu# */ /** * @name openValue * @memberof SelectTreeLeafMenu# * */ /** * @name nullValue * @memberof SelectTreeLeafMenu# * */ } SelectTreeLeafMenu_SelectTreeLeafMenu.tag = 'SelectTreeLeafMenu'.toLowerCase(); SelectTreeLeafMenu_SelectTreeLeafMenu.render = function () { var mobile = BrowserDetector/* default.isMobile */.Z.isMobile; return (0,ACore._)({ class: ['absol-selectmenu', 'as-select-menu', 'as-select-tree-leaf-menu', 'as-strict-value'], extendEvent: ['change'], props: { mobile: mobile }, attr: { tabindex: '1' }, child: [ { class: 'absol-selectmenu-holder-item', child: 'selectlistitem' }, { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] } ] }); }; SelectTreeLeafMenu_SelectTreeLeafMenu.prototype.findItemByValue = function (value) { return this.$selectBox.findItemByValue(value); }; SelectTreeLeafMenu_SelectTreeLeafMenu.prototype.init = function (props) { props = props || {}; Object.keys(props).forEach(function (key) { if (props[key] === undefined) delete props[key]; }); if (props.strictValue) { this.strictValue = props.strictValue; delete props.strictValue; } var hasValue = 'value' in props; var value = props.value; delete props.value; this.super(props); if (hasValue) this.value = value; }; SelectTreeLeafMenu_SelectTreeLeafMenu.property = {}; SelectTreeLeafMenu_SelectTreeLeafMenu.property.items = { set: function (items) { items = (0,utils.copySelectionItemArray)(items || [], { removeNoView: true }); this.$selectBox.items = items; if (!this.mobile) this.addStyle('--select-list-estimate-width', this.$selectBox.estimateSize.width + 'px'); var selectedItem = this.$selectBox.selectedItem; if (selectedItem) { this.$holderItem.data = selectedItem; if (this.mobile) { this.addStyle('--select-list-estimate-width', this.$selectBox._estimateItemWidth(selectedItem, 0) + 'px'); } } else { this.$holderItem.data = { text: '' }; } }, get: function () { return this.$selectBox.items; } }; SelectTreeLeafMenu_SelectTreeLeafMenu.property.value = { set: function (value) { this.$selectBox.value = value; var selectedItem = this.$selectBox.selectedItem; if (selectedItem) { this.$holderItem.data = selectedItem; if (this.mobile) { this.addStyle('--select-list-estimate-width', this.$selectBox._estimateItemWidth(selectedItem, 0) + 'px'); } } else { this.$holderItem.data = { text: '' }; } }, get: function () { return this.$selectBox.value; } }; SelectTreeLeafMenu_SelectTreeLeafMenu.property.strictValue = { set: function (value) { this.$selectBox.strictValue = !!value; if (value) this.addClass('as-strict-value'); else this.removeClass('as-strict-value'); }, get: function () { return this.hasClass('as-strict-value'); } }; SelectTreeLeafMenu_SelectTreeLeafMenu.property.disabled = SelectMenu2.property.disabled; SelectTreeLeafMenu_SelectTreeLeafMenu.eventHandler = {}; SelectTreeLeafMenu_SelectTreeLeafMenu.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$selectBox, event)) return; this.isFocus = false; }; SelectTreeLeafMenu_SelectTreeLeafMenu.eventHandler.click = function (event) { if (!this.disabled) this.isFocus = true; }; SelectTreeLeafMenu_SelectTreeLeafMenu.eventHandler.pressItem = function (event) { this.$selectBox.value = event.item.value; this.$holderItem.data = event.item; var prevValue = this._value; this._value = event.item.value; this.isFocus = false; if (prevValue !== this._value) { this.emit('change', { item: event, type: 'change', target: this, originalEvent: event.originalEvent || event.originalEvent || event }, this); } }; SelectTreeLeafMenu_SelectTreeLeafMenu.eventHandler.preUpdateListPosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$selectBox.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { this.isFocus = false; } }; ACore/* default.install */.Z.install(SelectTreeLeafMenu_SelectTreeLeafMenu); /* harmony default export */ const js_SelectTreeLeafMenu = (SelectTreeLeafMenu_SelectTreeLeafMenu); /** * * @param {SelectTreeLeafMenu} elt * @constructor */ function STLBoxController(elt) { this.elt = elt; this.ev_click = this.ev_click.bind(this); this.ev_clickOut = this.ev_clickOut.bind(this); this.elt.on('click', this.ev_click); } Object.defineProperty(STLBoxController.prototype, 'isFocus', { set: function (value) { value = !!value; if (this.elt.hasClass('as-focus') === value) return; if (value && (this.elt.disabled || this.elt.readOnly)) return; var bound; if (value) { this.elt.$selectBox.addTo(document.body); this.elt.addClass('as-focus'); this.elt.$selectBox.addStyle('visible', 'hidden'); this.elt.off('click', this.ev_click); if (this.elt.mobile) { } else { bound = this.elt.getBoundingClientRect(); this.elt.$selectBox.addStyle('min-width', bound.width + 'px'); this.elt.$selectBox.followTarget = this.elt; this.elt.$selectBox.updatePosition(); } setTimeout(function () { document.addEventListener('mousedown', this.ev_clickOut); this.elt.$selectBox.removeStyle('visibility'); this.elt.$selectBox.focus(); }.bind(this), 5); if (this.elt.$selectBox.viewToValue && (0,utils.keyStringOf)(this.elt.nullValue) === (0,utils.keyStringOf)(this.elt.$selectBox.value)) { this.elt.$selectBox.viewToValue(this.elt.openValue); } else this.elt.$selectBox.viewToSelected(); } else { this.elt.removeClass('as-focus'); this.elt.$selectBox.remove(); document.removeEventListener('mousedown', this.ev_clickOut); if (this.elt.mobile) { } else { this.elt.$selectBox.followTarget = null; } setTimeout(() => { this.elt.on('click', this.ev_click); }, 100); this.elt.$selectBox.resetSearchState(); } }, get: function () { return this.elt.hasClass('as-focus'); } }); STLBoxController.prototype.ev_click = function (event) { if (!this.elt.disabled && !this.elt.readOnly) this.isFocus = true; }; STLBoxController.prototype.ev_clickOut = function (event) { if (!(0,EventEmitter/* hitElement */.EY)(this.elt.$selectBox, event) || (event.target.attr && event.target.attr('class') && event.target.attr('class').indexOf('modal') >= 0)) { this.isFocus = false; } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiCheckTreeLeafBox.js function MultiCheckTreeLeafBox_isBranchStatus(status) { return status === 'open' || status === 'close'; } function MultiCheckTreeLeafBox_invertStatus(status) { return { open: 'close', close: 'open' }[status] || 'none'; } /*** * @extends Follower * @constructor */ function MultiCheckTreeLeafBox() { (0,MultiLanguageCSS/* loadLanguageModule */.q)(); this._initControl(); this._searchCache = {}; this._items = []; this._values = []; this.strictValue = true; this.$items = []; this.$itemByValue = {}; this.$dislayItems = this.$items; this.$dislayItemByValue = this.$itemByValue; this.$content = (0,ACore.$)('.as-select-tree-leaf-box-content', this); this._savedStatus = {}; this.estimateSize = { width: 0, height: 0 }; } MultiCheckTreeLeafBox.tag = 'MultiCheckTreeLeafBox'.toLowerCase(); MultiCheckTreeLeafBox.render = function () { return (0,ACore._)({ tag: Follower/* default */.Z, attr: { tabindex: 0 }, class: ['as-select-tree-leaf-box', 'as-select-list-box'], extendEvent: ['change'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller', 'as-select-tree-leaf-box-content'], child: [] }, 'attachhook.as-dom-signal' ], props: { anchor: [1, 6, 2, 5] } }); }; MultiCheckTreeLeafBox.prototype.focus = js_SelectListBox.prototype.focus; MultiCheckTreeLeafBox.prototype._initControl = function () { this.$searchInput = (0,ACore.$)('searchtextinput', this) .on('stoptyping', this.eventHandler.searchModify); }; MultiCheckTreeLeafBox.prototype.resetSearchState = function () { var value = this.$searchInput.value; if (value.length > 0) { this.$searchInput.value = ''; if (value.trim().length) { this.$content.clearChild(); this.$content.addChild(this.$items); this.$dislayItems = this.$items; this.$dislayItemByValue = this.$itemByValue; this._updateSelectedItems(); } } this.updatePosition(); }; MultiCheckTreeLeafBox.prototype._findFirstLeaf = function () { var found = false; function visit(item) { if (item.isLeaf) { found = item; return true; } if (item.items && item.items.length > 0) { item.items.some(visit); } return !!found; } this._items.some(visit); return found; }; MultiCheckTreeLeafBox.prototype._makeTree = function (item, dict, savedStatus) { var self = this; var status = 'none'; var isLeaf = item.isLeaf; if (item.items && item.items.length > 0) { status = 'close'; } if (MultiCheckTreeLeafBox_isBranchStatus(status) && MultiCheckTreeLeafBox_isBranchStatus(savedStatus[item.value])) { status = savedStatus[item.value]; } var treeElt = (0,ACore._)({ tag: ExpTree/* default.tag */.ZP.tag, class: 'as-select-tree-leaf-item', props: { name: item.text, desc: item.desc, icon: item.icon, status: status, itemData: item }, on: { 'statuschange': this.updatePosition.bind(this) } }); var nodeElt = treeElt.getNode().on({ press: function (event) { if (MultiCheckTreeLeafBox_isBranchStatus(treeElt.status)) { treeElt.status = MultiCheckTreeLeafBox_invertStatus(treeElt.status) savedStatus[item.value] = treeElt.status; self.updatePosition(); } else if (isLeaf) { if (!(0,EventEmitter/* hitElement */.EY)(checkboxElt, event)) { var checked = !checkboxElt.checked; checkboxElt.checked = checked; var idx = self._values.indexOf(item.value); var changed = false; if (checked && idx < 0) { changed = true; self._values.push(item.value); } else if (!checked && idx >= 0) { changed = true; self._values.splice(idx, 1); } if (changed) self.emit('change', { item: item, target: self, itemElt: treeElt, originalEvent: event }, self); } } } }); var checkboxElt = null; if (isLeaf) { checkboxElt = (0,ACore._)({ tag: CheckBoxInput/* default.tag */.Z.tag, on: { change: function (event) { var checked = checkboxElt.checked; var idx = self._values.indexOf(item.value); var changed = false; if (checked && idx < 0) { changed = true; self._values.push(item.value); } else if (!checked && idx >= 0) { changed = true; self._values.splice(idx, 1); } if (changed) self.emit('change', { item: item, target: self, itemElt: treeElt, originalEvent: event }, self); } } }); nodeElt.addChildAfter(checkboxElt, nodeElt.$toggleIcon); treeElt.$checkbox = checkboxElt; } if (dict) { if (dict[item.value] && !this.warned) { this.warned = true; console.warn(this, 'has duplicated value, element will not work correctly!', item); } dict[item.value] = treeElt; } if (isLeaf) { treeElt.addClass('as-is-leaf'); } if (item.items && item.items.length > 0) { item.items.forEach(function (item1) { treeElt.addChild(self._makeTree(item1, dict, savedStatus)); }); } return treeElt; }; MultiCheckTreeLeafBox.prototype._estimateItemWidth = function (item, level) { var width = 12;//padding width += 12 * level; width += 14.7 + 5;//toggle icon if (item.icon) width += 21;//icon width += 7 + (0,utils.estimateWidth14)(item.text) + 5 + 7;//margin-text if (item.desc) width += 6 + (0,utils.estimateWidth14)(item.desc) * 0.85; if (item.isLeaf) width += 16; return width; }; MultiCheckTreeLeafBox.prototype.viewToSelected = function () { var selectedNode = this.$selectedItem; if (!selectedNode) return; selectedNode.scrollIntoView(); var parent = selectedNode.getParent(); while (parent && parent.getParent) { if (parent.status === 'close') { parent.getNode().emit('press'); } parent = parent.getParent(); } }; MultiCheckTreeLeafBox.prototype._calcEstimateSize = function (items) { var self = this; var width = 0; var height = 0; function visit(item, level) { var itemWidth = self._estimateItemWidth(item, level); width = Math.max(width, itemWidth); height += 28; if (item.items && item.items.length) { item.items.forEach(function (item) { visit(item, level + 1); }); } } items.forEach(function (item) { visit(item, 0); }); return { width: width, height: height }; }; MultiCheckTreeLeafBox.prototype._updateSelectedItems = function () { var dict = this._values.reduce(function (ac, cr) { ac[cr] = true; return ac; }, {}); var itemElt; for (var val in this.$dislayItemByValue) { itemElt = this.$dislayItemByValue[val]; if (itemElt.$checkbox) { itemElt.$checkbox.checked = !!dict[itemElt.itemData.value]; } } }; MultiCheckTreeLeafBox.prototype.findItemByValue = function (value) { var itemElt = this.$itemByValue[value]; if (!itemElt) return null; return itemElt.itemData; }; MultiCheckTreeLeafBox.property = {}; MultiCheckTreeLeafBox.eventHandler = {}; MultiCheckTreeLeafBox.property.items = { /*** * @this MultiCheckTreeLeafBox * @param items */ set: function (items) { var self = this; this._savedStatus = {}; this._searchCache = {}; items = (0,utils.copySelectionItemArray)(items || [], { removeNoView: true }); this._items = items; (0,search/* prepareSearchForList */.Lb)(items); this.$content.clearChild(); this.$itemByValue = {}; this.$dislayItemByValue = this.$itemByValue; this.$items = items.map(function (item) { return self._makeTree(item, self.$itemByValue, self._savedStatus); }); this.$dislayItems = this.$items; this.$content.addChild(this.$items); this.estimateSize = this._calcEstimateSize(items); this.addStyle('--select-list-estimate-width', this.estimateSize.width + 'px'); this._updateSelectedItems(); this.updatePosition(); }, get: function () { return this._items; } }; MultiCheckTreeLeafBox.property.values = { set: function (values) { this._values.splice(0, this._values.length); values = values || []; var arr = this._values; values.reduce(function (ac, cr) { if (!ac[cr]) { ac[cr] = true; arr.push(cr); } return ac; }, {}); this._updateSelectedItems(); }, get: function () { return this._values; } }; MultiCheckTreeLeafBox.property.enableSearch = js_SelectListBox.property.enableSearch; MultiCheckTreeLeafBox.prototype._search = function (query) { var self = this; var queryItem = (0,search/* default */.ZP)({ text: query }); var minScore = Infinity; var maxScore = -Infinity; function makeScoreTree(item) { var holder = { item: item, score: (0,search/* calcItemMatchScore */.lk)(queryItem, item), childrenScore: 0, children: [] }; minScore = Math.min(minScore, holder.score); maxScore = Math.max(maxScore, holder.score); var children; if (item.items && item.items.length > 0) { children = item.items.map(makeScoreTree); holder.children = children; holder.childrenScore = holder.children.reduce(function (ac, cr) { return Math.max(ac, cr.score, cr.childrenScore); }, 0); } return holder; } var treeScores = this._items.map(makeScoreTree); var midScore = (maxScore + minScore) / 2; var savedStatus = {}; function filterTree(scoredTrees, ignore) { return scoredTrees.filter(function (holder) { return ignore || holder.score >= midScore || holder.childrenScore >= midScore; }).map(function makeTree(holder) { var item = Object.assign({}, holder.item); if (!ignore && holder.children && holder.children.length > 0) { if (holder.childrenScore >= midScore) { savedStatus[item.value] = 'open'; item.items = filterTree(holder.children, false); } else { savedStatus[item.value] = 'close'; item.items = filterTree(holder.children, true); } } return item; }); } var resultItems = filterTree(treeScores, false); var dict = {}; var $items = resultItems.map(function (item) { return self._makeTree(item, dict, savedStatus); }); return { $items: $items, items: resultItems, savedStatus: Object.assign({}, savedStatus), originSavedStatus: savedStatus, dict: dict }; } /*** * @this MultiCheckTreeLeafBox */ MultiCheckTreeLeafBox.eventHandler.searchModify = function () { var query = this.$searchInput.value.trim(); if (query.length === 0) { this.$content.clearChild().addChild(this.$items); this.$dislayItemByValue = this.$itemByValue; this.$dislayItems = this.$items; this._updateSelectedItems(); this.updatePosition(); return; } if (!this._searchCache[query]) { this._searchCache[query] = this._search(query); } var searchData = this._searchCache[query]; searchData.savedStatus = Object.assign(searchData.savedStatus, searchData.originSavedStatus); for (var val in searchData.dict) { if (MultiCheckTreeLeafBox_isBranchStatus(searchData.dict[val].status)) { if (searchData.savedStatus[val]) { searchData.dict[val].status = searchData.savedStatus[val] } } } this.$content.clearChild() .addChild(searchData.$items); this.$dislayItemByValue = searchData.dict; this.$dislayItems = searchData.$items; this._updateSelectedItems(); this.updatePosition(); }; ACore/* default.install */.Z.install(MultiCheckTreeLeafBox); /* harmony default export */ const js_MultiCheckTreeLeafBox = (MultiCheckTreeLeafBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiCheckTreeLeafMenu.js /**** * Only leafs have checkbox * @extends AElement * @constructor */ function MultiCheckTreeLeafMenu() { (0,MultiLanguageCSS/* loadLanguageModule */.q)(); this.$selectBox = (0,ACore._)({ tag: js_MultiCheckTreeLeafBox.tag, on: { change: this.eventHandler.selectBoxChange, preupdateposition: this.eventHandler.preUpdateListPosition } }); this.$selectlistBox = this.$selectBox; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$selectBox, 'enableSearch'); this.on('mousedown', this.eventHandler.click); this.$itemCtn = (0,ACore.$)('.as-multi-select-menu-item-ctn', this); this.boxCtrl = new STLBoxController(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.boxCtrl, 'isFocus'); } MultiCheckTreeLeafMenu.tag = 'MultiCheckTreeLeafMenu'.toLowerCase(); MultiCheckTreeLeafMenu.render = function () { return (0,ACore._)({ class: ['as-multi-select-menu', 'as-multi-check-tree-leaf-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { attr: { 'data-ml-key': 'txt_select_value' }, class: ['as-multi-select-menu-item-ctn', 'as-bscroller'] }, { tag: 'button', class: 'as-multi-select-menu-toggle-btn', child: 'dropdown-ico' }, 'attachhook' ] }); }; MultiCheckTreeLeafMenu.prototype._updateSelectedItems = function () { var values = this.$selectBox.values; while (this.$itemCtn.childNodes.length > values.length) { this.$itemCtn.removeChild(this.$itemCtn.lastChild); } while (this.$itemCtn.childNodes.length < values.length) { this.$itemCtn.addChild(this._makeItem()); } var item; for (var i = 0; i < values.length; ++i) { item = this.$selectBox.$itemByValue[values[i]] && this.$selectBox.$itemByValue[values[i]].itemData; if (item) { this.$itemCtn.childNodes[i].data = item; this.$itemCtn.childNodes[i].removeStyle('display', 'none'); } else { this.$itemCtn.childNodes[i].addStyle('display', 'none'); } } }; MultiCheckTreeLeafMenu.prototype._makeItem = function () { var itemElt = (0,ACore._)({ tag: js_SelectBoxItem.tag, }); itemElt.on('close', this.eventHandler.itemPressClose.bind(null, itemElt)); return itemElt; }; MultiCheckTreeLeafMenu.prototype.findItemByValue = function (value) { return this.$selectBox.findItemByValue(value); }; MultiCheckTreeLeafMenu.prototype.init = function (props) { props = props || {}; var cProps = Object.assign({}, props); if ('items' in props) { this.items = props.items; delete cProps.items; } if ('values' in props) { this.values = props.values; delete cProps.values; } Object.assign(this, cProps); }; MultiCheckTreeLeafMenu.property = {}; MultiCheckTreeLeafMenu.property.items = { set: function (items) { this.$selectBox.items = items; this.addStyle('--select-list-estimate-width', Math.max(145 + 20, this.$selectBox.estimateSize.width) + 'px'); this._updateSelectedItems(); }, get: function () { return this.$selectBox.items; } }; MultiCheckTreeLeafMenu.property.values = { set: function (values) { values = values || []; this.pendingValues = values; this.$selectBox.values = values; this._updateSelectedItems(); }, get: function () { if ('pendingValues' in this) return this.pendingValues; return this.$selectBox.values.slice().filter(value => { return !!this.$selectBox.$itemByValue[value]; }); } }; MultiCheckTreeLeafMenu.property.disabled = js_MultiSelectMenu.property.disabled; MultiCheckTreeLeafMenu.property.readOnly = js_MultiSelectMenu.property.readOnly; MultiCheckTreeLeafMenu.property.placeholder = { set: function (value) { if (value) { this.$itemCtn.attr('data-placeholder', value + ''); } else { this.$itemCtn.attr('data-placeholder', null); } }, get: function () { return this.$itemCtn.attr('data-placeholder'); } }; MultiCheckTreeLeafMenu.eventHandler = {}; MultiCheckTreeLeafMenu.eventHandler.clickOut = js_SelectTreeLeafMenu.eventHandler.clickOut; MultiCheckTreeLeafMenu.eventHandler.preUpdateListPosition = SelectMenu2.eventHandler.preUpdateListPosition; MultiCheckTreeLeafMenu.eventHandler.click = function (event) { if (!this.readOnly && (event.target === this || event.target === this.$itemCtn)) { this.isFocus = true; } }; MultiCheckTreeLeafMenu.eventHandler.selectBoxChange = function () { delete this.pendingValues; this._updateSelectedItems(); this.emit('change', { type: 'change', target: this }, this); }; MultiCheckTreeLeafMenu.eventHandler.itemPressClose = function (itemElt, event) { delete this.pendingValues; var item = itemElt.data; this.$selectBox.values = this.$selectBox.values.filter(function (value) { return value !== item.value; }); this._updateSelectedItems(); this.emit('change', { type: 'change', target: this }, this); }; ACore/* default.install */.Z.install(MultiCheckTreeLeafMenu); /* harmony default export */ const js_MultiCheckTreeLeafMenu = (MultiCheckTreeLeafMenu); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/filelistinput.css var filelistinput = __webpack_require__(7288); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FileListItem.js /*** * @extends AElement * @constructor */ function FileListItem() { this.$parent = null; this.$icon = (0,ACore.$)('.as-file-list-item-icon', this); this.$name = (0,ACore.$)('.as-file-list-item-name', this); this.$quickMenuBtn = (0,ACore.$)('.as-file-list-item-quick-btn', this); this.$check = (0,ACore.$)('.as-file-list-item-check', this); this.value = null; this.fileType = null; this.fileName = ''; OOP/* default.drillProperty */.ZP.drillProperty(this, this.$check, 'checked'); this.on('click', this.eventHandler.click); QuickMenu/* default.toggleWhenClick */.Z.toggleWhenClick(this.$quickMenuBtn, { getMenuProps: () => { var list = this.parentElement; if (list.disabled) return; var self = this; var itemElt = this var menuItems = []; menuItems.push({ text: LanguageSystem/* default.getText */.ZP.getText('txt_download') || "Download", icon: 'span.mdi.mdi-download', cmd: 'download' }); if (!list.readOnly) { if (itemElt) menuItems.push({ text: LanguageSystem/* default.getText */.ZP.getText('txt_delete') || "Delete", icon: 'span.mdi.mdi-delete', cmd: 'delete' }); menuItems.push( { text: LanguageSystem/* default.getText */.ZP.getText('txt_delete_all') || "Delete All", icon: 'span.mdi.mdi-delete-empty', cmd: 'delete_all' }); } return { items: menuItems }; }, onSelect: function (menuItem) { var itemElt = this; var self = this.parentElement; var files; switch (menuItem.cmd) { case 'download': self.downloadFileItemElt(itemElt); break; case 'delete': self.deleteFileItemElt(itemElt); self.emit('change', { type: 'change', item: itemElt.fileData, target: this, action: 'delete' }, this); break; case 'delete_all': files = self.files; self.files = []; self.emit('change', { type: 'change', items: files, target: this, action: 'delete_all' }, this); break; } }.bind(this) }); this.$check.on('change', function (event) { if (this.$parent) { this.$parent.emit('check', { target: this.$parent, elt: this, type: 'check' }, this.$parent); } }.bind(this)); /*** * @name checked * @type {boolean} * @memberOf FileListItem# */ } FileListItem.tag = 'FileListItem'.toLowerCase(); FileListItem.render = function () { return (0,ACore._)({ class: 'as-file-list-item', child: [ { tag: CheckBoxInput/* default */.Z, class: 'as-file-list-item-check' }, { tag: 'img', class: 'as-file-list-item-icon', props: { src: MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + 'blank' + '.svg' } }, { class: 'as-file-list-item-name', child: { text: '..' } }, { tag: 'button', class: 'as-file-list-item-quick-btn', child: 'span.mdi.mdi-dots-vertical' } ] }); }; FileListItem.property = {}; FileListItem.property.fileType = { set: function (value) { this._fileType = value; if (value) { if (catalog.indexOf(value) >= 0) this.$icon.src = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + value + '.svg'; else this.$icon.src = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + 'blank' + '.svg'; } else { this.$icon.src = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + 'blank' + '.svg'; } }, get: function () { return this._fileType; } }; FileListItem.property.fileName = { set: function (value) { this.$name.firstChild.data = value + ''; }, get: function () { return this.$name.firstChild.data; } }; FileListItem.property.value = { set: function (value) { value = value || null; var info = (0,utils.fileInfoOf)(value); var type = info.type || null; var size = info.size || null; var name = info.name || null; this._value = value; this.fileSize = size; this.fileName = name; this.fileType = type; if (value) { this.addClass('as-has-value'); } else { this.removeClass('as-has-value'); } }, get: function () { return this._value; } }; FileListItem.eventHandler = {}; /*** * @this FileListItem * @param event */ FileListItem.eventHandler.click = function (event) { if (!(0,EventEmitter/* isMouseLeft */.FQ)(event)) return; if ((0,EventEmitter/* hitElement */.EY)(this.$check, event) || (0,EventEmitter/* hitElement */.EY)(this.$quickMenuBtn, event)) return; if (this.$parent && this.$parent.showCheck) { this.$check.checked = !this.$check.checked; this.$check.notifyChange(); } }; ACore/* default.install */.Z.install(FileListItem); /* harmony default export */ const js_FileListItem = (FileListItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FileListInput.js /*** * @extends AElement * @constructor */ function FileListInput() { ContextMenu/* default.auto */.Z.auto(); this.$add = (0,ACore.$)('.as-file-list-input-add', this); this.$attachhook = (0,ACore.$)('attachhook', this); this.$attachhook.requestUpdateSize = this.updateSize.bind(this); this.$attachhook.on('attached', function () { ResizeSystem/* default.add */.Z.add(this); this.requestUpdateSize(); }); this.on('filedrop', this.eventHandler.input_fileDrop); this.on('contextmenu', this.eventHandler.itemContext); this.$addedFile = (0,ACore.$)('input', this.$add) .on('change', this.eventHandler.clickAdd); /*** * * @type {FileInputBox[]} */ this.$fileItems = []; this.$activeItem = null; this._files = []; /*** * @name files * @memberOf FileListInput# * @type {*} * */ /*** * @name readOnly * @memberOf FileListInput# * @type {boolean} */ /*** * @name disabled * @memberOf FileListInput# * @type {boolean} */ /*** * @name multiple * @memberOf FileListInput# * @type {boolean} */ /*** * @name droppable * @memberOf FileListInput# * @type {boolean} */ } FileListInput.tag = 'FileListInput'.toLowerCase(); FileListInput.render = function () { return (0,ACore._)({ tag: DropZone/* default.tag */.Z.tag, class: ['as-file-list-input', 'as-bscroller', 'as-empty', 'as-droppable'], extendEvent: ['change', 'contextmenu', 'check'], child: [ { tag: 'label', class: 'as-file-list-input-add', child: [ { tag: 'input', attr: { type: 'file', accept: '*', title: null } }, { class: 'as-file-list-input-add-icon-ctn', child: 'span.mdi.mdi-upload-outline' }, 'attachhook' ] }, { tag: 'span', class: 'as-file-list-drag-file-text', child: { text: '(Kéo thả file vào đây để tải lên)' } }, { class: 'as-file-list-input-upload-overlay', child: 'span.mdi.mdi-upload' } ] }); }; FileListInput.prototype.defaultChecked = false; FileListInput.prototype.updateSize = function () { var bound, px, n; var requireWidth = this.getComputedStyleValue('--item-require-width') || '300px'; if (requireWidth.match(/%$/)) { this.addStyle('--item-width', requireWidth); } else if (requireWidth.match(/px$/)) { bound = this.getBoundingClientRect(); px = parseFloat(requireWidth.replace('px', '')); if (!isNaN(px) && px > 0) { n = Math.max(1, Math.floor((bound.width - 10 - 2) / px)); this.addStyle('--item-width', Math.floor(100 / n) + '%'); } else { this.removeStyle('--item-width'); } } else { this.removeStyle('--item-width'); } }; FileListInput.prototype._makeFileItem = function (file) { var fileElt = (0,ACore._)({ tag: js_FileListItem.tag, props: { $parent: this, allowUpload: false, fileData: file, checked: this.defaultChecked } }); fileElt.on('mousedown', this.eventHandler.mouseDownItem.bind(this, fileElt)); fileElt.value = file; return fileElt; }; FileListInput.prototype.add = function (file, idx) { if (!(0,utils.isNaturalNumber)(idx)) idx = Infinity; idx = Math.min(this.$fileItems.length, idx); var fileElt = this._makeFileItem(file); var bf = this.$fileItems[idx]; if (bf) { this.$fileItems.splice(idx, 0, fileElt); this._files.splice(idx, 0, file); this.addChildBefore(fileElt, bf); } else { this.$fileItems.push(fileElt); this._files.push(file); this.addChildBefore(fileElt, this.$add); } this._updateCountClass(); }; FileListInput.prototype._updateCountClass = function () { if (this._files.length > 0) { this.removeClass('as-empty'); } else { this.addClass('as-empty'); } }; FileListInput.prototype.activeFileItemElt = function (itemElt) { if (this.$activeItem !== itemElt) { if (this.$activeItem) { this.$activeItem.removeClass('as-active'); } this.$activeItem = itemElt; if (this.$activeItem) { this.$activeItem.addClass('as-active'); } } }; FileListInput.prototype.downloadFileItemElt = function (fileElt) { var fileData = fileElt.fileData; var name = fileData.name || fileElt.fileName; var file; if (fileData instanceof File || fileData instanceof Blob) { file = fileData; } else if (typeof fileData === 'object') { if (fileData.url) file = fileData.url; } else if (typeof fileData === "string") { file = fileData; } if (file) { (0,FileSaver.saveAs)(file, name); } }; FileListInput.prototype.deleteFileItemElt = function (fileElt) { var fileData = fileElt.fileData; var idx = this._files.indexOf(fileData); if (idx >= 0) { this._files.splice(idx, 1); } fileElt.remove(); }; FileListInput.prototype._findFileItemElt = function (target) { while (target && target !== this) { if (target.hasClass && target.hasClass('as-file-list-item')) { return target; } target = target.parentElement; } return null; }; FileListInput.prototype.getChildren = function () { return this.$fileItems.slice(); }; FileListInput.property = {}; FileListInput.property.files = { /*** * @this FileListInput * @param files */ set: function (files) { files = files || []; files = files.slice(); var self = this; this.$fileItems.forEach(function (fileElt) { fileElt.remove(); }); files = files || []; this._files = files; this.$fileItems = files.map(function (file) { var elt = self._makeFileItem(file); self.addChildBefore(elt, self.$add); return elt; }); this._updateCountClass(); }, /*** * @this FileListInput */ get: function () { return (this._files ||[]).slice(); } }; FileListInput.property.readOnly = { set: function (value) { value = !!value; if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } this.$fileItems.forEach(function (fileElt) { fileElt.removable = !value; }); }, get: function () { return this.hasClass('as-read-only'); } }; FileListInput.property.droppable = { set: function (value) { value = !!value; if (value) { this.addClass('as-droppable'); } else { this.removeClass('as-droppable'); } this.$fileItems.forEach(function (fileElt) { fileElt.removable = !value; }); }, get: function () { return this.hasClass('as-droppable'); } }; FileListInput.property.multiple = { set: function (value) { this.$addedFile.multiple = !!value; }, get: function () { return this.$addedFile.multiple; } }; FileListInput.property.accept = { set: function (value) { if (!value) value = null; this.$addedFile.attr('accept', value + ''); }, get: function () { return this.$addedFile.attr('accept') || null; } }; FileListInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; FileListInput.property.showCheck = { set: function (value) { if (value) { this.addClass('as-show-check'); } else { this.removeClass('as-show-check'); } }, get: function () { return this.hasClass('as-show-check'); } }; ACore/* default.install */.Z.install(FileListInput); /*** * @memberOf FileListInput# * @type {{}} */ FileListInput.eventHandler = {}; FileListInput.eventHandler.clickAdd = function (event) { var files = Array.prototype.slice.call(this.$addedFile.files); this.$addedFile.files = null; if (files.length === 0) return; for (var i = 0; i < files.length; ++i) { this.add(files[i]); } this.emit('change', { files: files, type: 'change', target: this, originalEvent: event, action: 'add' }, this); }; /*** * @this FileListInput * @param itemElt * @param event */ FileListInput.eventHandler.mouseDownItem = function (itemElt, event) { this.activeFileItemElt(itemElt); }; FileListInput.eventHandler.input_fileDrop = function (event) { if (this.readOnly || this.disabled) return; var self = this; var files = Array.prototype.slice.call(event.files); if (files.length === 0) return; if (!this.multiple) files = files.slice(0, 1); var accept = this.accept; files = files.filter(function (file) { return (0,utils.fileAccept)(accept, file.type) || (0,utils.fileAccept)(accept, file.name); }); if (files.length > 0) { files.forEach(function (file) { self.add(file); }); this.emit('change', { type: 'change', files: files, target: this, action: 'drop' }, this); } }; /*** * @this FileListInput * @param itemElt * @param event */ FileListInput.eventHandler.itemContext = function (event) { if (this.disabled) return; var self = this; var itemElt = this._findFileItemElt(event.target); var menuItems = []; if (itemElt) { menuItems.push({ text: LanguageSystem/* default.getText */.ZP.getText('txt_download') || "Download", icon: 'span.mdi.mdi-download', cmd: 'download' }); } if (!this.readOnly) { if (itemElt) menuItems.push({ text: LanguageSystem/* default.getText */.ZP.getText('txt_delete') || "Delete", icon: 'span.mdi.mdi-delete', cmd: 'delete' }); menuItems.push( { text: LanguageSystem/* default.getText */.ZP.getText('txt_delete_all') || "Delete All", icon: 'span.mdi.mdi-delete-empty', cmd: 'delete_all' }); } if (menuItems.length > 0) { event.showContextMenu({ items: menuItems }, function (event) { var files; switch (event.menuItem.cmd) { case 'download': self.downloadFileItemElt(itemElt); break; case 'delete': self.deleteFileItemElt(itemElt); self.emit('change', { type: 'change', item: itemElt.fileData, target: this, action: 'delete' }, this); break; case 'delete_all': files = self.files; self.files = []; self.emit('change', { type: 'change', items: files, target: this, action: 'delete_all' }, this); break; } }); } }; /* harmony default export */ const js_FileListInput = (FileListInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dateinyearinput.css var dateinyearinput = __webpack_require__(8563); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DateInYearPicker.js /*** * @extends AElement * @constructor */ function DateInYearPicker() { this._month = null; this._date = null; this.$domSignal = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); this._setupMonth(); this._setupDate(); } DateInYearPicker.tag = 'DateInYearPicker'.toLowerCase(); DateInYearPicker.render = function () { return (0,ACore._)({ extendEvent: ['change'], class: 'as-date-in-year-picker', child: [ { class: 'as-date-in-year-picker-table', child: [ { class: 'as-date-in-year-picker-row', child: [ { class: 'as-date-in-year-picker-cell', child: {tag: 'span', child: {text: 'Month'}} }, { class: 'as-date-in-year-picker-cell', child: {tag: 'span', child: {text: 'Date'}} } ] }, { class: 'as-date-in-year-picker-row', child: [ { class: 'as-date-in-year-picker-cell', child: { class: 'as-date-in-year-picker-month-col', child: [ { class: 'as-date-in-year-picker-month-viewport', child: [ { class: 'as-date-in-year-picker-month-scroller', child: Array(36).fill(null).map(function (u, i) { return { tag: 'button', class: 'as-date-in-year-picker-month', child: { tag: 'span', child: {text: 1 + i % 12 + ''} }, props: { monthL: i % 12 } } }) } ] }, { tag: 'button', class: ['as-date-in-year-picker-month-btn', 'as-up'], child: 'span.mdi.mdi-chevron-up' }, { tag: 'button', class: ['as-date-in-year-picker-month-btn', 'as-down'], child: 'span.mdi.mdi-chevron-down' } ] } }, { class: 'as-date-in-year-picker-cell', child: { class: 'as-date-in-year-picker-days', child: Array(5).fill(null).map(function (u, i) { return { class: 'as-date-in-year-picker-week', child: Array(7).fill(null).map(function (u1, j) { return { class: 'as-date-in-year-picker-day', child: { tag: 'span', child: {text: i * 7 + j + 1 + ''} } }; }) }; }) } } ] } ] } ] }); }; DateInYearPicker.prototype._setupMonth = function () { this._monthScrollDy = 0; this.$monthScroller = (0,ACore.$)('.as-date-in-year-picker-month-scroller', this) .on('scroll', this.eventHandler.monthScroll) .once('wheel', this.eventHandler.monthScroll); this.$monthUpBtn = (0,ACore.$)('.as-date-in-year-picker-month-btn.as-up', this) .on('pointerdown', this.eventHandler.monthPressDown); this.$monthDownBtn = (0,ACore.$)('.as-date-in-year-picker-month-btn.as-down', this) .on('pointerdown', this.eventHandler.monthPressUp); this.$months = (0,ACore.$$)('.as-date-in-year-picker-month', this); for (var i = 0; i < 36; ++i) this.$months[i].on('click', this.eventHandler.clickMonth.bind(this, i % 12)); }; DateInYearPicker.prototype._setupDate = function () { this.$days = (0,ACore.$$)('.as-date-in-year-picker-day', this); var i; for (i = 31; i < 35; ++i) { this.$days[i].addStyle('visibility', 'hidden'); } for (i = 0; i < 31; ++i) { this.$days[i].on('click', this.eventHandler.clickDate.bind(this, i + 1)); } }; DateInYearPicker.prototype.scrollIntoSelected = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('scrollIntoSelected'); return; } var d = Infinity; var dy; var y; var ly, hy; var lineHeight = this.getFontSize() * 2; if (this._month !== null) { for (var k = 0; k < 3; ++k) { y = this._month * lineHeight + lineHeight * 12 * k; ly = this.$monthScroller.scrollTop; hy = ly + lineHeight * 4 - lineHeight; if (ly <= y && hy >= y) { dy = 0; break; } if (y < ly && ly - y < d) { d = ly - y; dy = y - ly; } if (y > hy && y - hy < d) { d = y - hy; dy = y - hy; } } this.$monthScroller.scrollTop += dy; } }; /*** * @memberOf DateInYearPicker# * @type {{}} */ DateInYearPicker.eventHandler = {}; /*** * @this DateInYearPicker */ DateInYearPicker.eventHandler.monthPressDown = function () { document.addEventListener('pointerup', this.eventHandler.monthRelease); this._monthScrollDy = -8; this.eventHandler.monthTick(); }; /** * @this DateInYearPicker */ DateInYearPicker.eventHandler.monthPressUp = function () { document.addEventListener('pointerup', this.eventHandler.monthRelease); this._monthScrollDy = 8; this.eventHandler.monthTick(); }; /** * @this DateInYearPicker */ DateInYearPicker.eventHandler.monthTick = function () { if (!this._monthScrollDy) return; var d = this._monthScrollDy; var fontSize = this.getFontSize(); if (this.$monthScroller.scrollTop + d < 0) d += fontSize * 2 * 12; this.$monthScroller.scrollTop += d; setTimeout(this.eventHandler.monthTick, 30); }; DateInYearPicker.eventHandler.monthRelease = function () { document.removeEventListener('pointerup', this.eventHandler.monthRelease); this._monthScrollDy = 0; }; /** * @this DateInYearPicker */ DateInYearPicker.eventHandler.monthScroll = function () { var scrollTop = this.$monthScroller.scrollTop; var fontSize = this.getFontSize(); if (scrollTop < fontSize * 2 * 12) { this.$monthScroller.scrollTop += fontSize * 2 * 12; } else if (scrollTop > fontSize * 2 * 12 * 2) { this.$monthScroller.scrollTop -= fontSize * 2 * 12; } }; /** * @this DateInYearPicker */ DateInYearPicker.eventHandler.clickMonth = function (month, event) { var pDate = this.date; if (this.month === month) return; this.month = month; this.emit('change', {type: 'change', originalEvent: event, target: this}, this); }; /** * @this DateInYearPicker */ DateInYearPicker.eventHandler.clickDate = function (date, event) { if (this.date === date) return this.date = date; this.emit('change', {type: 'change', originalEvent: event, target: this}, this); }; DateInYearPicker.property = {}; DateInYearPicker.property.date = { set: function (value) { if (typeof value !== 'number') value = null; var cM, dim; if (this._month === null) { dim = 31; } else { cM = new Date(2000, this._month, 1); dim = (0,datetime.compareDate)((0,datetime.nextMonth)(cM), cM); } if (typeof value === "number") value = Math.max(1, Math.min(dim, Math.floor(value))); if (isNaN(value)) value = null; if (this._date === value) return; if (this._date !== null) { this.$days[this._date - 1].removeClass('as-selected'); } this._date = value; if (this._date !== null) { this.$days[this._date - 1].addClass('as-selected'); } }, get: function () { return this._date; } }; DateInYearPicker.property.month = { /*** * @this DateInYearPicker * @param value */ set: function (value) { if (typeof value == 'number') { value = Math.max(0, Math.min(11, Math.floor(value))); } else value = null; if (isNaN(value)) value = null; if (this._month === value) return; if (this._month !== null) { this.$months[this._month].removeClass('as-selected'); this.$months[this._month + 12].removeClass('as-selected'); this.$months[this._month + 24].removeClass('as-selected'); } this._month = value; var cM, dim; if (this._month !== null) { this.$months[this._month].addClass('as-selected'); this.$months[this._month + 12].addClass('as-selected'); this.$months[this._month + 24].addClass('as-selected'); this.scrollIntoSelected(); cM = new Date(2000, this._month, 1); dim = (0,datetime.compareDate)((0,datetime.nextMonth)(cM), cM); } else { dim = 31; } for (var i = 29; i < 31; ++i) { if (i < dim) { this.$days[i].removeStyle('visibility'); } else { this.$days[i].addStyle('visibility', 'hidden'); } } this.date = Math.min(this.date, dim); }, get: function () { return this._month; } }; DateInYearPicker.property.value = { set: function (value) { value = value || {month: null, date: null}; this.month = value.month; this.date = value.date; }, get: function () { return {month: this.month, date: this.date}; } }; ACore/* default.install */.Z.install(DateInYearPicker); /* harmony default export */ const js_DateInYearPicker = (DateInYearPicker); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DateInYearInput.js /*** * @extends AElement * @constructor */ function DateInYearInput() { this._format = 'dd/MM'; this._value = null; this.$clearBtn = (0,ACore.$)('.as-time-input-clear-btn', this) .on('click', this.clear.bind(this, true)); this.$input = (0,ACore.$)('input', this); this.on('click', this.eventHandler.click); } DateInYearInput.tag = 'DateInYearInput'.toLowerCase(); DateInYearInput.render = function () { return (0,ACore._)({ extendEvent: ['change'], class: ['as-date-time-input', 'as-date-in-year-input', 'as-empty'], child: [ { tag: 'input', class: 'as-date-time-input-text', attr: { ondrop: "return false;", readOnly: true }, props: { value: 'dd/MM' } }, { tag: 'button', class: 'as-time-input-clear-btn', child: 'span.mdi.mdi-close-circle' }, { tag: 'button', class: 'as-date-time-input-icon-btn', child: 'span.mdi.mdi-calendar-today' } ] }); }; DateInYearInput.prototype.share = { $follower: null, $picker: null, $input: null }; DateInYearInput.prototype._preparePicker = function () { if (this.share.$picker) return; this.share.$picker = (0,ACore._)({ tag: js_DateInYearPicker.tag, class:'as-dropdown-box-common-style' }); this.share.$follower = (0,ACore._)({ tag: Follower/* default.tag */.Z.tag, class: 'as-date-in-year-follower', child: this.share.$picker }); }; DateInYearInput.prototype.clear = function (userAction, event) { var pValue = this.value; this.value = null; if (pValue) { this.emit('change', { type: 'change', action: 'clear', target: this, originalEvent: event }, this) } }; DateInYearInput.prototype._attachPicker = function () { this._preparePicker(); if (this.share.$input === this) return; if (this.share.$input) this.share.$input._releasePicker(); this.share.$input = this; this.share.$follower.addTo(document.body); this.share.$follower.followTarget = this; this.share.$follower.sponsorElement = this; this.share.$picker.value = this._value; this.share.$picker.on('change', this.eventHandler.pickerChange); setTimeout(function () { document.addEventListener('click', this.eventHandler.clickOut); }.bind(this), 0); }; DateInYearInput.prototype._releasePicker = function () { if (this.share.$input !== this) return; var cValue = this._value; var value = this.share.$picker.value; var nValue = this._normalizeValue(value); this.share.$input = null; this.share.$picker.followTarget = null; this.share.$follower.remove(); this.share.$picker.off('change', this.eventHandler.pickerChange); document.removeEventListener('click', this.eventHandler.clickOut); var changed = !cValue !== !nValue; if (nValue && !changed) { changed = cValue.date === nValue.date && cValue.month === nValue.month; } if (changed) { this._value = value; this.emit('change', { type: 'change', value: nValue, target: this }, this); } }; DateInYearInput.prototype._normalizeValue = function (value) { if (!value) return null; var m = Math.min(11, Math.max(0, Math.floor(value.month))); if (isNaN(m)) return null; var dim = (0,datetime.compareDate)((0,datetime.nextMonth)(new Date(2000, m, 1)), new Date(2000, m, 1)); var d = Math.min(dim, Math.max(1, Math.floor(value.date))); if (isNaN(d)) return null; return { date: d, month: m }; }; DateInYearInput.prototype._updateValueText = function () { var value = this._value; if (value) { this.$input.value = this._format.replace(new RegExp(datetime.DATE_TIME_TOKEN_RGX.source, 'g'), function (full) { switch (full) { case 'dd': case 'd': if ((0,utils.isRealNumber)(value.date)) { return (0,utils.zeroPadding)(value.date, full.length); } return full; case 'M': case 'MM': if ((0,utils.isRealNumber)(value.month)) { return (0,utils.zeroPadding)(value.month + 1, full.length); } return full; default: return full; } }); } else { this.$input.value = this._format; } if (this.$input.value === this._format) { this.addClass('as-empty'); } else { this.removeClass('as-empty'); } }; DateInYearInput.property = {}; DateInYearInput.property.value = { set: function (value) { value = this._normalizeValue(value); this._value = value; this._updateValueText(); }, get: function () { return this._normalizeValue(this._value); } }; DateInYearInput.property.notNull = { set: function (value) { if (value) { this.addClass('as-must-not-null'); } else { this.removeClass('as-must-not-null'); } }, get: function () { return this.hasClass('as-must-not-null'); } }; DateInYearInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); this.$input.disabled = true; } else { this.removeClass('as-disabled'); this.$input.disabled = false; } }, get: function () { return this.hasClass('as-disabled'); } }; DateInYearInput.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); this.$input.readOnly = true; } else { this.removeClass('as-read-only'); this.$input.readOnly = false; } }, get: function () { return this.hasClass('as-read-only'); } }; /*** * @memberOf DateInYearInput# * @type {{}} */ DateInYearInput.eventHandler = {}; /*** * @this DateInYearInput * @param event */ DateInYearInput.eventHandler.click = function (event) { if (this.readOnly || (0,EventEmitter/* hitElement */.EY)(this.$clearBtn, event)) return; this._attachPicker(); }; /*** * @this DateInYearInput * @param event */ DateInYearInput.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$follower, event)) return; this._releasePicker(); }; DateInYearInput.eventHandler.pickerChange = function () { this._value = this.share.$picker.value; this._updateValueText(); }; ACore/* default.install */.Z.install(DateInYearInput); /* harmony default export */ const js_DateInYearInput = (DateInYearInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dualselectmenu.css var dualselectmenu = __webpack_require__(9273); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DualSelectBox.js /*** * @extends Follower * @constructor */ function DualSelectBox() { this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('scrollIntoSelected', this.scrollIntoSelected.bind(this)); this._items = []; this._value = [null, null]; this.holderByValue = {}; this.$lists = (0,ACore.$$)('.as-dual-select-box-list', this); this.$searcTextInput = (0,ACore.$)('searchtextinput', this) .on('stoptyping', this.eventHandler.searchTextInputModify); this.$closeBtn = (0,ACore.$)('.as-select-list-box-close-btn', this) .on('click', this.eventHandler.clickCloseBtn); this.cView = new DualSelectView(this, this._items); this.searchedView = { '*': this.cView }; this.estimateSize = { width: 0, height: 0 }; this._emittedValue = [null, null]; /*** * @name strictValue * @type {boolean} * @memberOf DualSelectBox# */ /*** * @name enableSearch * @type {boolean} * @memberOf DualSelectBox# */ /*** * @name value * @type {Array} * @memberOf DualSelectBox# */ /*** * @name items * @type {Array} * @memberOf DualSelectBox# */ } DualSelectBox.tag = 'DualSelectBox'.toLowerCase(); DualSelectBox.render = function () { return (0,ACore._)({ tag: Follower/* default.tag */.Z.tag, class: 'as-dual-select-box', extendEvent: ['change', 'close'], child: [ { class: 'as-dual-select-box-search-ctn', child: { tag: 'searchtextinput' } }, { class: 'as-dual-select-box-list-ctn', child: [ { class: ['as-dual-select-box-list', 'absol-selectlist', 'as-bscroller'], }, { class: 'as-dual-select-box-arrow-ctn', child: 'span.mdi.mdi-menu-right' }, { class: ['as-dual-select-box-list', 'absol-selectlist', 'as-bscroller'] } ] }, { class: 'as-dropdown-box-footer', child: [ { class: 'as-dropdown-box-footer-right', child: [ { tag: 'a', class: 'as-select-list-box-close-btn', child: { text: LanguageSystem/* default.getText */.ZP.getText('txt_close') } } ] } ] } ] }); }; DualSelectBox.prototype._implicit = function (value) { if (value instanceof Array) { if (value.length > 2) value = value.slice(0, 2); else { value.push.apply(value, Array(2 - value.length).fill(null)); } } else { value = [null, null]; } return value; }; DualSelectBox.prototype._explicit = function (value) { value = value.slice(); var strictValue = this.strictValue; if (!this.holderByValue[value[0]]) { if (this._items.length > 0 && strictValue) { value[0] = this._items[0].value; } else { return null; } } if (!this.holderByValue[value[0]].child[value[1]]) { if (strictValue && this.holderByValue[value[0]].item.items && this.holderByValue[value[0]].item.items.length > 0) { value[1] = this.holderByValue[value[0]].item.items[0].value; } else { return null; } } if (value[0] === null || value[1] === null) { return null; } return value; }; DualSelectBox.prototype._notifyIfChange = function (event) { var value = this._explicit(this._value); if (value === this._emittedValue) return; if (!value !== !this._emittedValue || (value[0] !== this._emittedValue[0] || value[1] !== this._emittedValue[1])) { this.emit('change', { type: 'change', target: this, originalEvent: event }, this); } }; DualSelectBox.prototype._makeLeftItem = function (item) { var itemElt = (0,ACore._)({ class: 'absol-selectlist-item', child: { tag: 'span', class:'absol-selectlist-item-text', child: { text: item.text } } }); itemElt.itemData = item; itemElt.on('click', this.eventHandler.clickLeftItem.bind(this, itemElt)); return itemElt; }; DualSelectBox.prototype.makeRightItem = function (item) { var itemElt = (0,ACore._)({ class: 'absol-selectlist-item', child: { tag: 'span', class:'absol-selectlist-item-text', child: { text: item.text } } }); itemElt.itemData = item; itemElt.on('click', this.eventHandler.clickRightItem.bind(this, itemElt)); return itemElt; }; DualSelectBox.prototype._calcEstimateSize = function (items) { var fontSize = (0,ACore.$)(document.body).getFontSize(); var longestItem = null; var longestE14 = 0; var e14, i, j; var item, subItem; for (i = 0; i < items.length; ++i) { item = items[i]; e14 = (0,utils.estimateWidth14)(item.text); if (e14 > longestE14) { longestItem = item; longestE14 = e14; } } var leftTextWidth = longestItem ? (0,utils.measureText)(longestItem.text, '14px arial').width : 0; var maxN = items.length; for (i = 0; i < items.length; ++i) { item = items[i]; if (!item.items || item.items.length === 0) continue; maxN = Math.max(maxN, item.items.length); for (j = 0; j < item.items.length; ++j) { subItem = item.items[j]; e14 = (0,utils.estimateWidth14)(subItem.text); if (e14 > longestE14) { longestItem = subItem; longestE14 = e14; } } } var rightTextWidth = longestItem ? (0,utils.measureText)(longestItem.text, '14px arial').width : 0; return { width: (7 + leftTextWidth + 7 + 5 + 7 + 1 + 17 + 1 + 7 + rightTextWidth + 7 + 5 + 7 + 20) * fontSize / 14, height: maxN * 20 * fontSize / 14, textWidth: (leftTextWidth + rightTextWidth + 12) * fontSize / 14 } }; DualSelectBox.prototype.scrollIntoSelected = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('scrollIntoSelected'); return; } if (this.cView && this.cView.$leftSelectedItem && this.cView.$leftSelectedItem.isDescendantOf(this.$lists[0])) { this.cView.$leftSelectedItem.scrollIntoView(); } if (this.cView && this.cView.$rightSelectedItem && this.cView.$rightSelectedItem.isDescendantOf(this.$lists[1])) { this.cView.$rightSelectedItem.scrollIntoView(); } }; DualSelectBox.prototype.focus = js_SelectListBox.prototype.focus; DualSelectBox.property = {}; DualSelectBox.property.items = { /*** * @this DualSelectBox * @param items */ set: function (items) { var self = this; items = items || []; (0,search/* prepareSearchForList */.Lb)(items); this._items = items; this.holderByValue = items.reduce(function (ac, cr) { ac[cr.value] = { item: cr, child: (cr.items || []).reduce(function (ac1, cr1) { ac1[cr1.value] = { item: cr1 } return ac1; }, {}) } return ac; }, {}); this.estimateSize = this._calcEstimateSize(items); this.addStyle('--dual-list-estimate-width', this.estimateSize.width + 'px'); this.searchedView = {}; this.cView = new DualSelectView(this, items); this.searchedView['*'] = this.cView; this.cView.toView(); }, get: function () { return this._items; } }; DualSelectBox.property.enableSearch = { set: function (value) { if (value) { this.addClass('as-enable-search'); } else { this.removeClass('as-enable-search'); } }, get: function () { return this.hasClass('as-enable-search'); } }; DualSelectBox.property.strictValue = { set: function (value) { if (value) { this.addClass('as-strict-value'); } else { this.removeClass('as-strict-value'); } if (this.cView) this.cView.updateViewByValue(); }, get: function () { return this.hasClass('as-strict-value'); } }; DualSelectBox.property.value = { /*** * @this DualSelectBox * @param value */ set: function (value) { this._value = this._implicit(value); if (this.cView) { this.cView.updateViewByValue(); this.cView.toRightList(); } this.scrollIntoSelected(); }, get: function () { return this._explicit(this._value); } }; /*** * @memberOf DualSelectBox# * @type {{}} */ DualSelectBox.eventHandler = {}; /*** * @this DualSelectBox * @param itemElt * @param event */ DualSelectBox.eventHandler.clickLeftItem = function (itemElt, event) { var item = itemElt.itemData; this._value[0] = item.value; this.cView.updateLeftSelectedItem(); this.cView.updateRightList(); this.cView.toRightList(); if (this.cView.$leftItemByValue[item.value] && this.cView.$leftItemByValue[item.value].itemData && this.cView.$leftItemByValue[item.value].itemData.items && this.cView.$leftItemByValue[item.value].itemData.items.length > 0) { this._value[1] = this.cView.$leftItemByValue[item.value].itemData.items[0].value; this.cView.updateRightSelectedItem(); } if (this.cView.$rightSelectedItem) { this.cView.$rightSelectedItem.scrollIntoView(); } this._notifyIfChange(event); }; /*** * @this DualSelectBox * @param itemElt * @param event */ DualSelectBox.eventHandler.clickRightItem = function (itemElt, event) { var item = itemElt.itemData; this._value[1] = item.value; this.cView.updateRightSelectedItem(); this._notifyIfChange(event); }; DualSelectBox.prototype.searchItemByText = function (text) { var items = this._items; var queryItem = (0,search/* default */.ZP)({ text: text }); var maxScore = 0; var holders = items.map(function (item) { var h = { item: item, itemScore: (0,search/* calcItemMatchScore */.lk)(queryItem, item), }; maxScore = Math.max(maxScore, h.itemScore); var childMaxScore = 0; if (item.items && item.items.length > 0) { h.child = item.items.map(function (cItem) { var cItemScore = (0,search/* calcItemMatchScore */.lk)(queryItem, cItem); maxScore = Math.max(maxScore, cItemScore); childMaxScore = Math.max(childMaxScore, cItemScore); return { item: cItem, itemScore: cItemScore }; }); h.childScore = childMaxScore; } return h; }); holders.sort(function (a, b) { return -Math.max(a.itemScore, a.childScore) + Math.max(b.itemScore, b.childScore) }); var midScore = maxScore / 2; holders = holders.filter(function (holder) { return Math.max(holder.itemScore, holder.childScore) >= midScore; }); return holders.map(function (holder) { var oldItem = holder.item; var item = { text: oldItem.text, value: oldItem.value }; var childHolders; if (holder.child) { childHolders = holder.child.slice(); childHolders.sort(function (a, b) { return -a.itemScore + b.itemScore; }); item.items = childHolders.map(function (cHolder) { return cHolder.item; }); item.isSearchItem = true; } return item; }); }; DualSelectBox.prototype.focus = function () { if (this.enableSearch) { this.$searcTextInput.focus(); } }; DualSelectBox.prototype.resetSearchState = function () { if (this.$searcTextInput.value.length === 0) return; this.$searcTextInput.value = ''; this.eventHandler.searchTextInputModify(); }; /*** * @this DualSelectBox */ DualSelectBox.eventHandler.searchTextInputModify = function () { var query = this.$searcTextInput.value.trim().replace(/\s+/, ' '); if (query.length === 0) query = '*'; var view = this.searchedView[query]; if (!view) { view = new DualSelectView(this, this.searchItemByText(query)); this.searchedView[query] = view; } this.cView = view; this.cView.updateLeftSelectedItem(); this.cView.updateRightSelectedItem(); view.toView(); this.$lists[0].scrollTop = 0; this.$lists[1].scrollTop = 0; if (query === '*') this.scrollIntoSelected(); }; DualSelectBox.eventHandler.clickCloseBtn = function (event) { this.emit('close', { type: 'close', target: this, originalEvent: event }, this); }; ACore/* default.install */.Z.install(DualSelectBox); /* harmony default export */ const js_DualSelectBox = (DualSelectBox); /*** * * @param {DualSelectBox} box * @param items * @constructor */ function DualSelectView(box, items) { var self = this; this.box = box; this.items = items; this.$leftItems = items.map(function (item) { return self.box._makeLeftItem(item); }); this.$leftItemByValue = this.$leftItems.reduce(function (ac, cr) { ac[cr.itemData.value] = cr; return ac; }, {}); this.$rightItems = []; this.$rightItemByValue = {}; this.$leftSelectedItem = null; this.$rightSelectedItem = null; this.updateViewByValue(); } DualSelectView.prototype.toView = function () { this.box.$lists[0].clearChild(); this.box.$lists[0].addChild(this.$leftItems); this.updateLeftSelectedItem(); this.toRightList(); }; DualSelectView.prototype.toRightList = function () { this.box.$lists[1].clearChild(); this.box.$lists[1].addChild(this.$rightItems); this.updateLeftSelectedItem(); }; DualSelectView.prototype.updateViewByValue = function () { this.updateLeftSelectedItem(); this.updateRightList(); }; DualSelectView.prototype.updateRightList = function () { var self = this; var leftValue = this.box._value[0]; var items = this.$leftItemByValue[leftValue] && this.$leftItemByValue[leftValue].itemData.items; if (items && items.length > 0) { this.$rightItems = items.map(function (item) { return self.box.makeRightItem(item); }); } else { this.$rightItems = []; } this.$rightItemByValue = this.$rightItems.reduce(function (ac, cr) { ac[cr.itemData.value] = cr; return ac; }, {}); this.updateRightSelectedItem(); }; DualSelectView.prototype.updateLeftSelectedItem = function () { if (this.$leftSelectedItem) { this.$leftSelectedItem.removeClass('as-selected'); } this.$leftSelectedItem = this.$leftItemByValue[this.box._value[0]] || null; if (this.$leftSelectedItem) { this.$leftSelectedItem.addClass('as-selected'); } }; DualSelectView.prototype.updateRightSelectedItem = function () { if (this.$rightSelectedItem) { this.$rightSelectedItem.removeClass('as-selected'); } this.$rightSelectedItem = this.$rightItemByValue[this.box._value[1]] || null; if (this.$rightSelectedItem) { this.$rightSelectedItem.addClass('as-selected'); } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DualSelectMenu.js /*** * @extends AElement * @constructor */ function DualSelectMenu() { this._format = '$0, $1'; /*** * @type {DualSelectBox} */ this.$box = (0,ACore._)({ tag: js_DualSelectBox.tag, props: { anchor: [1, 6, 2, 5] }, on: { preupdateposition: this.eventHandler.preUpdatePosition, change: this.eventHandler.boxChange, close: this.eventHandler.boxClose } }); this.$box.cancelWaiting(); this.$item = (0,ACore.$)('.absol-selectlist-item', this); this.on('click', this.eventHandler.click); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$box, 'enableSearch'); /*** * @name strictValue * @type {boolean} * @memberOf DualSelectMenu# */ /*** * @name readOnly * @type {boolean} * @memberOf DualSelectMenu# */ /*** * @name disabled * @type {boolean} * @memberOf DualSelectMenu# */ } DualSelectMenu.tag = 'DualSelectMenu'.toLowerCase(); DualSelectMenu.render = function () { return (0,ACore._)({ class: ['absol-selectmenu', 'as-dual-select-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { class: 'absol-selectmenu-holder-item', child: '.absol-selectlist-item' }, { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] }, 'attachhook', ] }); }; DualSelectMenu.prototype._updateViewValue = function () { var format = this._format; var value = this.$box.value || [null, null]; var strictValue = this.strictValue; var hbv = this.$box.holderByValue; var firstToken = '__'; var secToken = '__'; var firstHolder = hbv[value[0]]; var sectHolder; if (firstHolder) { firstToken = firstHolder.item.text; sectHolder = firstHolder.child[value[1]]; if (sectHolder) secToken = sectHolder.item.text } var text = format.replace('$0', firstToken) .replace('$1', secToken); this.$item.clearChild().addChild((0,ACore._)({ tag: 'span', class:['as-selectlist-item-text', 'absol-selectlist-item-text'], child: { text: text } })); }; DualSelectMenu.property = {}; DualSelectMenu.property.selectedItems = { get: function () { var value = this.$box.value || [null, null]; var hbv = this.$box.holderByValue; var firstHolder = hbv[value[0]]; var sectHolder; var res = [null, null]; if (firstHolder) { res[0] = firstHolder.item; sectHolder = firstHolder.child[value[1]]; if (sectHolder) res[1] = sectHolder.item; } return res; } }; DualSelectMenu.property.isFocus = { /*** * @this DualSelectMenu * @param value */ set: function (value) { var self = this; value = !!value; if (value && (this.disabled || this.readOnly)) return; if (this.hasClass('as-focus') === value) return; if (value) { this._prevValue = (this.$box.value || [null, null]).join('//'); this.addClass('as-focus'); this.off('click', this.eventHandler.click); this.$box.followTarget = this; this.$box.sponsorElement = this; this.$box.addTo(document.body); this.$box.updatePosition(); this.$box.scrollIntoSelected(); setTimeout(function () { self.$box.focus(); document.addEventListener('click', self.eventHandler.clickOut); }, 10); } else { this.removeClass('as-focus'); this.$box.selfRemove(); this.$box.resetSearchState(); document.removeEventListener('click', self.eventHandler.clickOut); setTimeout(function () { self.on('click', self.eventHandler.click); }, 10); if ((this.$box.value || [null, null]).join('//') !== this._prevValue) { this._updateViewValue(); this.emit('change', { type: 'change', target: this }, this); } } }, get: function () { return this.hasClass('as-focus'); } } /**** * @memberOf DualSelectMenu# * @type {{}} */ DualSelectMenu.eventHandler = {}; DualSelectMenu.property.items = { /*** * @this DualSelectMenu * @param items */ set: function (items) { this.$box.items = items; this.addStyle('--dual-list-estimate-text-width', this.$box.estimateSize.textWidth + 'px'); this._updateViewValue(); }, get: function () { return this.$box.items; } }; DualSelectMenu.property.value = { set: function (value) { this.$box.value = value; this._updateViewValue(); }, get: function () { return this.$box.value; } }; DualSelectMenu.property.strictValue = { set: function (value) { this.$box.strictValue = value; this._updateViewValue(); }, get: function () { return this.$box.strictValue; } }; DualSelectMenu.property.format = { set: function (value) { this._format = value || '$0, $1'; this._updateViewValue(); }, get: function () { return this._format; } }; DualSelectMenu.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; DualSelectMenu.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } } /** * @this DualSelectMenu */ DualSelectMenu.eventHandler.click = function () { if (this.readOnly) return; this.isFocus = true; }; /** * @this DualSelectMenu */ DualSelectMenu.eventHandler.clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$box, event)) return; this.isFocus = false; }; /*** * @this DualSelectMenu */ DualSelectMenu.eventHandler.preUpdatePosition = function () { var bound = this.getBoundingClientRect(); var screenSize = (0,Dom/* getScreenSize */.tE)(); var availableTop = bound.top - 5; var availableBot = screenSize.height - 5 - bound.bottom; this.$box.addStyle('--max-height', Math.max(availableBot, availableTop) + 'px'); var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); if (bound.bottom < outBound.top || bound.top > outBound.bottom || bound.right < outBound.left || bound.left > outBound.right) { this.isFocus = false; } }; DualSelectMenu.eventHandler.boxChange = function () { this._updateViewValue(); }; DualSelectMenu.eventHandler.boxClose = function () { this.isFocus = false; }; ACore/* default.install */.Z.install(DualSelectMenu); /* harmony default export */ const js_DualSelectMenu = (DualSelectMenu); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/toclist.css var toclist = __webpack_require__(5322); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TOCItem.js /*** * @extends AElement * @constructor */ function TOCItem() { this.$iconP = null; this.$iconCtn = (0,ACore.$)('.as-toc-item-ext-icon-ctn', this); this._status = 'none'; this.$name = (0,ACore.$)('.as-toc-item-name', this); this.$nameInput = (0,ACore.$)('.as-toc-item-name-input', this) .on('keydown', this.eventHandler.keyDownNameInput) .on('paste', this.eventHandler.keyDownNameInput); this.$toggleCtn = (0,ACore.$)('.as-toc-item-toggle-ico-ctn', this); this._level = 0; this.$checkbox = (0,ACore.$)(CheckBoxInput/* default.tag */.Z.tag, this) .on('change', this.eventHandler.checkedChange); this.$checkbox.disabled = true; this.$checkbox.addStyle('display', 'none'); this.$checkIco = (0,ACore.$)('.as-toc-item-check-ctn .mdi-check', this) .addStyle('display', 'none') .addStyle('font-size', '18px'); this.$quickMenuBtn = (0,ACore.$)('.as-toc-item-quick-menu-ctn button', this) .on('click', this.eventHandler.clickQuickMenuBtn); this.on('click', this.eventHandler.click); this._lastClickTime = 0; /*** * @name hasQuickMenu * @type {boolean} * @memberOf TOCItem# */ /*** * @name name * @type {string} * @memberOf TOCItem# */ /*** * @name status * @type {"none"|"open"|"close"} * @memberOf TOCItem# */ /*** * @name level * @type {number} * @memberOf TOCItem# */ /*** * @name checked * @type {boolean} * @memberOf TOCItem# */ /*** * @name nodeData * @type {{}} * @memberOf TOCItem# */ } TOCItem.tag = 'TOCItem'.toLowerCase(); TOCItem.render = function () { return (0,ACore._)({ class: ['as-toc-item', 'as-has-quick-menu'], extendEvent: ['presstoggle', 'checkedchange', 'pressquickmenu', 'press', 'renamefinish'], child: [ { class: 'as-toc-item-toggle-ico-ctn', child: 'toggler-ico' }, '.as-toc-item-ext-icon-ctn', { class: 'as-toc-item-name-ctn', child: [ { tag: 'span', class: 'as-toc-item-name', child: { text: 'đây là cái tên' } }, { tag: 'input', class: 'as-toc-item-name-input', attr: { type: 'text' } } ] }, { class: 'as-toc-item-check-ctn', child: [{ tag: CheckBoxInput/* default.tag */.Z.tag }, 'span.mdi.mdi-check'] }, { class: 'as-toc-item-quick-menu-ctn', child: { tag: 'button', child: 'span.mdi.mdi-dots-vertical' } } ] }); }; TOCItem.property = {}; TOCItem.property.icon = { set: function (value) { if (this.$iconP) { this.$iconP.remove(); this.$iconP = undefined; } if (value) { var newE; if (!Dom/* default.isDomNode */.ZP.isDomNode(value)) { newE = (0,ACore._)(value); } this.$iconP = newE; this.$iconCtn.addChild(newE); this._icon = value; } else { this._icon = undefined; } }, get: function () { return this._icon; } }; TOCItem.property.status = { set: function (value) { if (['none', 'open', 'close'].indexOf(value) < 0) value = 'none'; this.removeClass('as-status-' + this._status); this._status = value; this.addClass('as-status-' + value); }, get: function () { return this._status; } }; TOCItem.property.name = { set: function (value) { this.$name.firstChild.data = value || ''; }, get: function () { return this.$name.firstChild.data; } }; TOCItem.property.level = { set: function (value) { this._level = value; this.addStyle('--level', value + ''); }, get: function () { return this._level; } }; TOCItem.property.checked = { set: function (value) { this.$checkbox.checked = value; if (value) { this.$checkIco.removeStyle('display'); } else { this.$checkIco.addStyle('display', 'none'); } }, get: function () { return this.$checkbox.checked; } }; TOCItem.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; TOCItem.property.hasQuickMenu = { set: function (value) { if (value) { this.addClass('as-has-quick-menu'); } else { this.removeClass('as-has-quick-menu'); } }, get: function () { return this.hasClass('as-has-quick-menu'); } }; TOCItem.property.extendClasses = { set: function (value) { value = value || []; if (typeof value === 'string') value = value.trim().split(/\s/).filter(x => !!x); if (this._extendClasses) { this._extendClasses.forEach(c => this.removeClass(c)); } this._extendClasses = value; this._extendClasses.forEach(c => this.addClass(c)); }, get: function () { return this._extendClasses || []; } }; TOCItem.prototype.rename = function () { this.addClass('as-renaming'); var name = this.name; var textWidth = (0,utils.measureText)(name, '14px Arial, Helvetica, sans-serif').width; this.$nameInput.addStyle('width', textWidth + 2 + 'px'); this.$nameInput.value = name; this.$nameInput.focus(); this.$nameInput.select(); this.$nameInput.once('blur', function (event) { var event1; if (this.$nameInput.value !== name) { event1 = (0,EventEmitter/* copyEvent */.FG)(event, { originalEvent: event, type: 'renamefinish', newName: this.$nameInput.value, __promise__: Promise.resolve(true), waitFor: function (promise) { if (promise && promise.then) { this.__promise__ = promise; } else { this.__promise__ = Promise.resolve(promise); } } }); this.emit('renamefinish', event1, this); event1.__promise__.then(function (result) { if (result === true) { this.name = event1.newName; } else if (typeof result === 'string') { this.name = result; } }.bind(this)); } this.removeClass('as-renaming'); }.bind(this)); }; /*** * @memberOf TOCItem# * @type {{}} */ TOCItem.eventHandler = {}; TOCItem.eventHandler.keyDownNameInput = function (event) { var extendText = ''; if (event.type === 'paste') { extendText = (event.clipboardData || window.clipboardData).getData('text') || ''; } else if (event.key.length === 1 && !(event.ctrl && event.key === 'C')) { extendText = event.key; } else if (event.key === 'Enter') { this.$nameInput.blur(); } if (extendText.length > 0) { this.$nameInput.addStyle('width', (0,utils.measureText)(this.$nameInput.value + extendText, '14px Arial, Helvetica, sans-serif').width + 2 + 'px'); } setTimeout(function () { var name = this.$nameInput.value; this.$nameInput.addStyle('width', (0,utils.measureText)(name, '14px Arial, Helvetica, sans-serif').width + 2 + 'px'); }.bind(this), 0); }; TOCItem.eventHandler.checkedChange = function (event) { this.emit('checkedchange', { type: 'checkedchange', target: this, originalEvent: event }, this); }; TOCItem.eventHandler.clickQuickMenuBtn = function (event) { this.emit('pressquickmenu', { type: 'pressquickmenu', originalEvent: event }, this); }; TOCItem.eventHandler.click = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$checkbox, event) || (0,EventEmitter/* hitElement */.EY)(this.$quickMenuBtn, event)) return; var now= Date.now(); if ((0,EventEmitter/* hitElement */.EY)(this.$toggleCtn, event)) { this.emit('presstoggle', { originalEvent: event, type: 'presstoggle' }, this); } else { if (now - this._lastClickTime > 500) { this.emit('press', { type: 'press', originalEvent: event }, this); } else if (this.status === "close" || this.status === 'open'){ this.emit('presstoggle', { originalEvent: event, type: 'presstoggle' }, this); } this._lastClickTime = now; } }; ACore/* default.install */.Z.install(TOCItem); /* harmony default export */ const js_TOCItem = (TOCItem); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tool/BlurTrigger.js var BlurTrigger = __webpack_require__(9346); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TOCList.js /*** * @extends AElement * @constructor */ function TOCList() { this.$searchInput = null; this.$body = (0,ACore.$)('.as-toc-list-body', this); this.$searching = (0,ACore.$)('.as-toc-list-searching', this); this.rootController = new TOCVirtualRootController(this, [], this.$body); this.searchCache = {}; this.savedState = { active: [], status: {} }; /*** * @name nodes * @type {{}[]} * @memberOf TOCList# */ } TOCList.tag = 'TOCList'.toLowerCase(); TOCList.render = function () { return (0,ACore._)({ extendEvent: ['pressnode', 'checkednodechange', 'pressnodequickmmenu', 'statechange'], class: 'as-toc-list', child: [ '.as-toc-list-body', '.as-toc-list-searching' ] }); }; TOCList.prototype.applySavedState = function () { var savedStatus = this.savedState.status; function visitArr(arr) { arr.forEach(function (ct) { var status = savedStatus[ct.ident]; if (status) { ct.status = status; } savedStatus[ct.ident] = ct.status; visitArr(ct.children); }); } visitArr(this.rootController.children); if (this.savedState.active) { this.savedState.active.forEach(function (ident) { var activeCt = this.findControllerByIdent(ident); if (activeCt) activeCt.active(); }.bind(this)); } }; TOCList.prototype.resetSavedState = function () { this.savedState = { active: null, status: {} }; }; TOCList.prototype.saveState = function () { var oldState = this.savedState; var savedState = { active: [], status: {} }; var changed = false; function visitArr(arr) { arr.forEach(function (ct) { savedState.status[ct.ident] = ct.status; changed = changed || savedState.status[ct.ident] !== oldState.status[ct.ident]; if (ct.nodeElt.hasClass('as-active')) { savedState.active.push(ct.ident); } visitArr(ct.children); }); } var oldActive = (oldState.active || []).slice(); oldActive.sort(); var newActive = (savedState.active || []).slice(); newActive.sort(); changed = changed || (oldActive.join('/') !== newActive.join('/')); visitArr(this.rootController.children); this.savedState = savedState; if (changed) this.notifySavedStateChange(); }; TOCList.prototype.notifySavedStateChange = function () { this.emit('statechange', { target: this, type: 'statechange' }, this); }; TOCList.prototype.loadSavedState = function (savedState) { savedState = savedState || {}; if (typeof savedState.active === 'string') savedState.active = [savedState.active]; this.savedState = { active: savedState.active || [], status: savedState.status || {} }; this.applySavedState(); }; /*** * @param {number=} n */ TOCList.prototype.openAllNodeRecursive = function (n) { this.rootController.openRecursive(n); this.saveState(); }; TOCList.prototype.closeAllNodeRecursive = function () { this.rootController.closeRecursive(); this.saveState(); }; TOCList.prototype.deactivateAllNode = function () { this.rootController.deactivateRecursive(); }; /*** * * @param ident * @returns {TOCNodeController|null} */ TOCList.prototype.activeNode = function (ident) { var nodeCt = this.findControllerByIdent(ident); var parent; if (nodeCt) { nodeCt.active(); parent = nodeCt.parent; while (parent) { if (parent.open && parent.status === 'close') parent.open(); parent = parent.parent; } setTimeout(() => { (0,utils.vScrollIntoView)(nodeCt.nodeElt); }, 100); } return nodeCt; }; TOCList.prototype.getActivatedNodes = function () { var res = []; this.rootController.traverse(function (node) { if (node.activated) { res.push(node); } }); return res; }; /*** * * @param {string} ident * @param {TOCNodeController|TOCVirtualRootController=} rootController * @returns {TOCNodeController} */ TOCList.prototype.findControllerByIdent = function (ident, rootController) { var res = null; rootController = rootController || this.rootController; function visitArr(arr) { arr.some(function (ct) { if (ct.ident + '' === ident + '') { res = ct; return true; } visitArr(ct.children); }); } visitArr(rootController.children); return res; }; TOCList.prototype.makeNodeController = function (nodeData) { return new TOCNodeController(this, nodeData, null); }; /** * * @param query * @private * @returns {TOCVirtualRootController} */ TOCList.prototype._calcSearch = function (query) { var searchRootController = this.searchCache[query]; if (searchRootController) return searchRootController; var itemTree = this.searchCache.__itemTree__; if (!itemTree) { itemTree = this.nodes.map(function visit(node) { var item = (0,search/* default */.ZP)({ text: node.name, value: Object.assign({}, node) }); if (node.children && node.children.length > 0) { item.items = node.children.map(visit); } return item; }); this.searchCache.__itemTree__ = itemTree; } var resultItemTree = (0,search/* searchTreeListByText */.$l)(query, itemTree); var resultNodes = resultItemTree.map(function visit2(item) { var node = Object.assign({}, item.value); delete node.children; if (item.items && item.items.length > 0) { node.children = item.items.map(visit2); } return node; }); this.searchCache[query] = new TOCVirtualRootController(this, resultNodes) return this.searchCache[query]; }; TOCList.prototype.search = function (query) { query = query || ''; query = query.trim().replace('\s(\s+)', ' '); var searchRoot = this._calcSearch(query); var activeNodeCt; if (query.length === 0) { this.removeClass('as-searching'); this.$searching.clearChild(); } else { this.addClass('as-searching'); this.$searching.clearChild(); searchRoot.openRecursive(); activeNodeCt = this.findControllerByIdent(this.savedState.active, searchRoot); if (activeNodeCt) activeNodeCt.active(); searchRoot.view = this.$searching; } }; TOCList.property = {}; TOCList.property.nodes = { /*** * @this TOCList * @param nodes */ set: function (nodes) { this.searchCache = {}; nodes = nodes || []; this.rootController = new TOCVirtualRootController(this, nodes); this.rootController.view = this.$body; this.applySavedState(); }, get: function () { return this.rootController.nodes; } }; TOCList.property.searchInput = { /*** * @this TOCList */ set: function (elt) { if (this.$searchInput) { this.$searchInput.off('stoptyping', this.eventHandler.searchTextInputModify); } this.$searchInput = elt; if (this.$searchInput) { this.$searchInput.on('stoptyping', this.eventHandler.searchTextInputModify); } }, /*** * @this TOCList */ get: function () { return this.$searchInput; } } /*** * @memberOf TOCList# * @type {{}} */ TOCList.eventHandler = {}; TOCList.eventHandler.pressNode = function (nodeController, event) { var newEvent = (0,EventEmitter/* copyEvent */.FG)(event.originalEvent || event, { type: 'pressnode', target: this, originalEvent: event.originalEvent || event, controller: nodeController, nodeData: nodeController.nodeElt.nodeData, nodeElt: nodeController.nodeElt, }); this.emit('pressnode', newEvent, this); }; TOCList.eventHandler.checkedNodeChange = function (nodeController, event) { var newEvent = { type: 'checkednodechange', target: this, originalEvent: event.originalEvent || event, controller: nodeController, nodeData: nodeController.nodeElt.nodeData, nodeElt: nodeController.nodeElt }; this.emit('checkednodechange', newEvent, this); }; TOCList.eventHandler.pressNodeQuickMenu = function (nodeController, event) { var newEvent = { type: 'pressnodequickmmenu', target: this, originalEvent: event.originalEvent || event, controller: nodeController, nodeData: nodeController.nodeElt.nodeData, nodeElt: nodeController.nodeElt }; newEvent.showMenu = function (menuProps, onSelect) { var token = QuickMenu/* default.show */.Z.show(nodeController.nodeElt.$quickMenuBtn, menuProps, [3, 4], onSelect, false); var blurTrigger = new BlurTrigger/* default */.Z([], 'click', function () { QuickMenu/* default.close */.Z.close(token); }, 10, 30); }; this.emit('pressnodequickmmenu', newEvent, this); }; /*** * @this TOCList */ TOCList.eventHandler.searchTextInputModify = function () { this.search(this.$searchInput.value); }; ACore/* default.install */.Z.install(TOCList); /*** * * @param {TOCList} listElt * @param {{}[]} nodes * @constructor */ function TOCVirtualRootController(listElt, nodes) { Object.defineProperties(this, { root: { value: this } }); this.listElt = listElt; this.level = -1; this.nodes = nodes; /*** * * @type {TOCNodeController[]} */ this.children = nodes.map(function (nodeData) { return new TOCNodeController(listElt, nodeData, this); }.bind(this)); this._view = null; /**** * @type {AElement} * @name view * @memberOf TOCVirtualRootController# */ } TOCVirtualRootController.prototype.deactivateRecursive = function () { this.children.forEach(function (ct) { }); }; TOCVirtualRootController.prototype.openRecursive = function (n) { this.children.forEach(function (ct) { ct.openRecursive(n); }); }; TOCVirtualRootController.prototype.closeRecursive = function () { this.children.forEach(function (ct) { ct.closeRecursive(); }); }; TOCVirtualRootController.prototype.getViewElements = function () { var ac = []; this.children.forEach(function (ct) { ct.getViewElements(ac); }); return ac; }; TOCVirtualRootController.prototype.indexOfChild = function (child) { for (var i = 0; i < this.children.length; ++i) { if (child === this.children[i] || this.children[i].ident === child) return i; } return -1; }; /*** * * @param {TOCNodeController} controller * @param {TOCNodeController} at * @returns {TOCVirtualRootController} */ TOCVirtualRootController.prototype.addChildBefore = function (controller, at) { var atIdx; if (at) { atIdx = this.indexOfChild(at); if (atIdx >= 0) { if (controller.parent) controller.remove(); this.children.splice(atIdx, 0, controller); controller.__parent__ = this; if (at.nodeElt.parentElement) { (0,utils.addElementsBefore)(at.nodeElt.parentElement, controller.getViewElements(), at.nodeElt); } this.updateStatus(); } else { throw new Error("The node before which the new node is to be inserted is not a child of this node."); } } else { if (controller.parent) controller.remove(); this.children.push(controller); if (this.view) this.addChild(controller.getViewElements()); this.updateStatus(); } controller.setLevelRecursive(this.level + 1); return this; }; TOCVirtualRootController.prototype.addChild = function (controller) { this.addChildBefore(controller, null); return this; }; /*** * * @param {TOCNodeController} controller * @param at */ TOCVirtualRootController.prototype.addChildAfter = function (controller, at) { var atIdx; var lastElement; if (at) { atIdx = this.indexOfChild(at); if (atIdx === this.children.length) { if (controller.parent) controller.remove(); controller.__parent__ = this; this.children.push(controller); if (this.view) this.view.addChild(controller.getViewElements()); } else if (atIdx >= 0) { if (controller.parent) controller.remove(); controller.__parent__ = this; this.children.splice(atIdx, 0, controller); if (at.nodeElt.parentElement) { lastElement = at.getViewElements().pop(); (0,utils.addElementAfter)(at.nodeElt.parentElement, controller.getViewElements(), lastElement); } } else { throw new Error("The node before which the new node is to be inserted is not a child of this node."); } } else { if (controller.parent) controller.remove(); controller.__parent__ = this; this.children.unshift(controller); (0,utils.addElementAfter)(this.view, controller.getViewElements(), this.view.firstChild); } return this; }; TOCVirtualRootController.prototype.updateStatus = noop/* default */.Z; /*** * @param {TOCNodeController} child * @returns {TOCVirtualRootController|TOCNodeController} */ TOCVirtualRootController.prototype.removeChild = function (child) { var idx = this.children.indexOf(child); if (idx >= 0) { this.children.splice(idx, 1); child.getViewElements().forEach(function (elt) { elt.remove(); }); this.updateStatus(); } return this; }; /*** * * @param {function(nodeCt:TOCNodeController):(void|boolean)} callback return true to stop */ TOCVirtualRootController.prototype.traverse = function (callback) { this.children.some(function visit(ct) { return callback(ct) || ct.children.some(visit); }); }; Object.defineProperties(TOCVirtualRootController.prototype, { firstChild: { get: function () { return this.children[0] || null; } }, lastChild: { get: function () { return this.children[this.children.length - 1] || null; } }, view: { /*** * @this TOCVirtualRootController * @param view */ set: function (view) { view = view || null; if (view === this._view) return; if (this._view) { this._view.clearChild(); this._view.rootController = null; this._view = null; } if (view) { if (view.rootController) { view.rootController.view = null; } view.rootController = this; this._view = view; this._view.addChild(this.getViewElements()); } }, get: function () { return this._view; } } }); /*** * * @param {TOCList} listElt * @param {{}} nodeData * @param {TOCNodeController|TOCVirtualRootController} parent * @constructor */ function TOCNodeController(listElt, nodeData, parent) { Object.defineProperties(this, { listElt: { value: listElt }, __parent__: { value: parent, enumerable: false, writable: true } }); this.level = parent ? parent.level + 1 : 0; /*** * @type {TOCItem} */ this.nodeElt = (0,ACore._)({ tag: js_TOCItem.tag, props: { nodeData: nodeData, checked: !!nodeData.checked, name: nodeData.name, icon: nodeData.icon, level: this.level, controller: this, status: 'none', extendClasses: nodeData.extendClasses }, on: { presstoggle: this.toggle.bind(this), press: this.ev_press.bind(this), checkedchange: this.ev_checkedChange.bind(this), pressquickmenu: this.ev_pressQuickMenu.bind(this) } }); if (nodeData.hasQuickMenu === false) this.nodeElt.hasQuickMenu = false; this.nodeElt.on('presstoggle', this.listElt.saveState.bind(this.listElt)); /*** * @name children * @type {TOCNodeController[]} * @memberOf TOCNodeController# */ if (nodeData.children && nodeData.children.length > 0) { this.nodeElt.status = 'close'; this.children = nodeData.children.map(function (c) { return new TOCNodeController(listElt, c, this); }.bind(this)); } else { this.children = []; } } TOCNodeController.prototype.indexOfChild = TOCVirtualRootController.prototype.indexOfChild; TOCNodeController.prototype.traverse = TOCVirtualRootController.prototype.traverse; TOCNodeController.prototype.updateStatus = function () { if (this.children.length === 0 && this.nodeElt.status !== 'none') { this.nodeElt.status = 'none'; } else if (this.children.length > 0 && this.nodeElt.status === 'none') { this.nodeElt.status = 'close'; } }; TOCNodeController.prototype.deactivateRecursive = function () { this.nodeElt.removeClass('as-active'); this.children.forEach(function (ct) { ct.deactivateRecursive(); }); }; TOCNodeController.prototype.removeChild = TOCVirtualRootController.prototype.removeChild; TOCNodeController.prototype.remove = function () { this.parent.removeChild(this); }; /*** * * @param {TOCNodeController} controller * @param {TOCNodeController} at * @returns {TOCNodeController} */ TOCNodeController.prototype.addChildBefore = function (controller, at) { var atIdx; if (at) { atIdx = this.indexOfChild(at); if (atIdx >= 0) { if (controller.parent) controller.remove(); this.children.splice(atIdx, 0, controller); controller.__parent__ = this; if (this.status === 'open') { (0,utils.addElementsBefore)(this.nodeElt.parentElement, controller.getViewElements(), at.nodeElt); } controller.setLevelRecursive(this.level + 1); this.updateStatus(); } else { throw new Error("The node before which the new node is to be inserted is not a child of this node."); } } else { if (controller.parent) controller.remove(); this.children.push(controller); this.updateStatus(); if (this.status === "open") { (0,utils.addElementsBefore)(this.nodeElt.parentElement, controller.getViewElements(), at.nodeElt); } } return this; }; TOCNodeController.prototype.addChild = TOCVirtualRootController.prototype.addChild; TOCNodeController.prototype.addChildAfter = function (controller, at) { throw new Error("Not implement!"); }; TOCNodeController.prototype.toggle = function () { if (this.status === 'close') this.open(); else if (this.status === 'open') this.close(); }; TOCNodeController.prototype.open = function () { if (this.status !== 'close') return; this.nodeElt.status = 'open'; var pE = this.nodeElt.parentElement; if (!pE) return; var veArr = this.getViewElements(); veArr.shift(); var at = pE.findChildAfter(this.nodeElt); if (at) { while (veArr.length > 0) { pE.addChildBefore(veArr.shift(), at); } } else { pE.addChild(veArr); } }; TOCNodeController.prototype.close = function () { if (this.status !== 'open') return; var veArr = this.getViewElements(); veArr.shift(); while (veArr.length > 0) { veArr.pop().remove() } this.nodeElt.status = 'close'; }; TOCNodeController.prototype.getViewElements = function (ac) { if (ac === undefined) ac = []; ac.push(this.nodeElt); if (this.status === 'open' && this.children.length > 0) { this.children.forEach(function (ct) { ct.getViewElements(ac); }); } return ac; }; TOCNodeController.prototype.setLevelRecursive = function (value) { this.level = value; this.nodeElt.level = value; this.children.forEach(function (ct) { ct.setLevelRecursive(value + 1); }); }; /** * * @param {number=} level */ TOCNodeController.prototype.openRecursive = function (level) { if ((typeof level === "number") && this.level >= level) return; if (this.status === 'close') { this.open(); } this.children.forEach(function (ct) { ct.openRecursive(level); }); }; TOCNodeController.prototype.ev_press = function (event) { this.listElt.eventHandler.pressNode(this, event); }; TOCNodeController.prototype.ev_checkedChange = function (event) { this.nodeElt.nodeData.checked = this.nodeElt.checked; this.listElt.eventHandler.checkedNodeChange(this, event); }; TOCNodeController.prototype.ev_pressQuickMenu = function (event) { this.listElt.eventHandler.pressNodeQuickMenu(this, event); }; TOCNodeController.prototype.ev_renameFinish = function (event) { }; TOCNodeController.prototype.closeRecursive = function () { if (this.status === 'open') { this.close(); } this.children.forEach(function (ct) { ct.closeRecursive(); }); }; TOCNodeController.prototype.rename = function () { }; /*** * * @param {boolean=true} isActive default: true * @param {boolean=false} append default: false */ TOCNodeController.prototype.active = function (isActive, append) { var self = this; if (arguments.length === 0) isActive = true; append = !!append; var idx = this.listElt.savedState.active ? this.listElt.savedState.active.indexOf(this.ident) : -1; if (isActive) { this.root.traverse(function (ct) { if (ct === self) { ct.nodeElt.addClass('as-active'); } else if (!append) ct.nodeElt.removeClass('as-active'); }); if (idx < 0) { this.listElt.savedState.active = this.listElt.savedState.active || []; if (append) { this.listElt.savedState.active.push(this.ident); } else { this.listElt.savedState.active = [this.ident]; } this.listElt.notifySavedStateChange(); } } else { if (idx >= 0) { if (append) { this.listElt.savedState.active.splice(idx, 1); this.nodeElt.removeClass('as-active'); } else { this.listElt.savedState.active = []; this.root.traverse(function (ct) { ct.nodeElt.removeClass('as-active'); }); } } } }; Object.defineProperties(TOCNodeController.prototype, { /*** * @memberOf TOCNodeController# * @name status * @type {"open"|"close"|"none"} */ status: { get: function () { return this.nodeElt.status; }, set: function (value) { if (value === 'open' && this.nodeElt.status === 'close') this.open(); else if (value === 'close' && this.nodeElt.status === 'open') this.close(); } }, root: { get: function () { return this.parent ? this.parent.root : this; } }, checked: { get: function () { return !!this.nodeElt.nodeData.checked; }, set: function (value) { this.nodeElt.checked = !!value; this.nodeElt.nodeData.checked = !!value; } }, name: { set: function (value) { value = value || ''; this.nodeElt.name = value; this.nodeElt.nodeData.name = value; }, get: function () { return this.nodeElt.nodeData.name; } }, ident: { get: function () { return this.nodeElt.nodeData.ident; }, set: function (value) { this.nodeElt.nodeData.ident = value; } }, nodeData: { get: function () { return this.nodeElt.nodeData; }, set: function (value) { this.nodeElt.nodeData = value; } }, parent: { get: function () { return this.__parent__; } }, firstChild: { get: function () { return this.children[0] || null; } }, lastChild: { get: function () { return this.children[this.children.length - 1] || null; } }, activated: { get: function () { return this.nodeElt.hasClass('as-active'); } } }); /* harmony default export */ const js_TOCList = (TOCList); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/ckplaceholder.css var ckplaceholder = __webpack_require__(2285); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/ckcontentstyle.css.tpl /* harmony default export */ const ckcontentstyle_css = ("\r\n.as-ck-alert {\r\n padding: .75rem 1.25rem;\r\n margin-bottom: 1rem;\r\n border: 1px solid transparent;\r\n border-radius: .188rem;\r\n}\r\n\r\n.as-ck-alert.as-variant-notice {\r\n color: #7b5700;\r\n background-color: #fbedcc;\r\n border-color: #fae6b8;\r\n}\r\n\r\n.as-ck-alert.as-variant-warning {\r\n color: #852d19;\r\n background-color: #ffddd6;\r\n border-color: #ffd0c5;\r\n}\r\n\r\n.as-ck-alert.as-variant-info {\r\n color: #352c64;\r\n background-color: #e0ddf2;\r\n border-color: #d4cfed;\r\n}\r\n\r\n.as-ck-alert.as-variant-success {\r\n color: #2a601f;\r\n background-color: #dcf1d8;\r\n border-color: #ceebc8;\r\n}\r\n\r\n\r\n.cke_contents_ltr ul {\r\n list-style: none;\r\n}\r\n\r\n.cke_contents_ltr ul li {\r\n position: relative;\r\n}\r\n\r\n.cke_contents_ltr ul li::before {\r\n color: #007bff;\r\n content: '●';\r\n position: absolute;\r\n left: -1.2em;\r\n top: -0.1em;\r\n display: inline-block;\r\n}\r\n\r\n.cke_contents_ltr thead {\r\n background-color: #d6d6d6;\r\n\r\n}\r\n\r\n.cke_contents_ltr table {\r\n border-collapse: collapse;\r\n}\r\n\r\n.cke_contents_ltr table[align=\"center\"] {\r\n margin-left: auto;\r\n margin-right: auto;\r\n}\r\n\r\n.cke_contents_ltr table[align=\"right\"] {\r\n margin-left: auto;\r\n}\r\n\r\n\r\n.cke_contents_ltr thead td {\r\n padding: 10px;\r\n border: 1px solid #efefef;\r\n font-weight: bold;\r\n}\r\n\r\n.cke_contents_ltr thead td:last-child {\r\n border-right-color: #dddddd;\r\n}\r\n\r\n\r\n.cke_contents_ltr thead td:first-child {\r\n border-left-color: #dddddd;\r\n}\r\n\r\n\r\n.cke_contents_ltr tbody td {\r\n\r\n}\r\n\r\n.cke_contents_ltr tbody tr:nth-child(odd) {\r\n background-color: rgb(245, 245, 245);\r\n}\r\n\r\n.cke_contents_ltr tbody tr:nth-child(even) {\r\n background-color: white;\r\n}\r\n\r\n.cke_contents_ltr tbody td {\r\n padding: 5px 10px;\r\n border: 1px solid #ddd;\r\n}\r\n\r\n\r\n.cke_button_icon.cke_button__insert_expression_icon {\r\n background-image: url('');\r\n background-position: 0 0px;\r\n background-size: 16px;\r\n}\r\n\r\n.cke_button_icon.cke_button__insert_variable_icon {\r\n background-image: url('');\r\n background-position: 0 0px;\r\n background-size: 16px;\r\n}\r\n\r\n.cke_button_icon.cke_button__insert_dynamic_link_icon {\r\n background-image: url('');\r\n background-position: 0 0px;\r\n background-size: 16px;\r\n}\r\n\r\n\r\n.cke_button_icon.cke_button__mdi_dialog_icon {\r\n background-image: url('');\r\n background-position: 0 0px;\r\n background-size: 16px;\r\n}\r\n\r\n\r\n\r\n.as-ck-widget-expression {\r\n color: #1da1ff;\r\n}\r\n\r\n.as-ck-widget-variable {\r\n color: #144f25;\r\n}\r\n\r\n.as-ck-widget-mdi {\r\n display: inline-block;\r\n width: 1.5em;\r\n height: 1.5em;\r\n position: relative;\r\n vertical-align: baseline;\r\n}\r\n.as-ck-widget-mdi.mdi::before {\r\n display: block;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n text-align: center;\r\n font-size: 1.5em;\r\n line-height: 1;\r\n}\r\n\r\n\r\n.cke_button__image_mgn_dialog_icon {\r\n background: url($basePath/plugins/icons.png) no-repeat 0 -960px !important;\r\n}\r\n\r\n\r\nbody .cke_contents_ltr h1,\r\nbody .cke_contents_ltr h2,\r\nbody .cke_contents_ltr h3,\r\nbody .cke_contents_ltr h4,\r\nbody .cke_contents_ltr h5,\r\nbody .cke_contents_ltr h6 {\r\n font-weight: normal;\r\n line-height: 1.2;\r\n}\r\n\r\nbody .cke_contents_ltr {\r\n line-height: 1.6;\r\n font-size: inherit;\r\n font-family: sans-serif, Arial, Verdana, \"Trebuchet MS\", \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\r\n background-color: #fff;\r\n word-wrap: break-word;\r\n text-align: left;\r\n}\r\n\r\n.cke_contents_ltr blockquote {\r\n font-style: italic;\r\n font-family: inherit;\r\n border-style: solid;\r\n border-color: #ccc;\r\n border-width: 0;\r\n padding-left: 20px;\r\n padding-right: 8px;\r\n border-left-width: 5px;\r\n}\r\n\r\nbody .cke_contents_ltr a {\r\n color: #0782C1;\r\n}\r\n\r\nbody .cke_contents_ltr ol,\r\nbody .cke_contents_ltr ul,\r\nbody .cke_contents_ltr dl {\r\n /* IE7: reset rtl list margin. (#7334) */\r\n *margin-right: 0px;\r\n /* Preserved spaces for list items with text direction different than the list. (#6249,#8049)*/\r\n padding: 0 40px;\r\n}\r\n\r\n\r\nbody.cke_contents_ltr { /*editor*/\r\n font-size: 14px;\r\n}\r\n\r\n\r\nbody .cke_contents_ltr hr\r\n{\r\n border: 0px;\r\n border-top: 1px solid #ccc;\r\n}\r\n\r\nbody .cke_contents_ltr img.right\r\n{\r\n border: 1px solid #ccc;\r\n float: right;\r\n margin-left: 15px;\r\n padding: 5px;\r\n}\r\n\r\nbody .cke_contents_ltr img.left\r\n{\r\n border: 1px solid #ccc;\r\n float: left;\r\n margin-right: 15px;\r\n padding: 5px;\r\n}\r\n\r\nbody .cke_contents_ltr pre\r\n{\r\n white-space: pre-wrap; /* CSS 2.1 */\r\n word-wrap: break-word; /* IE7 */\r\n -moz-tab-size: 4;\r\n tab-size: 4;\r\n}\r\n\r\nbody .cke_contents_ltr .marker\r\n{\r\n background-color: Yellow;\r\n}\r\n\r\nbody .cke_contents_ltr span[lang]\r\n{\r\n font-style: italic;\r\n}\r\n\r\nbody .cke_contents_ltr figure\r\n{\r\n text-align: center;\r\n outline: solid 1px #ccc;\r\n background: rgba(0,0,0,0.05);\r\n padding: 10px;\r\n margin: 10px 20px;\r\n display: inline-block;\r\n}\r\n\r\nbody .cke_contents_ltr figure > figcaption\r\n{\r\n text-align: center;\r\n display: block; /* For IE8 */\r\n}\r\n\r\nbody .cke_contents_ltr a > img {\r\n padding: 1px;\r\n margin: 1px;\r\n border: none;\r\n outline: 1px solid #0782C1;\r\n}\r\n\r\n/* Widget Styles */\r\nbody .cke_contents_ltr .code-featured\r\n{\r\n border: 5px solid red;\r\n}\r\n\r\nbody .cke_contents_ltr .math-featured\r\n{\r\n padding: 20px;\r\n box-shadow: 0 0 2px rgba(200, 0, 0, 1);\r\n background-color: rgba(255, 0, 0, 0.05);\r\n margin: 10px;\r\n}\r\n\r\nbody .cke_contents_ltr .image-clean\r\n{\r\n border: 0;\r\n background: none;\r\n padding: 0;\r\n}\r\n\r\nbody .cke_contents_ltr .image-clean > figcaption\r\n{\r\n font-size: .9em;\r\n text-align: right;\r\n}\r\n\r\nbody .cke_contents_ltr .image-grayscale\r\n{\r\n background-color: white;\r\n color: #666;\r\n}\r\n\r\nbody .cke_contents_ltr .image-grayscale img, img.image-grayscale\r\n{\r\n filter: grayscale(100%);\r\n}\r\n\r\nbody .cke_contents_ltr .embed-240p\r\n{\r\n max-width: 426px;\r\n max-height: 240px;\r\n margin:0 auto;\r\n}\r\n\r\nbody .cke_contents_ltr .embed-360p\r\n{\r\n max-width: 640px;\r\n max-height: 360px;\r\n margin:0 auto;\r\n}\r\n\r\nbody .cke_contents_ltr .embed-480p\r\n{\r\n max-width: 854px;\r\n max-height: 480px;\r\n margin:0 auto;\r\n}\r\n\r\nbody .cke_contents_ltr .embed-720p\r\n{\r\n max-width: 1280px;\r\n max-height: 720px;\r\n margin:0 auto;\r\n}\r\n\r\nbody .cke_contents_ltr .embed-1080p\r\n{\r\n max-width: 1920px;\r\n max-height: 1080px;\r\n margin:0 auto;\r\n}\r\n"); // EXTERNAL MODULE: ./node_modules/absol/src/JSMaker/TemplateString.js var TemplateString = __webpack_require__(369); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/ExpressionExtension.js var ExpressionExtension_name = 'expression'; var command = 'insert_expression'; function init(editor) { editor.widgets.add(ExpressionExtension_name, { button: 'Create Expression', template: '<span class="as-ck-widget-expression">{{ expression }}</span>', allowedContent: 'span(!as-ck-widget-expression)', requiredContent: 'span(as-ck-widget-expression)', upcast: function (element) { return element.name === 'span' && element.hasClass('as-ck-widget-expression'); } }); editor.ui.addButton(command, { label: 'Insert expression', command: command, }); editor.addCommand(command, { exec: function (editor) { if (editor.placeHolderElt) { editor.placeHolderElt.emit('command', { command: command, target: editor, type: 'command' }); } } }); } var parserDiv = (0,ACore._)('div'); function explicit(data, placeHolderElt) { parserDiv.innerHTML = data; (0,ACore.$$)('.as-ck-widget-expression', parserDiv).forEach(function (elt) { var text = elt.innerHTML; text.replace(/{/g, '{').replace(/}/g, '}'); elt.parentElement.replaceChild((0,ACore._)({ text: text }), elt) }); return parserDiv.innerHTML; } function implicit(data, placeHolderElt) { var template = TemplateString/* default.parse */.Z.parse(data); return template.parts.slice().map(function (part) { if (part.type === 1) { return '<span class="as-ck-widget-expression">{{ ' + part.data.trim() + ' }}</span>' } else return part.data; }).join(''); } /* harmony default export */ const ExpressionExtension = ({ name: ExpressionExtension_name, command: command, implicit: implicit, explicit: explicit, plugin: { requires: 'widget', init: init }, extendMethods: { /*** * @this CKPlaceholder * @memberOf CKPlaceholder# * @param expression * */ insertExpression: function (expression) { this.editor.insertHtml('<span class="as-ck-widget-expression">{{ ' + expression.trim() + ' }}</span>') }, getSelectedExpression: function () { var sel = this.editor.getSelection(); if (!sel) return null; var elt = sel.getSelectedElement(); if (!elt) return null; if (!elt.hasClass('cke_widget_wrapper_as-ck-widget-expression')) return null; var exp = elt.getText(); exp = exp.replace(/{|}|\{|\}/g, '').trim(); return exp; } } }); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/SimpleTextExtension.js var SimpleTextExtension_name = 'simple_text'; var SimpleTextExtension_parserDiv = (0,ACore._)('div'); function SimpleTextExtension_explicit(data, placeHolderElt) { SimpleTextExtension_parserDiv.innerHTML = data.replace(/ /g, ' '); return SimpleTextExtension_parserDiv.innerText; } function SimpleTextExtension_implicit(data, placeHolderElt) { return data //.replace(/</g, '<').replace(/</g, '>').replace(/"/g, '"').replace(/&/g, '&') .replace(/[\r\n]/g, ''); } /* harmony default export */ const SimpleTextExtension = ({ name: SimpleTextExtension_name, implicit: SimpleTextExtension_implicit, explicit: SimpleTextExtension_explicit, }); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/VariableExtension.js var VariableExtension_name = 'variable'; var VariableExtension_command = 'insert_variable'; function VariableExtension_init(editor) { editor.widgets.add(VariableExtension_name, { button: 'Create Variable', template: '<span class="as-ck-widget-variable" title="variable">variable</span>', allowedContent: 'span(!as-ck-widget-variable)', requiredContent: 'span(as-ck-widget-variable)', upcast: function (element) { return element.name === 'span' && element.hasClass('as-ck-widget-variable'); } }); editor.ui.addButton(VariableExtension_command, { label: 'Insert Variable', command: VariableExtension_command, }); editor.addCommand(VariableExtension_command, { exec: function (editor) { if (editor.placeHolderElt) { editor.placeHolderElt.emit('command', { command: VariableExtension_command, target: editor, type: 'command' }); } } }); } var VariableExtension_parserDiv = (0,ACore._)('div'); function VariableExtension_explicit(data, placeHolderElt) { VariableExtension_parserDiv.innerHTML = data; (0,ACore.$$)('.as-ck-widget-variable', VariableExtension_parserDiv).forEach(function (elt) { var text = elt.innerHTML; elt.parentElement.replaceChild((0,ACore._)({ text: text }), elt) }); return VariableExtension_parserDiv.innerHTML; } var tokenRgx = /("([^\\"]|(\\.))*")|([a-zA-Z_$A-Z]([a-zA-Z_$A-Z0-9]*))/g; function VariableExtension_implicit(data, placeHolderElt) { data = (data || '') + ''; data = data.replace(tokenRgx, function (full, isString, u1, u2, isIdent) { if (isIdent && placeHolderElt.variables && placeHolderElt.variables[isIdent]) { return placeHolderElt.makeVariableHtml(isIdent); } else return full; }); return data; } /* harmony default export */ const VariableExtension = ({ name: VariableExtension_name, command: VariableExtension_command, implicit: VariableExtension_implicit, explicit: VariableExtension_explicit, plugin: { requires: 'widget', init: VariableExtension_init }, extendMethods: { makeVariableHtml: function (variable, text) { variable = variable.trim(); if (this.variables && this.variables[variable]) { text = this.variables[variable].text; } text = text || variable; return '<span class="as-ck-widget-variable" title="' + text + '">' + variable.trim() + '</span>'; }, /*** * @this CKPlaceholder * @memberOf CKPlaceholder# * @param variable * */ insertVariable: function (variable, text) { this.editor.insertHtml(this.makeVariableHtml(variable, text)); }, getSelectedVariable: function () { var sel = this.editor.getSelection(); if (!sel) return null; var elt = sel.getSelectedElement(); if (!elt) return null; if (!elt.hasClass('cke_widget_wrapper_as-ck-widget-variable')) return null; var exp = elt.getText(); exp = exp.trim(); return exp; } } }); /*** * @name variables * @type {{}} * @memberOf CKPlaceholder# */ ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/DynamicLinkExtension.js var DynamicLinkExtension_name = 'dynamic_link'; var DynamicLinkExtension_command = 'insert_dynamic_link'; function DynamicLinkExtension_init(editor) { editor.widgets.add(DynamicLinkExtension_name, { button: 'Create Dynamic Link', template: '<a class="as-ck-widget-dynamic-link" data-link-id="1234" href="https://absol.cf">absol.cf</a>', allowedContent: 'a(!as-ck-widget-dynamic-link)', requiredContent: 'a(as-ck-widget-dynamic-link)', upcast: function (element) { return element.name === 'a' && element.hasClass('as-ck-widget-dynamic-link'); } }); editor.ui.addButton(DynamicLinkExtension_command, { label: 'Insert Dynamic Link', command: DynamicLinkExtension_command, }); editor.addCommand(DynamicLinkExtension_command, { exec: function (editor) { if (editor.placeHolderElt) { editor.placeHolderElt.emit('command', { command: DynamicLinkExtension_command, target: editor, type: 'command' }); } } }); } var DynamicLinkExtension_parserDiv = (0,ACore._)('div'); function DynamicLinkExtension_explicit(data, placeHolderElt) { DynamicLinkExtension_parserDiv.innerHTML = data; (0,ACore.$$)('.as-ck-widget-dynamic-link', DynamicLinkExtension_parserDiv).forEach(function (elt) { }); return DynamicLinkExtension_parserDiv.innerHTML; } function DynamicLinkExtension_implicit(data, placeHolderElt) { DynamicLinkExtension_parserDiv.innerHTML = data; (0,ACore.$$)('.as-ck-widget-dynamic-link', DynamicLinkExtension_parserDiv).forEach(function (elt) { var id = elt.getAttribute('data-link-id'); var info = placeHolderElt.dynamicLinks && placeHolderElt.dynamicLinks[id]; if (info){ elt.setAttribute('href', info.href); elt.innerHTML = info.text || info.href; } }); return DynamicLinkExtension_parserDiv.innerHTML; } /* harmony default export */ const DynamicLinkExtension = ({ name: DynamicLinkExtension_name, command: DynamicLinkExtension_command, implicit: DynamicLinkExtension_implicit, explicit: DynamicLinkExtension_explicit, plugin: { requires: 'widget', init: DynamicLinkExtension_init }, extendMethods: { /*** * @this CKPlaceholder * @memberOf CKPlaceholder# * @param {string} id * @param {string=} href * @param {string=} text * */ insertDynamicLink: function (id, href, text) { var info = (this.dynamicLinks && this.dynamicLinks[id]) || {href:'.', text: 'undefined'}; if (!href){ href = info.href; } if (!text){ text = info.text; } this.editor.insertHtml('<a class="as-ck-widget-dynamic-link" data-link-id="'+id+'" href="'+href+'">' + text + '</a>') }, getSelectedDynamicLink: function () { var sel = this.editor.getSelection(); if (!sel) return null; var elt = sel.getSelectedElement(); if (!elt) return null; if (!elt.hasClass('cke_widget_wrapper_as-ck-widget-dynamic-link')) return null; return (elt.$.firstChild && elt.$.firstChild.getAttribute('data-link-id')) || null; } } }); /*** * @name dynamicLinks * @type {{}} * @memberOf CKPlaceholder# */ ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/ImageFileExtension.js var ImageFileExtension_name = 'image_mgn'; var ImageFileExtension_command = 'image_mgn_dialog'; function ImageFileExtension_init(editor) { editor.ui.addButton(ImageFileExtension_command, { label: 'Insert Image', command: ImageFileExtension_command, }); editor.addCommand(ImageFileExtension_command, { exec: function (editor) { if (window.contentModule && window.contentModule.chooseFile) { window.contentModule.chooseFile({ type: "image_file" }).then(function (result) { if (result instanceof Array) result = result[0]; if (result) { editor.insertHtml('<img alt="'+(result.title|| result.name)+'" src="'+result.url+'" style="max-width: 100%; border-width: 1px; border-style: solid;"/>') } }.bind(this)); } } }); } function ImageFileExtension_explicit(data, placeHolderElt) { return data; } var ImageFileExtension_tokenRgx = /("([^\\"]|(\\.))*")|([a-zA-Z_$A-Z]([a-zA-Z_$A-Z0-9]*))/g; function ImageFileExtension_implicit(data, placeHolderElt) { return data; } /* harmony default export */ const ImageFileExtension = ({ name: ImageFileExtension_name, command: ImageFileExtension_command, // implicit: implicit, // explicit: explicit, plugin: { init: ImageFileExtension_init } }); /*** * @name variables * @type {{}} * @memberOf CKPlaceholder# */ // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Fragment.js + 1 modules var Fragment = __webpack_require__(4861); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/MessageDialog.js var MessageDialog = __webpack_require__(3488); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/videourldialog.css var videourldialog = __webpack_require__(4607); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/videourldialog/videoUtils.js var videoUrlRules = [ [ 'youtube', /^https:\/\/www.youtube.com\//, /[^a-zAZ]v=([^&]+)/, o => 'https://www.youtube.com/embed/' + o.videoId ], [ 'youtube', /^https:\/\/www.youtube.com\/embed\//, /^https:\/\/www.youtube.com\/embed\/([^&\/]+)/, o => o.url, o => 'https://www.youtube.com/watch?v=' + o.videoId ], [ 'vimeo', /^https:\/\/vimeo.com\//, /vimeo.com\/([0-9A-Za-z_]+)/, o => 'https://player.vimeo.com/video/' + o.videoId ], [ 'dailymotion', /^https:\/\/www.dailymotion.com\/video\//, /dailymotion\.com\/video\/([0-9A-Za-z_]+)/, o => 'https://www.dailymotion.com/embed/video/' + o.videoId ], [ 'facebook', /^https:\/\/www.facebook.com\/watch/, /[^a-zAZ]v=([^&]+)/, o => 'https://www.facebook.com/plugins/video.php?height=315&width=560&show_text=false&t=0&href=' + encodeURIComponent(o.url), o => o.embedUrl ], /* INVAID VIDEO ID */ [ 'youtube', /^https:\/\/www.youtube.com(\/|$)/, 'INVALID_URL' ], [ 'vimeo', /^https:\/\/vimeo.com(\/|$)/, /vimeo.com\/([0-9A-Za-z_]+)/, 'INVALID_URL' ], [ 'dailymotion', /^https:\/\/www.dailymotion.com(\/|$)/, null ], [ 'facebook', /^https:\/\/www.facebook.com/, 'INVALID_URL' ], /********************/ [ '*', /./, /\/([^\/]+)$/, o => o.url ] ]; function parseVideoUrl(url) { url = (url || "").trim(); var res = { url: url }; videoUrlRules.some((rule) => { var matched = url.match(rule[1]); if (!matched) return false; res.hostType = rule[0]; if (rule[2] instanceof RegExp) { matched = url.match(rule[2]); if (!matched) return false; res.videoId = matched[1]; } else if (rule[2] === 'INVALID_URL') { res.videoId = "INVALID_URL"; } if (res.videoId !== 'INVALID_URL') { res.embedUrl = rule[3](res); } if (typeof rule[4] === "function") { res.originalUrl = rule[4](res); } else { res.originalUrl = res.url; } return true; }); return res; } var embedVideoSizeCache = {}; var metaRules = [ ['width', 'og:video:width', /content\s*=\s*"([0-9]+)/, 'number'], ['height', 'og:video:height', /content\s*=\s*"([0-9]+)/, 'number'], ['title', 'og:title', /content\s*=\s*"([^"]+)/, s => s.replace(/\s*-\s*Video Dailymotion$/, '')], ['image', 'og:image', /content\s*=\s*"([^"]+)/], ['width', /^video\s/, /width\s*=\s*"([0-9]+)/, 'number', true], ['height', /^video\s/, /height\s*=\s*"([0-9]+)/, 'number', true], ['image', /^img/, /src\s*=\s*"([^"]+)/, x => x.replace(/&/g, '&')], ['title', "a href=\"https://www.facebook.com/watch", />([^<]+)/], ] function getEmbedVideoInfo(url, fullPage) { // fullPage = false; var xUrl = fullPage ? 'https://absol.cf/getpage.php?url=' : 'https://absol.cf/getpagemeta.php?url='; embedVideoSizeCache[url] = embedVideoSizeCache[url] || fetch(xUrl + encodeURIComponent(url)).then(res => res.text()) .then(metaText => { if (metaText === 'DOWNLOAD_ERROR') return { error: metaText }; var lines = metaText.replace(/\n|(>\s*<)/g, '__spliter__').split('__spliter__'); var res = {}; lines.forEach(line => { metaRules.some(rule => { var key = rule[0]; if (key in res) return false; var matched; if (rule[1] instanceof RegExp) { matched = line.match(rule[1]); if (!matched) return false; } else if (typeof rule[1] === "string") { if (line.indexOf(rule[1]) < 0) return false; } matched = line.match(rule[2]); if (!matched) return false; var value = matched[1]; if (rule[3] === 'number') { value = parseFloat(value); if (isNaN(value)) return false; } else if (typeof rule[3] === "function") { value = rule[3](value); } res[key] = value; if (rule[4]) return false; return true; }); }); return res; }); return embedVideoSizeCache[url]; } var videoFileHeaderInfoCache = {}; function getVideoFileHeader(url) { videoFileHeaderInfoCache[url] = videoFileHeaderInfoCache[url] || new Promise(resolve => { var xhr = new XMLHttpRequest(); xhr.open('HEAD', url, true); xhr.onreadystatechange = function () { if (this.readyState === 4) { if (this.status === 200) { var res = { type: xhr.getResponseHeader('Content-Type') }; var title; var header = xhr.getAllResponseHeaders(); if (header && (header.indexOf('inline') !== -1 || header.indexOf('attachment') !== -1)) { var filenameRegex = /filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/; var matches = filenameRegex.exec(header); if (matches != null && matches[1]) { title = matches[1].replace(/['"]/g, ''); } } else { title = url.split('/').filter(x => !!x).pop() || ''; title = title.split('?').shift(); title = decodeURIComponent(title); } if (title) res.title = title; resolve(res); } else { resolve({ error: "STATUS_" + this.status }) } } }; xhr.send(); }); return videoFileHeaderInfoCache[url]; } function getVideoPreview(url) { return new Promise((resolve, reject) => { var renderDiv = (0,ACore._)({ style: { position: 'fixed', left: 0, top: 0, overflow: 'hidden', 'z-index': -1000, pointerEvents: 'none', visibility: 'hidden' } }).addTo(document.body); var videoElt = (0,ACore._)({ tag: 'video', attr: { crossorigin: "anonymous", crossOrigin: "anonymous", preload: 'metadata', src: url }, on: { loadeddata: function () { clearTimeout(timeout); var scale = Math.min(200, videoElt.videoWidth, videoElt.videoHeight) / videoElt.videoWidth; var cWidth = Math.ceil(videoElt.videoWidth * scale); var cHeight = Math.ceil(videoElt.videoHeight * scale); var canvas = (0,ACore._)({ tag: 'canvas', attr: { width: cWidth + 'px', height: cHeight + 'px' } }).addTo(renderDiv); var ctx = canvas.getContext('2d'); ctx.drawImage(videoElt, 0, 0, cWidth, cHeight); var image = canvas.toDataURL('image/jpeg', 0.1) renderDiv.remove(); resolve({ width: videoElt.videoWidth, height: videoElt.videoHeight, image: image }); }, error: function () { clearTimeout(timeout); renderDiv.remove(); reject(); } } }); renderDiv.addChild(videoElt); videoElt.currentTime = 0.1; var timeout = setTimeout(() => { renderDiv.remove(); reject(); }, 5000); }); } ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/videourldialog/VideoUrlDialog.js /*** * @extends Fragment * @constructor */ function VideoUrlDialog() { Fragment/* default.call */.Z.call(this); this.task = null; this.pendingResult = null; Object.keys(VideoUrlDialog.prototype).filter(key => key.startsWith('ev_')).forEach(key => { this[key] = this[key].bind(this); }); } OOP/* default.mixClass */.ZP.mixClass(VideoUrlDialog, Fragment/* default */.Z); VideoUrlDialog.prototype.cache = {}; VideoUrlDialog.prototype.createView = function () { this.$view = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, class: 'as-video-url-dialog-modal', child: { tag: MessageDialog/* default.tag */.Z.tag, class: 'as-video-url-dialog', props: { dialogTitle: 'Video', dialogActions: [ { text: 'OK', name: 'ok' }, { text: 'Cancel', name: 'cancel' } ] }, child: [ { class: 'as-video-url-dialog-row', child: [ { tag: 'label', child: { text: 'URL*' } }, { tag: 'input', attr: { type: 'text' }, class: ['as-video-url-dialog-url', 'as-text-input'], } ] }, { class: 'as-video-url-dialog-row', child: [ { tag: 'label', child: { text: 'Video Info' } }, { tag: 'span', class: ['as-video-url-dialog-video-info'], } ] }, { class: 'as-video-url-dialog-row', child: [ { tag: 'label', child: { text: 'Display Size' } }, { tag: 'input', class: ['as-text-input', 'as-video-url-dialog-width'], attr: { type: 'number', min: '4' } }, { tag: 'span', child: { text: ' x ' } }, { tag: 'input', class: ['as-text-input', 'as-video-url-dialog-height'], attr: { type: 'number', min: '3' } }, { tag: 'checkbox', style: { marginLeft: '1em' }, props: { text: 'keep ratio' } } ] }, { class: 'as-video-url-dialog-row', child: [ { tag: 'label', child: { text: 'Preview' } }, { tag: 'img', class: 'as-video-url-dialog-video-image' }] } ] } }); var keyTimeout = -1; this.$urlInput = (0,ACore.$)('.as-video-url-dialog-url', this.$view) .on('paste', (event) => { setTimeout(this.ev_urlChange.bind(this, event), 100); }) .on('change', this.ev_urlChange) .on('keyup', (event) => { if (keyTimeout > 0) { clearTimeout(keyTimeout); } keyTimeout = setTimeout(() => { keyTimeout = -1; this.ev_urlChange(event); }, 300); }); this.$dialog = (0,ACore.$)('.as-video-url-dialog', this.$view) .on('action', this.ev_action); this.$info = (0,ACore.$)('.as-video-url-dialog-video-info', this.$view); this.$image = (0,ACore.$)('.as-video-url-dialog-video-image', this.$view); this.$width = (0,ACore.$)('.as-video-url-dialog-width', this.$view) .on('change', this.ev_widthChange); this.$height = (0,ACore.$)('.as-video-url-dialog-height', this.$view) .on('change', this.ev_heightChange); this.$ratio = (0,ACore.$)('checkbox', this.$view) .on('change', this.ev_widthChange); this.$actionBtns = (0,ACore.$$)('.as-message-dialog-footer button', this.$view); this.$okBtn = this.$actionBtns[0]; }; VideoUrlDialog.prototype.onStart = function () { if (this.$view) { this.$urlInput.value = ''; this.$width.value = ''; this.$height.value = ''; this.$info.innerHTML = ''; this.$image.attr('src', undefined); this.$okBtn.disabled = true; } this._prevUrl = null; }; VideoUrlDialog.prototype.onResume = function () { document.body.appendChild(this.getView()); /*var testcase = [ 'https://www.facebook.com/watch?v=794088524953444', 'https://www.youtube.com/watch?v=_YzngEllRgM&list=RDGMEMQ1dJ7wXfLlqCjwV0xfSNbAVMX8mhF6HgzVA&index=14', 'https://vimeo.com/735513454', 'https://www.dailymotion.com/video/x8d2trt', 'https://www.youtube.com/embed/AoN__ZtGenc', 'https://www.youtube.com', 'https://absol.cf/share/10h.mp4(1).mp4', 'https://absol.cf/share', 'https://www.facebook.com/watch?v=386823333524397' ] this.$urlInput.value = testcase[0]; this.ev_urlChange();*/ }; VideoUrlDialog.prototype.onPause = function () { this.getView().remove(); }; VideoUrlDialog.prototype.resolveCurrentTask = function (result) { if (this.task) { this.task.resolve(result || this.pendingResult); this.task = null; } }; VideoUrlDialog.prototype.cancelCurrentTask = function () { if (this.task) { this.task.cancel(); this.task = null; } }; VideoUrlDialog.prototype.assignTask = function (task) { this.cancelCurrentTask(); this._prevUrl = null; this.task = task; if (task.initInfo) this.onInfo(task.initInfo); }; VideoUrlDialog.prototype.onInfo = function (info){ this.getView(); this._prevUrl = info.url; if (info.error) { this.pendingResult = null; this.$image.attr('src', undefined); this.$info.innerHTML = '<span style="color:#ff2c2c">Can not load video!</span>'; return; } this.pendingResult = info; if (info.image) this.$image.attr('src', info.image); else { this.$image.attr('src', undefined); } var infoText = []; if ((0,utils.isRealNumber)(info.width) && (0,utils.isRealNumber)(info.height)) { infoText.push([info.width, ' x ', info.height].join('')); } if ('displayWidth' in info){ this.$width.value = info.displayWidth; this.$height.value = info.displayHeight; this.$urlInput.value = info.url; } else if ((0,utils.isRealNumber)(info.width) && (0,utils.isRealNumber)(info.height)) { infoText.push([info.width, ' x ', info.height].join('')); this.$width.value = info.width; this.$height.value = info.height; this.$ratio.checked = true; } else { this.$width.value = 560; this.$height.value = 315; } if ('keepRatio' in info){ this.$ratio.checked = true; } if (info.type.startsWith('video/')) { infoText.push(info.type.substring(6).toUpperCase()); } if (info.title) { infoText.push('<strong>' + info.title + '</strong>'); } this.$info.innerHTML = infoText.join(', '); this.$okBtn.disabled = false; } /*** * @param event */ VideoUrlDialog.prototype.ev_urlChange = function (event) { var newUrl = this.$urlInput.value; if (this._prevUrl === newUrl) return; this.$okBtn.disabled = true; this._prevUrl = newUrl; var info = parseVideoUrl(newUrl); var sync; if (info.videoId === 'INVALID_URL') { info.error = 'INVALID_URL'; sync = Promise.resolve(); } else if (info.hostType !== '*') { info.type = 'text/html'; sync = getEmbedVideoInfo(info.originalUrl, info.hostType === 'facebook').then((result) => { if (newUrl !== this._prevUrl) return; Object.assign(info, result); if (!(0,utils.isNaturalNumber)(result.width)) { info.error = "INVALID_VIDEO"; } }); } else { sync = getVideoFileHeader(info.url).then(result => { if (newUrl !== this._prevUrl) return; Object.assign(info, result); if (result.error) { this.$info.innerHTML = '<span style="color:#ff2c2c">Can not load video!</span>'; } }).then(() => { if (newUrl !== this._prevUrl) return; if (info.error) return; if (info.type.startsWith('video/')) return getVideoPreview(info.url) .then(result1 => { if (newUrl !== this._prevUrl) return; Object.assign(info, result1); }, error1 => { info.error = "CAN_NOT_LOAD"; }); }); } sync.then(() => { if (newUrl !== this._prevUrl) return; this.onInfo(info); }); }; /*** * @param event */ VideoUrlDialog.prototype.ev_action = function (event) { setTimeout(() => { var action = event.action; if (action.name === 'cancel') { this.cancelCurrentTask() } var width = parseInt(this.$width.value); var height = parseInt(this.$height.value); var result = Object.assign({}, this.pendingResult); if (!isNaN(width) && !isNaN(height)) { result.displayWidth = width; result.displayHeight = height; } else { result.displayWidth = 560; result.displayHeight = 315; } result.keepRatio = this.$ratio.checked; if (action.name === 'ok') { this.resolveCurrentTask(result); } this.stop(); }, 100) }; VideoUrlDialog.prototype.ev_widthChange = function () { if (!this.$ratio.checked || !this.pendingResult || !(0,utils.isRealNumber)(this.pendingResult.width) || !(0,utils.isRealNumber)(this.pendingResult.height)) return; var ratio = this.pendingResult.width / this.pendingResult.height; var width = parseFloat(this.$width.value); this.$height.value = Math.round(width / ratio); }; VideoUrlDialog.prototype.ev_heightChange = function () { if (!this.$ratio.checked || !this.pendingResult || !(0,utils.isRealNumber)(this.pendingResult.width) || !(0,utils.isRealNumber)(this.pendingResult.height)) return; var ratio = this.pendingResult.width / this.pendingResult.height; var height = parseFloat(this.$height.value); this.$width.value = Math.round(height * ratio); }; /*** * @type {VideoUrlDialog} */ var shareInstance; function openVideUrlDialog(initInfo) { shareInstance = shareInstance || new VideoUrlDialog(); return new Promise((rs) => { var task = { resolved: false, canceled: false, resolve: function (info) { if (this.resolved) return; this.resolved = true; rs(info); }, cancel: function () { if (this.resolved || this.canceled) return; if (shareInstance.task !== this) return; this.canceled = true; rs(null); }, initInfo: initInfo } shareInstance.start(); shareInstance.assignTask(task); }); } /* harmony default export */ const videourldialog_VideoUrlDialog = ((/* unused pure expression or super */ null && (VideoUrlDialog))); // EXTERNAL MODULE: ./node_modules/absol/src/Converter/base64.js var base64 = __webpack_require__(9959); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/VideoExtension.js var VideoExtension_name = 'video'; var VideoExtension_command = 'insert_video'; function getInfoFromCKImage(elt) { var initInfo = null; if (elt.getAttribute('data-node-type') === 'video') { initInfo = JSON.parse((0,base64.base64DecodeUnicode)(elt.getAttribute('data-info'))); initInfo.embedUrl = elt.getAttribute('data-embed-url'); initInfo.image = elt.getAttribute('src'); initInfo.image = elt.getAttribute('src'); } return initInfo; } function VideoExtension_init(editor) { editor.ui.addButton(VideoExtension_command, { label: 'Insert Video', command: VideoExtension_command, }); editor.on('doubleclick', (event) => { var info; if (event.data && event.data.element) { info = getInfoFromCKImage(event.data.element); if (info) { event.cancel(); editor.execCommand(VideoExtension_command); } } }); editor.addCommand(VideoExtension_command, { exec: function (editor) { var initInfo; var sel = editor.getSelection(); var elt; if (sel) { elt = sel.getSelectedElement(); } if (elt) { initInfo = getInfoFromCKImage(elt); } openVideUrlDialog(initInfo).then((result) => { var savedInfo = Object.assign({}, result); delete savedInfo.image; delete savedInfo.embedUrl; if (result) { var html = `<img src="${result.image}" data-type="${result.type}" \ onload="window.ckeditorVideoInit && window.ckeditorVideoInit(this)"\ data-embed-url="${result.embedUrl}"\ width="${result.displayWidth}px" height="${result.displayHeight}px"\ data-node-type="video" \ data-info="${(0,base64.base64EncodeUnicode)(JSON.stringify(savedInfo))}" >`; editor.insertHtml(html); } }); } }); } window.ckeditorVideoInit = function (elt) { (0,ACore.$)(elt); if (!elt.isDescendantOf(document.body)) return; var newElt; var type = elt.attr('data-type'); if (type.startsWith('video/')) { newElt = (0,ACore._)({ tag: 'video', attr: { crossorigin: "anonymous", crossOrigin: "anonymous", preload: 'auto', src: elt.attr('data-embed-url'), width: elt.attr('width'), height: elt.attr('height'), controls: true }, }); } else { newElt = (0,ACore._)({ tag: 'iframe', attr: { src: elt.attr('data-embed-url'), width: elt.attr('width'), height: elt.attr('height'), } }) } elt.selfReplace(newElt); } /* harmony default export */ const VideoExtension = ({ name: VideoExtension_name, command: VideoExtension_command, plugin: { init: VideoExtension_init }, extendMethods: {} }); /*** * @name variables * @type {{}} * @memberOf CKPlaceholder# */ ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MDIPicker.js /** * @extends Follower * @constructor */ function MDIPicker() { this.$searchInput = (0,ACore.$)(Searcher/* default.tag */.Z.tag, this).on('stoptyping', this.eventHandler.searchChange); this.cancelWaiting(); var bodys = (0,ACore.$$)('.as-mdi-picker-body', this); this.$body = bodys[0]; this.$searchResult = bodys[1]; this.iconItems = []; this.$icons = {}; (0,utils.getMaterialDesignIconNames)().then(iconNames => { if (!iconNames) return; var row; var iconName; for (var i = 0; i < iconNames.length; i++) { iconName = iconNames[i]; if (i % 8 === 0) row = (0,ACore._)('.as-mdi-picker-row').addTo(this.$body); this.$icons[iconName] = (0,ACore._)({ tag: 'button', class: 'as-transparent-button', child: 'span.mdi.mdi-' + iconName, attr: { 'data-icon': iconName, title: iconName } }).addTo(row); this.iconItems.push({ text: iconName, icon: iconName }); } this.updatePosition() }); this.on('click', this.eventHandler.click); } MDIPicker.tag = 'MDIPicker'.toLowerCase(); MDIPicker.render = function () { return (0,ACore._)({ tag: Follower/* default */.Z, class: 'as-mdi-picker', extendEvent: 'pick', child: [ { tag: Searcher/* default */.Z }, { class: 'as-mdi-picker-body', }, { style: { display: 'none' }, class: 'as-mdi-picker-body', } ] }); }; MDIPicker.prototype.focus = function () { this.$searchInput.focus(); }; MDIPicker.eventHandler = {}; /** * @this MDIPicker */ MDIPicker.eventHandler.searchChange = function () { var query = this.$searchInput.value; query = query.trim().toLowerCase().replace(/\s+/g, ' '); var res, row, i; var iconName; if (query.length > 0) { this.$body.addStyle('display', 'none'); this.$searchResult.clearChild().removeStyle('display'); res = (0,search/* searchListByText */.o)(query, this.iconItems); for (i = 0; i < res.length; i++) { iconName = res[i].text; if (i % 8 === 0) row = (0,ACore._)('.as-mdi-picker-row').addTo(this.$searchResult); (0,ACore._)({ tag: 'button', class: 'as-transparent-button', child: 'span.mdi.mdi-' + iconName, attr: { 'data-icon': iconName, title: iconName } }).addTo(row); } } else { this.$searchResult.addStyle('display', 'none'); this.$body.removeStyle('display'); } }; MDIPicker.eventHandler.click = function (event) { var t = event.target; while (t) { if (t === this) break; if (t.hasClass && t.hasClass('as-transparent-button')) { this.emit('pick', { icon: t.attr('data-icon') }); } t = t.parentElement; } } ACore/* default.install */.Z.install(MDIPicker); /* harmony default export */ const js_MDIPicker = (MDIPicker); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/MDIExtension.js var MDIExtension_name = 'mdi'; var MDIExtension_command = 'mdi_dialog'; function MDIExtension_init(editor) { editor.widgets.add(MDIExtension_name, { button: 'Change MDI icon', template: '<span class="mdi"></span>', allowedContent: 'span(!as-ck-widget-mdi)', requiredContent: 'span(as-ck-widget-mdi)', upcast: function (element) { return element.name === 'div' && element.hasClass('mdi'); }, }); editor.ui.addButton(MDIExtension_command, { label: 'Insert MDI', command: MDIExtension_command, }); editor.addCommand(MDIExtension_command, { exec: function (editor) { var btn = (0,ACore.$)('.cke_button.cke_button__mdi_dialog', editor.container.$); if (!btn) return;//unknown error var zIndex = (0,utils.findMaxZIndex)(btn) + 2e3; var picker = (0,ACore._)({ tag: js_MDIPicker, style: { zIndex: zIndex, }, attr: { tabindex: 1 }, on: { pick: (event) => { picker.followTarget = null; picker.selfRemove(); editor.insertHtml(`<span class="as-ck-widget-mdi mdi mdi-${event.icon}"> </span>`); } } }).addTo(document.body); picker.followTarget = btn; setTimeout(() => { picker.focus(); }, 100); picker.on('blur', () => { setTimeout(() => { if (!document.activeElement || !AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(document.activeElement, picker)) { picker.followTarget = null; picker.selfRemove(); } }, 200); }, true); } }); } /* harmony default export */ const MDIExtension = ({ init: MDIExtension_init, name: MDIExtension_name, command: MDIExtension_command, plugin: { init: MDIExtension_init } }); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DynamicCSS.js var DynamicCSS = __webpack_require__(488); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/plugins.js var ckContentStyleUrl; var ckPluginInitialized = false; var CKExtensions = [ExpressionExtension, SimpleTextExtension, VariableExtension, DynamicLinkExtension, ImageFileExtension, VideoExtension, MDIExtension]; var CKExtensionDict = CKExtensions.reduce(function (ac, cr) { ac[cr.name] = cr; return ac; }, {}); var CKStylesSetDefault = [ { name: 'Notice', element: 'p', attributes: { class: 'as-ck-alert as-variant-notice' } }, { name: 'Warning', element: 'p', attributes: { class: 'as-ck-alert as-variant-warning' } }, { name: 'Tip', element: 'p', attributes: { class: 'as-ck-alert as-variant-info' } }, { name: 'Success', element: 'p', attributes: { class: 'as-ck-alert as-variant-success' } } ]; function ckInit() { if (!window.CKEDITOR) return; if (ckPluginInitialized) return; var styleCode = ckcontentstyle_css.replace(/\$basePath/g, CKEDITOR.basePath); ckContentStyleUrl = URL.createObjectURL((0,Converter_file.stringToBlob)(styleCode, 'css')); ckPluginInitialized = true; document.head.appendChild((0,ACore._)('<link rel="stylesheet" href="' + ckContentStyleUrl + '">')); if (!CKEDITOR.stylesSet.get('as_styles_set_default')) { CKEDITOR.stylesSet.add('as_styles_set_default', CKStylesSetDefault); } CKExtensions.forEach(function (e) { if (e.plugin) { CKEDITOR.plugins.add(e.name, e.plugin); } }) } function ckMakeDefaultConfig(config, extensions, holderElt) { ckInit(); var userImageFileDialog = !!(window.contentModule && window.contentModule.chooseFile); /* * if (!this.attributes.directUpload && window.contentModule && window.contentModule.chooseFile) { window.contentModule.chooseFile({ type: "image_file" }).then(function (result) { if (result) { this.attributes.value = result; } }.bind(this)); } * */ config = config || {}; //disable special chars encode config.entities = false; config.stylesSet = ['as_styles_set_default'].concat((0,DataStructure_Array.arrayUnique)((config.stylesSet || '').trim().split(/\s*,\s*/))) .filter(function (c) { return !!c; }).join(','); if (extensions) extensions.push('video'); if (extensions) extensions.push('mdi'); if (extensions && extensions.indexOf(VariableExtension.name) >= 0) { config.title = false; } if (config.toolbar === 'SIMPLE') { config.toolbar = [ { name: 'basicstyles', items: ['Bold', 'Italic', 'Underline', 'TextColor', 'BGColor', 'NumberedList', 'BulletedList', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock', userImageFileDialog ? 'image_mgn_dialog' : 'Image'] }, // { name: 'styles', items: ['Styles', 'Format', 'Font', 'FontSize'] }, { name: "extensions", items: extensions.map(function (eName) { if (CKExtensionDict[eName] && CKExtensionDict[eName].command) { return CKExtensionDict[eName].command; } }).filter(function (u) { return !!u; }) }, { name: 'tools', items: ['Maximize'] } ]; } else if (config.toolbar === 'BASIC') { config.toolbar = [ { name: 'basicstyles', items: ['Bold', 'Italic', 'Underline', 'TextColor', 'BGColor', 'NumberedList', 'BulletedList', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock', userImageFileDialog ? 'image_mgn_dialog' : 'Image'] }, { name: 'styles', items: ['Format', 'Font', 'FontSize'] }, { name: "paragraph", items: ['Paragraph'] }, { name: "extensions", items: extensions.map(function (eName) { if (CKExtensionDict[eName] && CKExtensionDict[eName].command) { return CKExtensionDict[eName].command; } }).filter(function (u) { return !!u; }) }, { name: 'tools', items: ['Maximize'] } ]; } else if (!config.toolbar || config.toolbar === "ADVANCED") { config.toolbar = [ { name: 'basicstyles', items: ['Bold', 'Italic', 'Underline', 'Strike', 'Subscript', 'Superscript'] }, { name: 'colors', items: ['TextColor', 'BGColor'] }, { name: "format", items: ['CopyFormatting', 'RemoveFormat'] }, { name: 'paragraph', items: ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', '-', 'Blockquote', 'CreateDiv', '-', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock'] }, { name: 'styles', items: ['Styles', 'Format', 'Font', 'FontSize'] }, { name: 'links', items: ['Link', 'Unlink', 'Anchor'] }, { name: 'insert', items: [userImageFileDialog ? 'image_mgn_dialog' : 'Image', 'Table', 'HorizontalRule', 'Smiley', 'SpecialChar', 'PageBreak', 'Iframe'] }, { name: 'tools', items: ['Maximize', 'ShowBlocks'] }, { name: 'editing', items: ['Find', 'Replace'] }, { name: "extensions", items: extensions.map(function (eName) { if (CKExtensionDict[eName] && CKExtensionDict[eName].command) { return CKExtensionDict[eName].command; } }).filter(function (u) { return !!u; }) }, { name: 'document', items: ['Source'] } ]; console.log(config.toolbar) } config.toolbar = config.toolbar.filter(function (i) { return i.items && i.items.length > 0; }); config.toolbar = [config.toolbar.reduce(function (ac, cr) { // if (ac.items.length > 0) // ac.items.push('-'); var items = cr.items.filter(function (it) { return it !== '-'; }); ac.items.push.apply(ac.items, items); return ac; }, { name: 'nogroup', items: [] })]; if (!config.height) { config.height = '500px'; } var contentsCss = [ckContentStyleUrl]; if (typeof config.contentsCss === "string") { contentsCss.push(config.contentsCss); } else if (config.contentsCss instanceof Array) { contentsCss.push.apply(contentsCss, config.contentsCss); } var has = contentsCss.some(function (url) { return url.indexOf('materialdesignicons') >= 0; }); if (!has) { contentsCss.push('https://absol.cf/vendor/materialdesignicons/materialdesignicons.css'); } has = contentsCss.some(function (url) { return url.indexOf('family=Material+Icons') >= 0; }); if (!has) { contentsCss.push('https://fonts.googleapis.com/icon?family=Material+Icons'); } has = contentsCss.some(function (url) { return url.indexOf(CKEDITOR.basePath + 'contents.css') >= 0; }); if (!has) { contentsCss.push(CKEDITOR.basePath + 'contents.css?time=' + Math.random()); } config.contentsCss = contentsCss; var extraPlugins = ['image_mgn']; if (holderElt.stickyToolbar && !config.height) { extraPlugins.push('autogrow'); config.autoGrow_minHeight = 400; } if (typeof config.extraPlugins === 'string') { extraPlugins.push.apply(extraPlugins, config.extraPlugins.trim().split(/\s*,\s*/)); } else if (extraPlugins instanceof Array) { extraPlugins.push.apply(extraPlugins, config.extraPlugins) } extraPlugins = extraPlugins.filter(function (c) { return typeof c === 'string' && !!c; }); CKExtensions.forEach(function (e) { if (extensions.indexOf(e.name) >= 0 && e.plugin) extraPlugins.push(e.name); }); extraPlugins = (0,DataStructure_Array.arrayUnique)(extraPlugins); config.extraPlugins = extraPlugins.join(','); config.allowedContent = true;//false: you must add button ui => bug Object.assign(config, { //style // htmlEncodeOutput: false, // entities: false, // basicEntities: false, // // config.cloudServices_uploadUrl: 'DDFFE2739B83A73DDF16AB641ECA2', // // config.cloudServices_tokenUrl: 'https://lab.daithangminh.vn/hr_system_settings/php/uploadMedia.php', // extraPlugins: 'LinkDB, Note', // filebrowserBrowseUrl: 'js/ckfinder/ckfinder.html', // filebrowserImageBrowseUrl: 'js/ckfinder/ckfinder.html?type=Images', // filebrowserFlashBrowseUrl: 'js/ckfinder/ckfinder.html?type=Flash', // filebrowserUploadUrl: 'js/ckfinder/core/connector/php/connector.php?command=QuickUpload&type=Files', // filebrowserImageUploadUrl: 'js/ckfinder/core/connector/php/connector.php?command=QuickUpload&type=Images', // filebrowserFlashUploadUrl: 'js/ckfinder/core/connector/php/connector.php?command=QuickUpload&type=Flash' }); return config; } function ckAddDefaultStyleSet(ckEditor) { } ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/CKStickyToolbarController.js function CKStickyToolbarController(holderElt) { this.editor = holderElt.editor; this.$elt = this.editor.container.$; this.activated = false; this['onScroll'] = this.onScroll.bind(this); this.trackedScroller = []; } CKStickyToolbarController.prototype.start = function () { if (this.activated) return; var c = this.$elt.parentElement; while (c) { c.addEventListener('scroll', this.onScroll); c = c.parentElement; } }; CKStickyToolbarController.prototype.stop = function () { if (!this.activated) return; while (this.trackedScroller.length > 0) { this.trackedScroller.pop().removeEventListener('scroll', this.onScroll); } }; CKStickyToolbarController.prototype.onScroll = function (event) { if (!AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(this.$elt, document.body)) { this.stop(); return; } this.$toolbar = this.$toolbar || (0,ACore.$)('.cke_top', this.$elt); if (!this.$toolbar) return; var oBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this.$elt.parentElement); var bound = this.$elt.getBoundingClientRect(); var tBound = this.$toolbar.getBoundingClientRect(); if (bound.top < oBound.top && oBound.top + tBound.height + 30 < bound.bottom) { this.$toolbar.addStyle('transform', 'translate(0, ' + ((oBound.top - bound.top)) + 'px)'); } else { this.$toolbar.removeStyle('transform'); } }; /* harmony default export */ const ckeditor_CKStickyToolbarController = (CKStickyToolbarController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/CKPlaceholder.js Dom/* default.documentReady.then */.ZP.documentReady.then(function () { setTimeout(ckInit, 100); }); /*** * @extends AElement * @constructor */ function CKPlaceholder() { ckInit(); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$attachhook.once('attached', this.eventHandler.attached); this._pendingData = ''; this.isReady = false; this.editor = null; this._extensions = []; this._config = this._makeInitConfig(); this.afterReady = new Promise(rs => { this.on('editorready', rs); }); this.stickyToolbarCtrl = null; /*** * @type {{}} * @name config * @memberOf CKPlaceholder# */ /*** * @type {string[]} * @name extensions * @memberOf CKPlaceholder# */ /*** * * @type {boolean} */ this.stickyToolbar = true; } CKPlaceholder.tag = 'CKPlaceholder'.toLowerCase(); CKPlaceholder.render = function () { return (0,ACore._)({ extendEvent: ['editorcreated', 'editorready', 'change', 'command', 'focus'], class: 'as-ck-placeholder' }); }; CKPlaceholder.prototype.mode = 'replace'; /** * * @param {string}data * @private * @returns {string} */ CKPlaceholder.prototype._implicit = function (data) { if (typeof data !== "string") data = ''; var self = this; return this._extensions.reverse().reduce(function (ac, cr) { var extension = CKExtensionDict[cr]; if (extension.implicit) { ac = extension.implicit(ac, self); } return ac; }, data); }; /** * * @param {string}data * @private * @returns {string} */ CKPlaceholder.prototype._explicit = function (data) { var self = this; return this._extensions.reduce(function (ac, cr) { var extension = CKExtensionDict[cr]; if (extension && extension.explicit) { ac = extension.explicit(ac, self); } return ac; }, data); }; /*** * @returns {{}} * @protected */ CKPlaceholder.prototype._makeInitConfig = function () { return {}; }; CKPlaceholder.prototype.selectNext = function () { var editor = this.editor; if (!editor) return; var ranges = editor.getSelection().getRanges(); // var startIndex = editor.element.getHtml().indexOf(findString); // if (startIndex != -1) { // ranges[0].setStart(element.getFirst(), startIndex); // ranges[0].setEnd(element.getFirst(), startIndex + findString.length); // sel.selectRanges([ranges[0]]); // } }; /*** * @memberOf CKPlaceholder# * @type {{}} */ CKPlaceholder.eventHandler = {}; /*** * @this CKPlaceholder */ CKPlaceholder.eventHandler.attached = function () { this.$attachhook.remove(); var config = this.config; var width = this.style.width; if (width.endsWith('px')) config.width = width; var height = this.style.height; if (height.endsWith('px')) config.height = height; config = ckMakeDefaultConfig(this.config, this.extensions, this); this.editor = this.mode === 'replace' ? CKEDITOR.replace(this, config) : CKEDITOR.inline(this, config); this.editor.placeHolderElt = this; this.editor.on('instanceReady', this.eventHandler.instanceReady); this.editor.on('change', this.eventHandler.change); if (this.mode === 'replace') { this.editor.on('focus', function (event) { this.emit('focus', { target: this, type: 'focus', originalEvent: event }); }.bind(this)); } this._extensions.forEach(function (name) { var e = CKExtensionDict[name]; if (e && e.extendMethods) { Object.assign(this, e.extendMethods); } }.bind(this)); this.emit('editorcreated', { type: 'editorcreated', target: this, editor: this.editor }, this); }; CKPlaceholder.eventHandler.instanceReady = function () { var width = this.style.width; if (width.endsWith('px')) width = parseFloat(width.replace('px')); var height = this.style.height; if (height.endsWith('px')) height = parseFloat(height.replace('px')); if ((0,utils.isRealNumber)(width) && (0,utils.isRealNumber)(height)) { this.editor.resize(width, height); } this.isReady = true; if (this._pendingData && this._pendingData.length > 0) { this.editor.setData(this._implicit(this._pendingData)); this._pendingData = null; } this.emit('editorready', { type: 'editorready', target: this, editor: this.editor }, this); }; CKPlaceholder.eventHandler.change = function () { this.emit('change', { type: 'change', target: this, editor: this.editor }, this); }; CKPlaceholder.property = {}; CKPlaceholder.property.data = { /*** * @this CKPlaceholder * @param data */ set: function (data) { if (typeof data !== "string") data = ''; if (this.isReady) { this.editor.setData(this._implicit(data)); } else { this._pendingData = data; } }, /*** * @this CKPlaceholder * @returns {string} */ get: function () { if (this.isReady) return this._explicit(this.editor.getData()); return this._pendingData; } }; CKPlaceholder.property.rawData = { get: function () { if (this.editor) this.editor.getData(); else return this._implicit(this._pendingData); } }; CKPlaceholder.property.config = { set: function (value) { if (this.editor) { throw new Error("Can not set config after the CKEditor created"); } this._config = Object.assign(this._makeInitConfig(), value); }, get: function () { return this._config; } }; CKPlaceholder.property.extensions = { set: function (value) { if (this.editor) { throw new Error("Can not set extensions after the CKEditor created"); } value = value || []; if (typeof value === "string") value = [value]; if (!(value instanceof Array)) value = []; this._extensions = value.filter(function (c) { return typeof c === "string" && c.length > 0 && CKExtensionDict[c]; }); this._extensions = value; }, get: function () { return this._extensions; } }; CKPlaceholder.property.stickyToolbar = { set: function (value) { if (value) { this.addClass('as-has-sticky-toolbar'); } else { return this.removeClass('as-has-sticky-toolbar'); } this.afterReady.then(() => { if (this.mode !== 'replace') return; if (this.stickyToolbar) { if (!this.stickyToolbarCtrl) { this.stickyToolbarCtrl = new ckeditor_CKStickyToolbarController(this); } this.stickyToolbarCtrl.start(); } else { this.editor.container.$.classList.remove('as-has-sticky-toolbar'); if (this.stickyToolbarCtrl) this.stickyToolbarCtrl.stop(); } }); }, get: function () { return this.hasClass('as-has-sticky-toolbar'); } }; ACore/* default.install */.Z.install(CKPlaceholder); /* harmony default export */ const ckeditor_CKPlaceholder = (CKPlaceholder); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ckeditor/CKInlineShortText.js /*** * @extends CKPlaceholder * @constructor */ function CKInlineShortText() { ckeditor_CKPlaceholder.call(this); this.once('editorcreated', this.eventHandler.afterEditorCreated) .on('paste', this.eventHandler.paste, true) .once('editorready', this.eventHandler.afterEditorReady); } OOP/* default.mixClass */.ZP.mixClass(CKInlineShortText, ckeditor_CKPlaceholder); CKInlineShortText.tag = 'CKInlineShortText'.toLowerCase(); CKInlineShortText.property = Object.assign({}, ckeditor_CKPlaceholder.property); CKInlineShortText.eventHandler = Object.assign({}, ckeditor_CKPlaceholder.eventHandler); CKInlineShortText.render = function () { return (0,ACore._)({ class: 'as-ck-inline-short-text', extendEvent: ['editorcreated', 'editorready', 'change', 'command'], id: (0,stringGenerate.randomIdent)(8), attr: { contenteditable: 'true' } }); }; CKInlineShortText.prototype.mode = 'inline'; CKInlineShortText.prototype._makeInitConfig = function () { var config = { toolbar: [ { name: 'extension', items: (0,DataStructure_Array.arrayRemoveNone)(this._extensions.map(function (eName) { if (CKExtensionDict[eName] && CKExtensionDict[eName].command) { return CKExtensionDict[eName].command; } })) } ], keystrokes: [ [13 /* Enter */, 'blur'], [CKEDITOR.SHIFT + 13 /* Shift + Enter */, 'blur'] ] }; return config; }; CKInlineShortText.property.extensions = Object.assign({}, ckeditor_CKPlaceholder.property.extensions, { set: function (value) { value = value || []; value.push('simple_text') value = (0,DataStructure_Array.arrayUnique)(value); ckeditor_CKPlaceholder.property.extensions.set.call(this, value); this._config = this._makeInitConfig(); } }); CKInlineShortText.prototype._hookScroll = function () { this.$scrollers = []; var c = this.parentElement; while (c) { this.$scrollers.push(c); c = c.parentElement; } this.$scrollers.push(document); this.$scrollers.forEach(function (elt) { elt.addEventListener('scroll', this.eventHandler.scroll); }.bind(this)) }; CKInlineShortText.prototype._unhookScroll = function () { this.$scrollers.forEach(function (elt) { elt.removeEventListener('scroll', this.eventHandler.scroll); }.bind(this)) }; CKInlineShortText.eventHandler.afterEditorCreated = function () { this.editor.on('paste', function (evt) { evt.cancel(); }); }; CKInlineShortText.eventHandler.afterEditorReady = function (){ this.$toolbarElt = this.$toolbarElt || (0,ACore.$)('#cke_' + this.attr('id')); this['removeToolbar'] = this.removeToolbar; this._hookScroll(); setTimeout(this.eventHandler.tick, 5000); } CKInlineShortText.eventHandler.paste = function (event) { var self = this; var clipboardData = (event.clipboardData || window.clipboardData); /**Safari bug */ event.preventDefault(); if (clipboardData) { if (clipboardData.items) { var items = Array.prototype.slice.call(clipboardData.items); var plainTextItems = items.filter(function (item) { return item.type.indexOf('text/plain') >= 0; }); if (plainTextItems.length > 0) { var plainTextItem = plainTextItems[0];//only one item plainTextItem.getAsString(function (text) { self.editor.insertHtml(self._implicit(text)) }); } } else { var text = event.clipboardData.getData('text/plain'); if (text) { self.editor.insertHtml(self._implicit(text)) } } } }; CKInlineShortText.eventHandler.tick = function () { if (!this.isDescendantOf(document.body)) { this._unhookScroll(); return; } setTimeout(this.eventHandler.tick, 5000); } /*** * @this CKInlineShortText */ CKInlineShortText.eventHandler.scroll = function () { // If we don't have any active instance of CKEDITOR - return if (!CKEDITOR.currentInstance) { return; } if (CKEDITOR.currentInstance.element.$ !== this) return; // Save the elements we need to work with if (!this.isDescendantOf(document.body)) { this._unhookScroll(); return; } this.$toolbarElt = this.$toolbarElt || (0,ACore.$)('#cke_' + this.attr('id')); var toolbarElt = this.$toolbarElt; if (!toolbarElt) return; var bound = this.getBoundingClientRect(); var toolBound = toolbarElt.getBoundingClientRect(); var outbound = (0,Dom/* traceOutBoundingClientRect */.DI)(this); var left = Math.max(0, bound.left); var top = bound.top - toolBound.height; if (outbound.top > bound.bottom || outbound.bottom < bound.top) { top = -1000; } else if (bound.top < toolBound.height) { top = bound.bottom; } toolbarElt.addStyle({ top: top + 'px', left: left + 'px' }); }; CKInlineShortText.property.removeToolbar = { set: function (value) { this._removeToolbar = !!value; if (this.$toolbarElt) { if (this._removeToolbar) { this.$toolbarElt.addClass('as-hidden'); } else { this.$toolbarElt.removeClass('as-hidden'); } } }, get: function () { return this._removeToolbar; } }; ACore/* default.install */.Z.install(CKInlineShortText); /* harmony default export */ const ckeditor_CKInlineShortText = (CKInlineShortText); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/verticaltimeline.css var verticaltimeline = __webpack_require__(5386); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/VerticalTimeline.js /*** * @extends AElement * @constructor */ function VerticalTimeline() { this._current = 0; this._items = []; this.$items = []; this.current = 0; } VerticalTimeline.tag = 'VerticalTimeline'.toLowerCase(); VerticalTimeline.render = function () { return (0,ACore._)({ class: 'as-vertical-timeline', child: [] }); }; VerticalTimeline.prototype._makeItem = function (item, i) { var iconElt = (0,ACore._)('span.mdi.mdi-circle'); return (0,ACore._)({ class: 'as-vertical-timeline-item', props: { $icon: iconElt }, child: [ { class: 'as-vertical-timeline-icon-ctn', child: iconElt }, { class: 'as-vertical-timeline-tile', child: { tag: 'span', child: { text: item.text } } } ] }); }; VerticalTimeline.property = {}; VerticalTimeline.property.items = { /*** * @this VerticalTimeline * @param items */ set: function (items) { items = items || []; this._items = items; this.clearChild(); this.$items = items.map(function (item, i) { return this._makeItem(item, i); }.bind(this)); this.addChild(this.$items); this.current = this._current;//update }, get: function () { } }; VerticalTimeline.property.current = { set: function (value) { value = (0,utils.isRealNumber)(value) ? (value >> 0) : -1; this._current = value; var itemElt; for (var i = 0; i < this.$items.length; ++i) { itemElt = this.$items[i];//.$icon.removeClass(''); if (i < value) { itemElt.$icon.removeClass('mdi-numeric-' + (i + 1) + '-circle') .removeClass('mdi-circle') .addClass('mdi-check-circle'); itemElt.removeClass('as-inactive').removeClass('as-active'); } else if (i === value) { itemElt.$icon.addClass('mdi-numeric-' + (i + 1) + '-circle') .removeClass('mdi-circle') .removeClass('mdi-check-circle'); itemElt.removeClass('as-inactive').addClass('as-active'); } else { itemElt.addClass('as-inactive').removeClass('as-active'); itemElt.$icon.removeClass('mdi-numeric-' + (i + 1) + '-circle') .addClass('mdi-circle') .removeClass('mdi-check-circle'); } } }, get: function () { return Math.max(-1, Math.min(this._current, this._items.length)); } }; ACore/* default.install */.Z.install(VerticalTimeline); /* harmony default export */ const js_VerticalTimeline = (VerticalTimeline); // EXTERNAL MODULE: ./node_modules/absol/src/Color/Color.js var Color_Color = __webpack_require__(257); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/locationinput.css var locationinput = __webpack_require__(4899); // EXTERNAL MODULE: ./node_modules/absol/src/Network/XLoader.js var XLoader = __webpack_require__(9238); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LocationPicker.js ///https://developers.google.com/maps/documentation/javascript/examples/geocoding-place-id var googleMapLibs = null; function getGoogleMapLib() { var jsElt; if (!googleMapLibs) { if (window.google && window.google.maps) { return Promise.resolve(window.google.maps); } else { jsElt = Array.prototype.find.call(document.head.childNodes, elt => { if ((typeof elt.src === "string") && elt.src.startsWith('https://maps.googleapis.com/maps/api/js')) return jsElt; }); if (jsElt) { return new Promise((resolve, reject) => { if (jsElt.readyState) { //IE jsElt.onreadystatechange = function () { if (jsElt.readyState === "loaded" || jsElt.readyState === "complete") { jsElt.onreadystatechange = null; resolve(); } }; } else { //Others var onLoad = () => { resolve(); jsElt.removeEventListener('load', onLoad); } jsElt.addEventListener('load', onLoad); } }) } else { throw new Error("Could not detect Google Map API!"); } } } return googleMapLibs; } var googleMarkerLibSync = null; function getGoogleMarkerLib() { if (!googleMarkerLibSync) googleMarkerLibSync = getGoogleMapLib() .then(() => google.maps.importLibrary("marker")) .then((mdl) => { google.maps.marker = mdl; return mdl; }); return googleMarkerLibSync; } var googlePlacesLibSync; function getGooglePlacesLib() { if (!googlePlacesLibSync) googlePlacesLibSync = getGoogleMapLib() .then(() => { if (google.maps.places) { } else { return google.maps.importLibrary("places").then((mdl) => { google.maps.places = mdl; return mdl; }); } }); return googleMarkerLibSync; } function createMyLocationMarkerContent() { var svgTxt = `<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"> <circle r="10" cx="12" cy="12" style="stroke: white; stroke-width: 2px; fill: #1da1ff"></circle> </svg>`; return (0,ACore._)(svgTxt); } /*** * @extends AElement * @constructor */ function LocationPicker() { getGoogleMarkerLib(); if (BrowserDetector/* default.isMobile */.Z.isMobile) { this.addClass('as-mobile'); } this.map = new google.maps.Map(this, { mapId: (0,stringGenerate.randomIdent)(),//'DEMO_MAP_ID', zoom: 8, scaleControl: true, center: new google.maps.LatLng(21.018755, 105.839729), streetViewControl: false, fullscreenControl: false, mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.TOP_RIGHT, } }); this.map.setOptions({ draggableCursor: 'default' }); this.map.addListener('click', this.eventHandler.clickMap); this.geocoder = new google.maps.Geocoder(); this.infoWindow = new google.maps.InfoWindow(); this.$myLocationBtn = (0,ACore._)({ tag: 'button', class: 'as-location-picker-control-btn', child: 'span.mdi.mdi-crosshairs-gps', on: { click: this.selectMyLocation.bind(this) } }); this.$rightBottomCtn = (0,ACore._)({ class: 'as-location-picker-control-ctn', child: [this.$myLocationBtn], style: { overflow: 'hidden' } }); this.$searchInput = (0,ACore._)({ tag: js_AutoCompleteInput.tag, class: 'as-location-picker-search-input', props: { adapter: this }, child: { class: 'as-location-picker-search-input-search-icon-ctn', child: 'span.mdi.mdi-magnify', on: { click: this.eventHandler.search } }, on: { change: this.eventHandler.searchChange } }); this.$searchInput.$input.on('keydown', this.eventHandler.searchKeypress) this.$topLeftCtn = (0,ACore._)({ class: ['as-location-picker-control-ctn', 'as-top'], child: [ this.$searchInput ] }); this.$okBtn = (0,ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, class: 'primary', props: { text: 'OK', disabled: true }, on: { click: this.eventHandler.clickAction.bind(this, 'OK') } } ); this.$cancelBtn = (0,ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, class: ['as-location-picker-cancel-btn', 'secondary'], props: { text: 'CANCEL' }, on: { click: this.eventHandler.clickAction.bind(this, 'CANCEL') } } ); this.$bottomLeftCtn = (0,ACore._)({ class: ['as-location-picker-control-ctn', 'as-transparent', 'as-bottom'], style: { paddingBottom: '5px' }, child: [this.$okBtn, this.$cancelBtn] }); this.map.controls[google.maps.ControlPosition.RIGHT_BOTTOM].push(this.$rightBottomCtn); this.map.controls[google.maps.ControlPosition.TOP_LEFT].push(this.$topLeftCtn); this.map.controls[google.maps.ControlPosition.BOTTOM_LEFT].push(this.$bottomLeftCtn); this.autoCompleteService = new google.maps.places.AutocompleteService(this.map, { fields: ["place_id", "geometry", "name", "formatted_address"] }); this.placeService = new google.maps.places.PlacesService(this.map); this.selectedMarker = null; this.searchingMarkers = []; this.myLocationMarker = null; /*** * @type {LatLng} * @name value * @memberOf LocationPicker# */ /*** * @type {boolean} * @name readOnly * @memberOf LocationPicker# */ } LocationPicker.tag = 'LocationPicker'.toLowerCase(); LocationPicker.render = function () { return (0,ACore._)({ class: 'as-location-picker', extendEvent: ['action', 'location', 'requestlocation', 'error'] }); }; LocationPicker.prototype.queryItems = function (query) { var latLng = (0,utils.parseDMS)(query) || (0,utils.parseLatLng)(query); if (latLng) { return new Promise(resolve => { this.geocoder.geocode({ location: (0,utils.implicitLatLng)(latLng) }, (results, status) => { if (status === google.maps.GeocoderStatus.OK) { results.forEach(it => { it.description = it.formatted_address; }); resolve(results); // Returns an array of place predictions } return resolve([]); }); }); } var request = { input: query, locationBias: this.map.getBounds() }; return new Promise( (resolve)=> { this.autoCompleteService.getPlacePredictions(request, function (results, status) { if (status === google.maps.places.PlacesServiceStatus.OK) { resolve(results); } else resolve([]); }); }); }; LocationPicker.prototype.getItemText = function (item, mInput) { return item.description; }; LocationPicker.prototype.getItemView = function (item, index, _, $, query, reuseItem, refParent, mInput) { return _({ class: 'as-place-search-auto-complete-item', child: [ { class: 'as-place-search-auto-complete-item-desc', child: { text: item.description } } ] }); }; LocationPicker.prototype.getBoundsZoomLevel = function (bounds) { var mapDim = this.getBoundingClientRect(); return (0,utils.getMapZoomLevel)(mapDim, bounds); } LocationPicker.prototype.clearSearchingMarkers = function () { while (this.searchingMarkers.length > 0) { this.searchingMarkers.pop().setMap(null); } }; /** * * @param place * @param {boolean=} panTo */ LocationPicker.prototype.selectPlace = function (place, panTo) { if (arguments.length === 1) panTo = true; return getGoogleMarkerLib().then(() => { this.selectedPlace = place || null; if (this.selectedMarker) { this.selectedMarker.setMap(null); } this.$okBtn.disabled = !this.selectedPlace; if (!place) return; var latLng = place.geometry && place.geometry.location; if (!latLng) return; var zoom = panTo && (place.geometry.bounds || place.geometry.viewport) ? this.getBoundsZoomLevel(place.geometry.bounds || place.geometry.viewport) : 18; if (panTo) { this.map.setZoom(zoom); setTimeout(() => { this.map.panTo(latLng); }, 100) } this.selectedMarker = new google.maps.marker.AdvancedMarkerElement({ map: this.map, position: latLng }); this.infoWindow.setContent((place.name ? place.name + ' - ' : '') + place.formatted_address); this.infoWindow.open(this.map, this.selectedMarker); }); }; LocationPicker.prototype.showSearchPlaces = function (places) { this.clearSearchingMarkers(); if (!places || places.length === 0) return; if (places.length === 1) { this.selectPlace(places[0]); return; } var bounds = places.reduce(function (ac, place) { if (place.geometry && place.geometry.location) ac.extend(place.geometry.location); return ac; }, new google.maps.LatLngBounds()); var zoom = places.length === 1 ? ((places[0].geometry.bounds || places[0].geometry.viewport) ? this.getBoundsZoomLevel((places[0].geometry.bounds || places[0].geometry.viewport)) : 18) : this.getBoundsZoomLevel(bounds); var center = places.length === 1 ? places[0].geometry.location : bounds.getCenter(); this.map.setCenter(center); this.map.setZoom(zoom); places.reduce(function (ac, place, i) { var marker; if (place.geometry && place.geometry.location) { marker = new google.maps.marker.AdvancedMarkerElement({ map: this.map, position: place.geometry.location, // icon: 'https://raw.githubusercontent.com/Concept211/Google-Maps-Markers/master/images/marker_black.png' }); ac.push(marker); marker.addListener('click', this.eventHandler.clickMarker.bind(null, marker, place)); } return ac; }.bind(this), this.searchingMarkers); }; /*** * * @param {string} placeId * @param {boolean=} panTo */ LocationPicker.prototype.selectPlaceId = function (placeId, panTo) { if (arguments.length === 1) panTo = true; return new Promise((resolve) => { this.placeService.getDetails({ placeId: placeId, fields: ["name", "formatted_address", "place_id", "geometry"] }, (place, status) => { if ( status === google.maps.places.PlacesServiceStatus.OK && place && place.geometry && place.geometry.location ) { this.selectPlace(place, panTo).then(() => { resolve(true); }); } else { resolve(false); } }); }) }; /*** * * @param latLng * @param {boolean=} panTo */ LocationPicker.prototype.selectLocation = function (latLng, panTo) { if (arguments.length === 1) panTo = true; if (arguments.length === 1) panTo = true; return getGoogleMarkerLib().then(() => { if (this.selectedMarker) { this.selectedMarker.setMap(null); } this.$okBtn.disabled = !latLng; this.selectedPlace = null; if (!latLng) return; this.selectedPlace = { geometry: { location: latLng } }; var zoom = 18; if (panTo) { this.map.setZoom(zoom); setTimeout(() => { this.map.panTo(latLng); }, 100) } this.selectedMarker = new google.maps.marker.AdvancedMarkerElement({ map: this.map, position: latLng }); }); // this.infoWindow.open(this.map, this.selectedMarker); /* return this.geocoder .geocode({ location: latLng }) .then(function (response) { if (response.results[0]) { return this.selectPlaceId(response.results[0].place_id, panTo); } else { return false; } }.bind(this)) .catch(function (e) { safeThrow(e); return false; }); */ }; LocationPicker.prototype.watchMyLocation = function (location, position) { return getGoogleMarkerLib().then(() => { if (this.myLocationMarker) return; this.accuracyCircle = new google.maps.Circle({ strokeColor: "#1988c3", strokeOpacity: 0.4, strokeWeight: 2, fillColor: "#1988c3", fillOpacity: 0.2, radius: 100, map: this.map, clickable: false }); this.accuracyCircle.setEditable(false); this.myLocationMarker = new google.maps.marker.AdvancedMarkerElement({ position: location, title: "My Location", // sName: "My Location", map: this.map, content: createMyLocationMarkerContent() }); if (position && position.coords) { this.accuracyCircle.setRadius(position.coords.accuracy); // Snackbar.show('Accuracy: ' + position.coords.accuracy.toFixed(1) + '(m)'); } var id; if (navigator.geolocation.watchPosition && navigator.geolocation.watchPosition) { id = navigator.geolocation.watchPosition(function (props) { if (!this.isDescendantOf(document.body)) { navigator.geolocation.clearWatch(id); } this.emit('location_now', { location: props.coords }); this.myLocationMarker.position = new google.maps.LatLng(props.coords.latitude, props.coords.longitude); this.accuracyCircle.setCenter(new google.maps.LatLng(props.coords.latitude, props.coords.longitude)); this.accuracyCircle.setRadius(props.coords.accuracy); // Snackbar.show('Sai số tọa độ: ' + props.coords.accuracy.toFixed(1) + ' mét'); }.bind(this), function () { }, { enableHighAccuracy: false, timeout: 5000, maximumAge: 0 }); } }) } LocationPicker.prototype.selectMyLocation = function () { var id = (0,stringGenerate.randomIdent)(); this.emit('requestlocation', { id: id }); if (navigator.geolocation) { var to = setTimeout(() => { this.emit('error', Object.assign(new Error("GPS không phản hồi!"), { id: id })); }, 10000); navigator.geolocation.getCurrentPosition((position) => { clearTimeout(to); var location = null; if (position && position.coords) { this.emit('location', { location: position.coords, id: id }); location = new google.maps.LatLng(position.coords.latitude, position.coords.longitude); } if (location) { this.watchMyLocation(location, position); if (!this.readOnly) this.selectLocation(location); else { this.map.setCenter(location) } } }, (err) => { clearTimeout(to); if (err && err.message.indexOf('denied') >= 0) err = Object.assign(new Error("Yêu cầu lấy tọa độ bị từ chối!"), { id: id }); this.emit('error', err); }, { maximumAge: Infinity }); } }; LocationPicker.property = {}; LocationPicker.property.zoom = { set: function (value) { if (!(0,utils.isRealNumber)(value)) { value = 1; } this.map.setZoom(value); }, get: function () { return this.map.getZoom(); } }; LocationPicker.property.center = { set: function (value) { value = value || null; var latlng = null; if (value instanceof google.maps.LatLng) { latlng = value; } else if (value && (0,utils.isRealNumber)(value.latitude) && (0,utils.isRealNumber)(value.longitude)) { latlng = new google.maps.LatLng(value.latitude, value.longitude); } else if ((value instanceof Array) && (0,utils.isRealNumber)(value[0]) && (0,utils.isRealNumber)(value[1])) { latlng = new google.maps.LatLng(value[0], value[1]); } latlng = latlng || new google.maps.LatLng(21.018755, 105.839729); this.map.setCenter(latlng || new google.maps.LatLng(21.018755, 105.839729)); }, get: function () { return this.map.getCenter(); } }; LocationPicker.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; /*** * * @type {{}} * @memberOf LocationPicker# */ LocationPicker.eventHandler = {}; /*** * @this LocationPicker */ LocationPicker.eventHandler.searchKeypress = function (event) { if (event.key === 'Enter') setTimeout(function () { if (!this.$searchInput.selectedItem) { this.eventHandler.search(); } }.bind(this), 100); }; LocationPicker.eventHandler.searchChange = function () { var item = this.$searchInput.selectedItem; if (!item) return; this.placeService.getDetails({ placeId: item.place_id, fields: ["name", "formatted_address", "place_id", "geometry"] }, function (place, status) { if ( status === google.maps.places.PlacesServiceStatus.OK && place && place.geometry && place.geometry.location ) { this.selectPlace(place); } }.bind(this)); }; /*** * @this LocationPicker */ LocationPicker.eventHandler.search = function () { var request = { bounds: this.map.getBounds(), query: this.$searchInput.value }; if (!request.query) return; this.placeService.textSearch(request, function callback(results, status) { if (status === google.maps.places.PlacesServiceStatus.OK) { this.showSearchPlaces(results); } }.bind((this))); }; LocationPicker.eventHandler.clickMarker = function (marker, place) { if (this.readOnly) return; this.selectPlace(place, false); }; LocationPicker.eventHandler.clickMap = function (event) { if (this.readOnly) return; if (event.placeId) { this.selectPlaceId(event.placeId); } else if (event.latLng) { this.selectLocation(event.latLng, false); } } ; LocationPicker.eventHandler.clickAction = function (action, event) { this.emit('action', { type: 'action', action: action, originalEvent: event, target: this }, this); }; ACore/* default.install */.Z.install(LocationPicker); /* harmony default export */ const js_LocationPicker = (LocationPicker); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LocationView.js var MARKER_RADIUS = 10; var MARKER_BORDER_COLOR = '#4945C8'; function generateColor(id) { id = id + ''; var rgb = [0, 0, 0]; var res; var white = Color_Color/* default.parse */.Z.parse('white'); var c = 100; while (c--) { for (var i = 0; i < id.length; ++i) { rgb[i % 3] = (rgb[i % 3] * 31 + id.charCodeAt(i) * 173) % 255; } res = new Color_Color/* default */.Z([rgb[0] / 255, rgb[1] / 255, rgb[2] / 255, 1]); if (res.getContrastWith(white) > 2 && rgb[0] + rgb[1] + rgb[2] > 50) { break; } } return res; } function distanceInPixels(zoom, latLng1, latLng2) { // Calculate the geographical distance in meters var R = 6371000; // Earth's radius in meters var lat1 = latLng1.lat() * Math.PI / 180; var lat2 = latLng2.lat() * Math.PI / 180; var deltaLat = (latLng2.lat() - latLng1.lat()) * Math.PI / 180; var deltaLng = (latLng2.lng() - latLng1.lng()) * Math.PI / 180; var a = Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) + Math.cos(lat1) * Math.cos(lat2) * Math.sin(deltaLng / 2) * Math.sin(deltaLng / 2); var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); var distanceInMeters = R * c; // Calculate the resolution (meters per pixel) var scale = 156543.03392 * Math.cos(lat1) / Math.pow(2, zoom); // Convert meters to pixels return distanceInMeters / scale; } // https://lab.daithangminh.vn/home_co/carddone/markerclusterer.js var loadMarkerClustererSync = null; var lastOpenInfo = null; /*** * * @param {LocationView} viewerElt * @param {Object} data * @constructor */ function LVPolyline(viewerElt, data) { this.viewerElt = viewerElt; this.map = viewerElt.map; this._polylines = []; this.id = data.id || (0,stringGenerate.randomIdent)(12); this.polylineData = { geodesic: true, strokeColor: data.color || generateColor(this.id).toString('hex6'), strokeOpacity: 1.0, strokeWeight: 2, }; this.polylineData.path = data.path.map(function (crd) { return (0,utils.implicitLatLng)(crd); }); this.polylineHL = new google.maps.Polyline(Object.assign({}, this.polylineData, { strokeColor: 'white', strokeWeight: 5 })); this.polyline = new google.maps.Polyline(this.polylineData); this.template = (0,ACore._)({ style: { position: 'relative', }, child: { tag: 'div', style: { width: `${MARKER_RADIUS * 2}px`, height: `${MARKER_RADIUS * 2}px`, position: 'absolute', top: `${-MARKER_RADIUS}px`, left: `${-MARKER_RADIUS}px`, borderRadius: '50%', backgroundColor: this.polylineData.strokeColor, border: `2px solid ${MARKER_BORDER_COLOR}`, boxSizing: 'border-box', } } }); this.markers = this.polylineData.path.map(function (crd, i) { var anchor = this.template.cloneNode(true); var mkr = new google.maps.marker.AdvancedMarkerElement({ position: crd, map: this.map, content: anchor, }); var infoWindow; if (data.path[i] && data.path[i].info) { infoWindow = new google.maps.InfoWindow(data.path[i].info); anchor.addEventListener('mouseover', function () { if (lastOpenInfo === infoWindow) return; try { if (lastOpenInfo) lastOpenInfo.close(); } catch (e) { } lastOpenInfo = infoWindow; infoWindow.open({ anchor: mkr, map: this.map, shouldFocus: true }); }) } return mkr; }.bind(this)); this.showRoute = viewerElt.showPolylineRoute; } LVPolyline.prototype.remove = function () { this.polyline.setMap(null); this.polylineHL.setMap(null); this.markers.forEach(function (mk) { mk.setMap(null); }) }; Object.defineProperty(LVPolyline.prototype, 'showRoute', { set: function (value) { this._showRoute = !!value; if (value) { this.polylineHL.setMap(this.map); this.polyline.setMap(this.map); } else { this.polylineHL.setMap(null); this.polyline.setMap(null); } }, get: function () { return this._showRoute; } }); Object.defineProperty(LVPolyline.prototype, 'color', { get: function () { return this.polylineData.strokeColor; } }); Object.defineProperty(LVPolyline.prototype, 'sumDistance', { get: function () { var res = 0; var path = this.polylineData.path; for (var i = 1; i < path.length; ++i) { res += (0,utils.latLngDistance)(path[i - 1], path[i]); } return res; } }); function LVPoints(viewerElt, data) { this.data = data; this.refData = [data]; this.id = data.id || (0,stringGenerate.randomIdent)(12); this.latLng = (0,utils.implicitLatLng)(data); if (!this.latLng) { console.error('Invalid data', data); return; } this.map = viewerElt.map; this.viewNumber = 0; } LVPoints.prototype.numberToHue = function (number) { var res = 0; var hs = 1; for (var i = 0; (i < 4 && number > 1); ++i) { hs *= 10; res += Math.log(Math.min(number, hs)) / Math.log(hs) * 0.25; number -= hs; } res = Math.min(0.8, res); return res; }; LVPoints.prototype.number2Image = function (number) { var data = this.data; var color = number === 1 ? data.color || generateColor(this.id).toString() : Color_Color/* default.fromHSL */.Z.fromHSL(this.numberToHue(number), 1, 0.5).toString(); try { color = Color_Color/* default.parse */.Z.parse(color); } catch (e) { color = number === 1 ? generateColor(this.id) : Color_Color/* default.fromHSL */.Z.fromHSL(this.numberToHue(number), 1, 0.4) } var textColor = color.getContrastYIQ().toString('hex8'); color = color.toString('hex8'); var outLineCount; var radius; if (number <= 1) { outLineCount = 0; radius = 10; } else { outLineCount = ((number + '').length); radius = 5 + outLineCount * 2; } var canvasSize = 2 * (radius + 5 * outLineCount + 2); var res = { tag: 'svg', style: { position: 'absolute', top: '50%', left: '50%', transform: 'translate(-50%, -50%)', cursor: 'pointer' }, attr: { width: canvasSize + '', height: canvasSize + '', viewBox: [-canvasSize / 2, -canvasSize / 2, canvasSize, canvasSize].join(' ') }, child: [ { tag: 'circle', attr: { cx: 0, cy: 0, r: radius, }, style: { fill: color, stroke: number === 1 ? 'white' : 'none', 'stroke-width': number === 1 ? 4 : 0, } } ] }; var path, r; var j, sAngle, eAngle; var angle; var delta = 2 * Math.PI / 5; for (var i = 0; i < outLineCount; ++i) { angle = -Math.PI / 2 - delta / 2; r = radius + 3 + i * 5; path = ''; for (j = 0; j < 5; ++j) { angle += delta; sAngle = angle + 0.1; eAngle = angle + delta - 0.1; path += ['M', Math.cos(sAngle) * r, Math.sin(sAngle) * r].join(' ') + ' '; path += ['A', r, r, 0, 0, 1, Math.cos(eAngle) * r, Math.sin(eAngle) * r].join(' ') + ' '; } res.child.push({ tag: 'path', style: { fill: 'none', stroke: color, 'stroke-width': 4 }, attr: { d: path, opacity: 0.5 - 0.5 * i / outLineCount, }, }); } if (number > 1) { res.child.push({ tag: 'text', attr: { x: 0, y: 0, 'dominant-baseline': 'middle', 'text-anchor': 'middle', fill: textColor, 'font-size': 10, 'font-weight': 'bold' }, child: { text: number + '' } }) } return Svg/* default.ShareInstance._ */.ZP.ShareInstance._(res); }; /** * * @param {number} number - <0: not show> */ LVPoints.prototype.view = function (number) { if (!(0,utils.isRealNumber)(number)) number = 0; number = Math.max(0, Math.floor(number)); if (this.viewNumber === number) return; this.viewNumber = number; var data = this.data; if (this.marker) { this.marker.setMap(null); this.marker = null; this.content = null; } if (number <= 0) return; this.content = this.number2Image(number); this.marker = new google.maps.marker.AdvancedMarkerElement({ position: this.latLng, map: this.map, content: this.content, }); this.marker.getMap = this.marker.getMap || (function () { return this.map; }); this.marker.getPosition = () => { return this.latLng; } this.marker.setMap(this.map); if (number === 1) { if (this.data.info && !this.infoWindow) { this.infoWindow = new google.maps.InfoWindow(this.data.info); } if (this.infoWindow ) { this.content.on('mouseover', () => { if (lastOpenInfo === this.infoWindow) return; try { if (lastOpenInfo) lastOpenInfo.close(); } catch (e) { } lastOpenInfo = this.infoWindow; this.infoWindow.open({ anchor: this.marker, map: this.map, shouldFocus: true }); }) } } else if (number >1) { this.content.on('click', ()=>{ this.map.setCenter(this.latLng); this.map.setZoom(this.map.getZoom()+1); }) } } LVPoints.prototype.remove = function () { if (this.marker) this.marker.setMap(null); this.content = null; this.marker = null; this.infoWindow = null; } /** * * @param {LocationView} lvElt * @param {LVPoints[]} points * @constructor */ function LVCluster(lvElt, points) { this.lvElt = lvElt; this.points = points; /** * * @type {Object<string, LVPoints>} */ this.pointDict = this.points.reduce((ac, cr) => { ac[cr.id] = cr; return ac; }, {}) this.viewingPoints = {}; this.map = lvElt.map; this.zoom = this.map.getZoom(); this.bounds = this.map.getBounds(); this.idleTO = -1; this.onIdle = this.onIdle.bind(this); } LVCluster.prototype.onProcessed = function () { if (this.idleTO >= 0) { clearTimeout(this.idleTO); } this.idleTO = setTimeout(this.onIdle, 500); }; LVCluster.prototype.onIdle = function () { this.idleTO = -1; this.bounds = this.map.getBounds(); this.zoom = this.map.getZoom(); if (!this.bounds) return; var newViewPoints = this.points.reduce((ac, point) => { if (!this.bounds.contains(point.latLng)) return ac; var rPoint; for (var rId in ac) { rPoint = this.pointDict[rId]; if (distanceInPixels(this.zoom, rPoint.latLng, point.latLng) < 50) { ac[rId]++; return ac; } } ac[point.id] = 1; return ac; }, {}); var id; var oldViewPoints = this.viewingPoints; for (id in oldViewPoints) { if (!newViewPoints[id]) { if (this.pointDict[id]) { this.pointDict[id].view(0); } } } for (id in newViewPoints) { if (this.pointDict[id]) { this.pointDict[id].view(newViewPoints[id]); } } this.viewingPoints = newViewPoints; }; /*** * @extends AElement * @constructor */ function LocationView() { this.map = new google.maps.Map(this, { zoom: 8, center: new google.maps.LatLng(21.018755, 105.839729), scaleControl: true, mapId: (0,stringGenerate.randomIdent)() }); google.maps.event.addListener(this.map, "zoom_changed", this.eventHandler.mapZoomChanged); google.maps.event.addListener(this.map, 'bounds_changed', this.eventHandler.mapBoundsChanged); this.marker = null; this._value = null; this.$domSignal = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); /*** * @type {LatLng} * @name value * @memberOf LocationView# */ /**** * * @type {LVPolyline[]} */ this.$polylines = []; this._showPolylineRoute = true; /**** * * @type {LVPoints[]} */ this.$points = []; } LocationView.tag = 'LocationView'.toLowerCase(); LocationView.render = function () { return (0,ACore._)({ class: 'as-location-view' }); }; LocationView.prototype.getPolylineById = function (id) { return this.$polylines.find(function (pll) { return pll.id === id; }) || null; }; LocationView.prototype.getPolylines = function () { return this.$polylines.slice(); }; LocationView.property = {}; LocationView.property.zoom = { set: function (value) { if (!(0,utils.isRealNumber)(value)) { value = 1; } this.map.setZoom(value); }, get: function () { return this.map.getZoom(); } }; LocationView.property.value = { set: function (value) { value = value || null; var latlng = (0,utils.implicitLatLng)(value); latlng = latlng || new google.maps.LatLng(21.018755, 105.839729); this.map.setCenter(latlng || new google.maps.LatLng(21.018755, 105.839729)); this._value = value; getGoogleMarkerLib().then(() => { if (this.marker) { this.marker.setMap(null); this.marker = null; } if (latlng && value) { this.marker = new google.maps.marker.AdvancedMarkerElement({ map: this.map, position: latlng, }); } }) }, get: function () { return this._value; } }; LocationView.property.polylines = { set: function (polylines) { this._polylines = polylines || []; this.$polylines.forEach(function (pll) { pll.remove(); }); getGoogleMarkerLib().then(() => { this.$polylines = polylines.map(function (pll) { return new LVPolyline(this, pll); }.bind(this)); var zoom; var center; var points = this.$polylines.reduce(function (ac, $polyline) { return ac.concat($polyline.polylineData.path); }, []); var bounds = points.reduce(function (ac, cr) { ac.extend(cr); return ac; }, new google.maps.LatLngBounds()); this.domSignal.once('update_view', function () { if (points.length > 1) { zoom = (0,utils.getMapZoomLevel)(this.getBoundingClientRect(), bounds); center = bounds.getCenter(); } else { zoom = 17; center = points[0] || new google.maps.LatLng(21.018755, 105.839729); } zoom = Math.min(zoom, 17); this.map.setZoom(zoom); this.map.setCenter(center); }.bind(this), 100); this.domSignal.emit('update_view'); }) }, get: function () { return this._polylines; } }; LocationView.property.showPolylineRoute = { set: function (value) { this._showPolylineRoute = !!value; this.$polylines.forEach(function (pll) { pll.showRoute = value; }) }, /** * @this LocationView * @returns {*|boolean} */ get: function () { return this._showPolylineRoute; } }; LocationView.property.points = { /** * @this LocationView * @param points */ set: function (points) { this.$points.forEach(function (point) { point.remove(); }); this._points = points || []; getGoogleMarkerLib().then(() => { var now = Date.now(); var rp = this._points.reduce(function (ac, pointData) { var id = pointData.id; var point; if (id && ac.dict[id]) { ac.dict[id].refData.push(pointData); } else { point = new LVPoints(this, pointData); ac.dict[point.id] = point; ac.arr.push(point); } return ac; }.bind(this), { arr: [], dict: {} }); this.$points = rp.arr; var zoom; var center; var latLngs = this.$points.map(function (p) { return p.latLng; }, []).filter(function (x) { return !!x; }); var bounds = latLngs.reduce(function (ac, cr) { ac.extend(cr); return ac; }, new google.maps.LatLngBounds()); this.pointsCluster = new LVCluster(this, this.$points); console.log('set points', Date.now() - now); this.domSignal.once('update_view', function () { if (points.length > 1) { zoom = (0,utils.getMapZoomLevel)(this.getBoundingClientRect(), bounds); center = bounds.getCenter(); } else { zoom = 17; center = points[0] || new google.maps.LatLng(21.018755, 105.839729); } zoom = Math.min(zoom, 17); this.map.setZoom(zoom); this.map.setCenter(center); if (this.pointsCluster) this.pointsCluster.onProcessed(); }.bind(this), 100); this.domSignal.emit('update_view'); }); }, get: function () { return this._points; } } LocationView.eventHandler = {}; LocationView.eventHandler.mapZoomChanged = function () { if (this.pointsCluster) this.pointsCluster.onProcessed(); // var now = Date.now(); // var eltRect = Rectangle.fromClientRect(this.getBoundingClientRect()); // var bounds = this.map.getBounds(); // // var mapRect = new Rectangle() // // console.log('zoom changed', Date.now() - now); }; LocationView.eventHandler.mapBoundsChanged = function () { if (this.pointsCluster) this.pointsCluster.onProcessed(); }; ACore/* default.install */.Z.install(LocationView); /* harmony default export */ const js_LocationView = (LocationView); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/adapter/PlaceSearchAutoCompleteAdapter.js /*** * * @param {PlaceSearchAutoCompleteInput} inputElt * @constructor */ function PlaceSearchAutoCompleteAdapter(inputElt) { this.inputElt = inputElt; this.service = new google.maps.places.AutocompleteService(this.inputElt.$service); } PlaceSearchAutoCompleteAdapter.prototype.queryItems = function (query, mInput) { var request = { input: query, }; return new Promise(function (resolve) { this.service.getPlacePredictions(request, function (results, status) { if (status === google.maps.places.PlacesServiceStatus.OK) { resolve(results); } else resolve([]); }); }.bind(this)); }; PlaceSearchAutoCompleteAdapter.prototype.getItemText = function (item, mInput) { return item.description; }; PlaceSearchAutoCompleteAdapter.prototype.getItemView = function (item, index, _, $, query, reuseItem, refParent, mInput) { return _({ class: 'as-place-search-auto-complete-item', child: [ { class: 'as-place-search-auto-complete-item-desc', child: { text: item.description } } ] }) }; /* harmony default export */ const adapter_PlaceSearchAutoCompleteAdapter = (PlaceSearchAutoCompleteAdapter); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/placesearchautocomplete.css var placesearchautocomplete = __webpack_require__(8677); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PlaceSearchAutoCompleteInput.js /*** * @extends AutoCompleteInput * @constructor */ function PlaceSearchAutoCompleteInput() { this.$service = (0,ACore._)('.as-place-search-auto-complete-input-service'); this.insertBefore(this.$service, null); this.adapter = new adapter_PlaceSearchAutoCompleteAdapter(this); } PlaceSearchAutoCompleteInput.tag = 'PlaceSearchAutoCompleteInput'.toLowerCase(); PlaceSearchAutoCompleteInput.render = function () { return (0,ACore._)({ tag: js_AutoCompleteInput.tag }, true); } ACore/* default.install */.Z.install(PlaceSearchAutoCompleteInput); /* harmony default export */ const js_PlaceSearchAutoCompleteInput = (PlaceSearchAutoCompleteInput); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LocationInput.js function LocationInput() { this.$text = (0,ACore.$)('input', this) .on('change', this.eventHandler.textChange); this.$iconCtn = (0,ACore.$)('.as-location-input-icon-ctn', this) .on('click', this.eventHandler.clickIcon); /*** * @type {{latitude: number, longitude: number}} * @name latLng * @memberOf LocationInput# */ /*** * @type {string} * @name value * @memberOf LocationInput# */ /*** * @type {boolean} * @name readOnly * @memberOf LocationInput# */ } LocationInput.tag = 'LocationInput'.toLowerCase(); LocationInput.render = function () { return (0,ACore._)({ class: 'as-location-input', extendEvent: ['change'], child: [ { tag: 'input', attr: { type: 'text' }, class: 'as-location-input-text' }, { class: 'as-location-input-icon-ctn', child: 'span.mdi.mdi-google-maps' } ] }); }; LocationInput.prototype.share = { $modal: null, $picker: null, $holder: null }; LocationInput.prototype._preparePicker = function () { if (this.share.$picker) return; this.share.$picker = (0,ACore._)({ tag: js_LocationPicker.tag }); this.share.$modal = (0,ACore._)({ tag: 'modal', class: 'as-location-input-modal', child: { class: 'as-location-input-modal-window', child: this.share.$picker } }); if (BrowserDetector/* default.isMobile */.Z.isMobile) { this.share.$modal.addClass('as-mobile'); } }; /*** * @this LocationInput * @private */ LocationInput.prototype._attachPicker = function () { if (this.share.$holder) { this.share.$holder._releasePicker(); } this._preparePicker(); this.share.$holder = this; this.$iconCtn.off('click', this.eventHandler.clickIcon); document.body.appendChild(this.share.$modal); this.share.$picker.on('action', this.eventHandler.pickerAction); this.share.$picker.$searchInput.value = ''; this.share.$picker.readOnly = this.readOnly; setTimeout(function () { document.addEventListener('click', this.eventHandler.clickOut); }.bind(this), 100); var value = this.latLng; if (value) { value = new google.maps.LatLng(value.latitude, value.longitude); } if (value) this.share.$picker.selectLocation(value, true); else this.share.$picker.selectPlace(null); }; LocationInput.prototype._releasePicker = function () { if (this.share.$holder !== this) return; this.share.$picker.off('action', this.eventHandler.pickerAction); this.$iconCtn.on('click', this.eventHandler.clickIcon); document.removeEventListener('click', this.eventHandler.clickOut) this.share.$modal.remove(); this.share.$holder = null; }; /** * * @type {{}} * @memberOf LocationInput# */ LocationInput.eventHandler = {}; LocationInput.eventHandler.pickerAction = function (event) { if (!this.readOnly && event.action === 'OK' && this.share.$picker.selectedPlace && this.share.$picker.selectedPlace.geometry && this.share.$picker.selectedPlace.geometry.location) { this.$text.value = [this.share.$picker.selectedPlace.geometry.location.lat(), this.share.$picker.selectedPlace.geometry.location.lng()].join(', '); this.emit('change', { type: 'change', originalEvent: event.originalEvent || event, target: this }, this); } this._releasePicker(); }; /*** * @this LocationInput */ LocationInput.eventHandler.clickIcon = function () { this._attachPicker(); }; /*** * @this LocationInput * @param event */ LocationInput.eventHandler.clickOut = function (event) { if (event.target === this.share.$modal) this._releasePicker(); }; LocationInput.eventHandler.textChange = function (event) { this.emit('change', { type: 'change', originalEvent: event.originalEvent || event, target: this }, this); }; LocationInput.property = {}; LocationInput.property.value = { set: function (value) { value = value || null; var lat, lng; if (typeof value === "string") { this.$text.value = value; return; } if (value instanceof Array) { lat = value[0]; lng = value[1]; } else if (value && typeof value === 'object') { if (('latitude' in value) && ('longitude' in value)) { lat = value.latitude; lng = value.longitude; } else if (value instanceof google.maps.LatLng) { lat = value.lat(); lng = value.lng(); } } if ((0,utils.isRealNumber)(lat) && (0,utils.isRealNumber)(lng)) { this.$text.value = [lat, lng].join(', '); } else { this.$text.value = ''; } }, get: function () { var text = this.$text.value; return (0,utils.normalizeLatLngString)(text); } }; LocationInput.property.latLng = { get: function () { var text = this.$text.value; return (0,utils.parseDMS)(text) || (0,utils.parseLatLng)(text); } }; LocationInput.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } this.$text.readOnly = !!value; }, get: function () { return this.hasClass('as-read-only'); } }; LocationInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } this.$text.disabled = !!value; }, get: function () { return this.hasClass('as-disabled'); } }; ACore/* default.install */.Z.install(LocationInput); /* harmony default export */ const js_LocationInput = (LocationInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/mknavigator.css var mknavigator = __webpack_require__(9907); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MKNavigatorItem.js /*** * @extends AElement * @constructor */ function MKNavigatorItem() { this._data = []; this.$text = (0,ACore.$)('.mk-nav-item-text', this); this.$switchCtn = (0,ACore.$)('.mk-nav-item-switch-ctn', this); this.$switch = (0,ACore.$)('switch', this) .on('change', this.eventHandler.switchChange); this.$dragzone = (0,ACore.$)('.mk-nav-item-drag-zone', this); this.on('click', this.eventHandler.click); } MKNavigatorItem.tag = 'MKNavigatorItem'.toLowerCase(); MKNavigatorItem.render = function () { return (0,ACore._)({ tag: Board/* default.tag */.Z.tag, class: 'mk-nav-item', extendEvent: ['checkedchange', 'press'], child: [ { class: ['mk-nav-item-drag-zone', BoardTable/* default.DRAG_ZONE_CLASS_NAME */.ZP.DRAG_ZONE_CLASS_NAME], child: '<i class="material-icons">drag_indicator</i>' }, { class: 'mk-nav-item-text-ctn', child: { tag: 'span', class: 'mk-nav-item-text', child: { text: '' } } }, { class: 'mk-nav-item-switch-ctn', child: { tag: js_Switch.tag } } ] }); }; MKNavigatorItem.prototype.updateText = function () { this.$text.firstChild.data = this._data.text; }; MKNavigatorItem.prototype.updateChecked = function () { if (typeof this._data.checked === "boolean") { this.$switchCtn.removeStyle('display'); this.$switch.checked = this._data.checked; } else { this.$switchCtn.addStyle('display', 'none'); } }; MKNavigatorItem.prototype.updateDraggable = function () { if (this._data.draggable) { this.$dragzone.removeStyle('display'); } else { this.$dragzone.addStyle('display', 'none'); } }; MKNavigatorItem.property = {}; MKNavigatorItem.property.data = { /** * @this MKNavigatorItem * @param data */ set: function (data) { data = data || {}; this._data = data; this.updateText(); this.updateChecked(); this.updateDraggable(); }, get: function () { return this._data; } }; /*** * @memberOf MKNavigatorItem# * @type {{}} */ MKNavigatorItem.eventHandler = {}; MKNavigatorItem.eventHandler.switchChange = function (event) { this._data.checked = this.$switch.checked; this.emit('checkedchange', { type: 'checkedchange' }, this); }; MKNavigatorItem.eventHandler.click = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$switch, event) || (0,EventEmitter/* hitElement */.EY)(this.$dragzone, event)) return; this.emit('press', { type: 'press', target: this, originalEvent: event }, this); } ACore/* default.install */.Z.install(MKNavigatorItem); /* harmony default export */ const js_MKNavigatorItem = (MKNavigatorItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MKNavigator.js /*** * @typedef MKNavigatorItemData * @property {string} text * @property {string|number} value * @property {boolean|number=} checked */ /*** * @extends AElement * @constructor */ function MKNavigator() { this._items = []; this._value = 0; this._hiddenValues = []; this.$itemByValue = {}; this.$header = (0,ACore.$)('.mk-nav-header', this); this.$body = (0,ACore.$)('.mk-nav-body', this) .on('orderchange', this.eventHandler.bodyOrderChange) .on('dragitemstart', this.eventHandler.dragItemStart); this.$footer = (0,ACore.$)('.mk-nav-footer', this); this.on('press', (event, sender) => { this.emit('clickitem', event, sender); }); /*** * @type {MKNavigatorItemData[]} * @name item * @memberOf MKNavigator# */ /*** * @type {number[]} * @name order * @memberOf MKNavigator# */ } MKNavigator.tag = 'MKNavigator'.toLowerCase(); MKNavigator.render = function () { return (0,ACore._)({ class: 'mk-nav', extendEvent: ['orderchange', 'checkedchange', 'press', 'clickitem'], child: [ { class: 'mk-nav-header' }, { tag: BoardTable/* default.tag */.ZP.tag, class: 'mk-nav-body' }, { class: 'mk-nav-footer' } ] }); }; MKNavigator.prototype.updateValue = function () { var value = this._value; for (var iValue in this.$itemByValue) { if (iValue + '' !== value + '') { this.$itemByValue[iValue].removeClass('mk-current'); } } var order = this.order; if (this.$itemByValue[value]) { this.$itemByValue[value].addClass('mk-current'); } else if (order.length > 0) { this.$itemByValue[order[0]].addClass('mk-current'); } var idx = order.filter(value => !this.$itemByValue[value].hasClass('as-hidden')).indexOf(value); if (idx >= 0) { this.addStyle('--mk-nav-line-top', `calc(${2 * idx}em + ${12 * idx}px)`); } else { this.removeStyle('--mk-nav-line-top'); } }; MKNavigator.prototype.setTextOfItem = function (value, text) { var itemElt = this.$itemByValue[value]; if (!itemElt) return; itemElt.data.text = text; itemElt.updateText(); }; MKNavigator.prototype.mkItem = function (data) { var self = this; return (0,ACore._)({ tag: js_MKNavigatorItem.tag, attr: { "data-value": data && data.value }, props: { data: data }, on: { checkedchange: function (event) { self.emit('checkedchange', { type: 'checkedchange', target: this, originalEvent: event.originalEvent, itemData: data, checked: data.checked }, self); }, press: function (event) { self.value = data.value; self.emit('press', { type: 'press', itemElt: this, itemData: data, value: data.value, target: this, originalEvent: event.originalEvent }, self) } } }); }; MKNavigator.prototype._updateHiddenValues = function () { var hiddenDict = this._hiddenValues.reduce((ac, x) => { ac[x] = true; return ac; }, {}) Object.keys(this.$itemByValue).forEach(value => { if (hiddenDict[value]) { this.$itemByValue[value].addClass('as-hidden'); } else { this.$itemByValue[value].removeClass('as-hidden'); } }); }; MKNavigator.property = {}; MKNavigator.property.items = { /*** * @this MKNavigator * @param items */ set: function (items) { items = items || []; this._items = items; this.$itemByValue = {}; var i = 0; var item; var itemElt; this.$header.clearChild(); this.$body.clearChild(); this.$footer.clearChild(); var draggable = false; var maxTextWidth = items.reduce((ac, it) => { var tw = (0,utils.measureText)(it.text || '').width; return Math.max(ac, tw); }, 0); this.addStyle('--max-text-width', Math.ceil(maxTextWidth) + 'px'); while (i < items.length) { if (items[i].draggable) break; item = items[i]; itemElt = this.mkItem(item); this.$itemByValue[item.value] = itemElt; this.$header.addChild(itemElt); ++i; } while (i < items.length) { if (!items[i].draggable) break; draggable = true; item = items[i]; itemElt = this.mkItem(item); this.$itemByValue[item.value] = itemElt; this.$body.addChild(itemElt); ++i; } while (i < items.length) { item = items[i]; itemElt = this.mkItem(item) this.$itemByValue[item.value] = itemElt; this.$footer.addChild(itemElt); ++i; } if (draggable) { this.addClass('mk-has-draggable'); } else { this.removeClass('mk-has-draggable'); } this._updateHiddenValues(); }, get: function () { return this._items; } }; MKNavigator.property.order = { get: function () { return (0,ACore.$$)(js_MKNavigatorItem.tag, this).map(function (e) { return e.data.value; }); } }; MKNavigator.property.value = { set: function (value) { this._value = value; this.updateValue(); }, get: function () { if (this.$itemByValue[this._value]) return this._value; if (this._items.length > 0) return this._items[0]; return this._value; } }; MKNavigator.property.hiddenValues = { set: function (values) { values = values || []; if (!(values instanceof Array)) values = []; this._hiddenValues = values; this._updateHiddenValues(); this.updateValue(); }, get: function () { return this._hiddenValues; } } /*** * @memberOf MKNavigator# * @type {{}} */ MKNavigator.eventHandler = {}; MKNavigator.eventHandler.bodyOrderChange = function (event) { this.updateValue(); this._items.splice(0, this._items.length); (0,ACore.$$)(js_MKNavigatorItem.tag, this).reduce(function (ac, cr) { ac.push(cr.data); return ac; }, this._items); this.emit('orderchange', { type: 'orderchange', target: this }, this); }; /*** * @memberOf MKNavigator# * @type {{}} */ MKNavigator.eventHandler.dragItemStart = function (event) { var bound = this.getBoundingClientRect(); this.addStyle('--mk-navigator-bound-left', bound.left + 'px'); } ACore/* default.install */.Z.install(MKNavigator); ACore/* default.install */.Z.install('mknav',MKNavigator); /* harmony default export */ const js_MKNavigator = (MKNavigator); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/processlbar.css var processlbar = __webpack_require__(4715); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ProcessLBar.js /*** * @extends AElement * @constructor */ function ProcessLBar() { this.$stepCtn = (0,ACore.$)('.as-process-l-bar-step-ctn', this); this.$stepName = (0,ACore.$)('.as-process-l-bar-step-name', this); this.$items = []; this._items = []; this._lHeight = 3; this._value = null; } ProcessLBar.tag = 'ProcessLBar'.toLowerCase(); ProcessLBar.render = function () { return (0,ACore._)({ class: 'as-process-l-bar', extendEvent: 'change', child: [ { class: 'as-process-l-bar-step-ctn' }, { class: 'as-process-l-bar-step-name' } ] }); }; ProcessLBar.prototype._updateCol = function () { var colN = Math.max(this.$items.length - this._lHeight + 1, 0); while (this.$stepCtn.childNodes.length > colN) { this.$stepCtn.lastChild.remove(); } while (this.$stepCtn.childNodes.length < colN) { this.$stepCtn.addChild((0,ACore._)('.as-process-l-bar-col')); } var i; for (i = 0; i < colN; ++i) { this.$stepCtn.childNodes[i].clearChild() .addChild(this.$items[i]) } for (i = colN; i < this.$items.length; ++i) { this.$stepCtn.lastChild.addChild(this.$items[i]); } this.nameWidth = this._items.reduce(function (ac, cr) { return Math.max(ac, (0,utils.measureText)(cr.name, 'bold 14px Arial, Helvetica, sans-serif').width); }, 0); if (colN <= 1) { this.addClass('as-col-layout'); } else { this.removeClass('as-col-layout'); } if (colN <= 2) { this.addStyle('--as-process-l-bar-item-min-width', this.nameWidth + 'px'); } else { this.addStyle('--as-process-l-bar-item-min-width', ((this.nameWidth + 10) / (colN - 1) - 10) + 'px'); } }; ProcessLBar.prototype._updateValue = function () { var value = this._value; this.$items.forEach(function (elt) { if (elt.itemData.value === value) { elt.addClass('as-active'); this.$stepName.clearChild().addChild((0,ACore._)({ tag: 'span', child: { text: elt.itemData.name } })); } else { elt.removeClass('as-active'); } }.bind(this)); }; ProcessLBar.prototype.notifyChange = function (originalEvent) { this.emit('change', { type: 'change', target: this, originalEvent: originalEvent || null }, this); }; ProcessLBar.prototype._makeItem = function (item) { var self = this; var stepElt = (0,ACore._)({ class: 'as-process-l-bar-step', attr: { title: item.name }, props: { itemData: item }, on: { click: function (event) { if (self.disabled) return; var value = this._value; if (item.value === value) return; self.value = item.value; self.notifyChange(event); } } }); if (item.color) { stepElt.addStyle('--as-process-l-bar-active-color', item.color); } return stepElt; }; ProcessLBar.property = {}; ProcessLBar.property.items = { set: function (items) { items = items || []; this._items = items; this.$itemByValue = {}; this.$items = this._items.map(function (item) { return this._makeItem(item); }.bind(this)); this._updateCol(); this._updateValue(); }, get: function () { return this._items; } }; ProcessLBar.property.value = { set: function (value) { this._value = value; this._updateValue(); }, get: function () { return this._value; } }; ProcessLBar.property.lHeight = { set: function (value) { this._lHeight = value; if (value === 1){ this.addClass('as-single-line'); } else { this.removeClass('as-single-line'); } this._updateCol(); }, get: function () { return this._lHeight; } }; ProcessLBar.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; /* harmony default export */ const js_ProcessLBar = (ProcessLBar); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/kvcommentitem.css var kvcommentitem = __webpack_require__(5021); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/KVCommentItem.js /*** * @extends AElement * @constructor */ function KVCommentItem() { this._time = new Date(); this._text = ''; this.$text = (0,ACore.$)('.kv-comment-item-text', this); this.$time = (0,ACore.$)('.kv-comment-item-time', this); this.$avatar = (0,ACore.$)('.kv-comment-avatar', this); this.quickmenu = null; this.on('contextmenu', this.eventHandler.kv_contextmenu) ContextMenu/* default.auto */.Z.auto(); } KVCommentItem.tag = 'KVCommentItem'.toLowerCase(); KVCommentItem.render = function () { return (0,ACore._)({ extendEvent:'contextmenu', class: "kv-comment-item", child: [ { class: "kv-comment-avatar-ctn", child: { class: 'kv-comment-avatar', style: { backgroundImage: 'url(https://raw.githubusercontent.com/duthienkt/absol/master/logo.svg?sanitize=true)' } } }, { class: "kv-comment-item-content", child: [ { class: 'kv-comment-item-text', child: { text: '' } }, { class: 'kv-comment-item-time', child: { text: (0,datetime.formatDateTime)(new Date(), 'dd/MM/yyyy HH:mm') } } ] }, { class: "kv-comment-item-flag-ctn", child: ['.kv-comment-item-flag-unread'] } ] }); } KVCommentItem.property = {}; KVCommentItem.property.text = { set: function (value) { value = value || ''; if (typeof value === 'string') this.$text.innerHTML = value; else if (absol.Dom.isDomNode(value)) { this.$text.clearChild().addChild(value); } else { this.$text.clearChild().addChild((0,ACore._)(value)); } this._text = value; }, get: function () { return this._text; } } KVCommentItem.property.unread = { set: function (value) { if (value) { this.addClass('as-unread'); } else { this.removeClass('as-unread'); } }, get: function () { return this.hasClass('as-unread'); } }; KVCommentItem.property.time = { set: function (value) { this._time = value; var text = ''; if (typeof value === 'string') text = value; else if (value instanceof Date){ text = (0,datetime.formatDateTime)(value, 'dd/MM/yyyy HH:mm') } this.$time.firstChild.data = text; }, get: function () { return this._time; } }; KVCommentItem.property.avatar = { set: function (value){ value = value ||'https://raw.githubusercontent.com/duthienkt/absol/master/logo.svg?sanitize=true'; this._avatar = value; this.$avatar.addStyle('backgroundImage','url('+value+')') }, get: function (){ return this._avatar; } }; /*** * @memberOf KVCommentItem# * @type {{}} */ KVCommentItem.eventHandler = {}; /*** * @this KVCommentItem * @param event */ KVCommentItem.eventHandler.kv_contextmenu = function (event){ if (this.quickmenu){ event.showContextMenu(this.quickmenu.props, function (event){ var menuItem = (0,utils.cleanMenuItemProperty)(event.menuItem); if (this.quickmenu.onSelect){ this.quickmenu.onSelect.call(this, menuItem); } }.bind(this)) } }; ACore/* default.install */.Z.install(KVCommentItem); /* harmony default export */ const js_KVCommentItem = (KVCommentItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTHeadCell.js var implicitSortKeyArr = key => { var res; if (typeof key === 'string') { res = key.split(/[\s,;]+/); } else if (key instanceof Array) { res = key.slice(); } else res = []; res = res.filter(k => !!k).map(k => k + ''); return res; } /*** * * @param {DTHeadRow} row * @param data * @constructor */ function DTHeadCell(row, data) { this.row = row; this._elt = null; this._copyElt = null; this._copyElt1 = null; this._copyElt2 = null; if (data.attr) { Object.keys(data.attr).forEach(key => { var key2 = key.toLowerCase(); if (key2 !== key) data.attr[key2] = data.attr[key]; }) } this.data = data; this._idx = null; } DTHeadCell.prototype.makeAutoSortAttribute = function () { var rows = this.row.head.table.data && this.row.head.table.data.body && this.row.head.table.data.body.rows; if (!rows || !rows.length) return; if (this.elt.attr('data-sort-key')) return; var idx = this.idx; var canSort = rows.every(row => { return row.cells[idx] && (typeof row.cells[idx].innerText === 'string'); }); if (canSort) { this.elt.attr('data-sort-key', '[' + idx + ']'); this.data.sortKey = '[' + idx + ']'; this._elt.attr('data-sort-order', 'none'); // this._elt.attr('title', 'Sort'); } }; Object.defineProperty(DTHeadCell.prototype, 'idx', { set: function (value) { this._idx = value; this.elt.attr('data-col-idx', value + ''); this.makeAutoSortAttribute(); }, get: function () { return this._idx; } }); DTHeadCell.prototype.nextSortState = function (event) { if (!this.elt.attr('data-sort-key')) return; var c = this.elt.attr('data-sort-order') || 'none'; var n = { none: 'ascending', ascending: 'descending', descending: 'none' }[c] || 'none'; var sortKeyArr = implicitSortKeyArr(this.data.sortKey || c); var sortBtn = this.$sortBtn; var followerElt, menuElt, items; if (sortKeyArr.length === 1) { (0,ACore.$$)('th', this.row.elt).forEach(elt => { if (elt === this.elt) return; if (elt.attr('data-sort-key')) { elt.attr('data-sort-order', 'none'); } }) this.elt.attr('data-sort-order', n); this.row.head.table.wrapper.requestQuery(); } else { items = [{ text: 'Không sắp xếp', value: { key: sortKeyArr.join(';'), order: 'none' }, icon: 'span.mdi.mdi-sort-variant-off' }]; if (c === 'none') { items[0].extendStyle = { color: '#007bff' }; } sortKeyArr.forEach(key => { items.push('-------'); var text = this.data.sortMenu && this.data.sortMenu[key] && this.data.sortMenu[key][0]; text = text || ("Tăng theo " + key); var item = { icon: 'span.mdi.mdi-sort-ascending', text: text, value: { key: key, order: 'ascending' } }; if (key === this.elt.attr('data-sort-key') && c === 'ascending') { item.extendStyle = { color: '#007bff' } } items.push(item); text = this.data.sortMenu && this.data.sortMenu[key] && this.data.sortMenu[key][1]; text = text || ("Tăng theo " + key); item = { icon: 'span.mdi.mdi-sort-descending', text: text, value: { key: key, order: 'descending' } }; if (key === this.elt.attr('data-sort-key') && c === 'descending') { item.extendStyle = { color: '#007bff' } } items.push(item); }); menuElt = (0,ACore._)({ tag: 'vmenu', props: { items: items }, on: { press: event => { var value = event.menuItem.value; (0,ACore.$$)('th', this.row.elt).forEach(elt => { if (elt === this.elt) return; if (elt.attr('data-sort-key')) { elt.attr('data-sort-order', 'none'); } }) this.elt.attr('data-sort-order', value.order); this.elt.attr('data-sort-key', value.key); this.row.head.table.wrapper.requestQuery(); finish(); } } }); followerElt = (0,ACore._)({ tag: Follower/* default */.Z, class: 'absol-context-menu-anchor', style: { zIndex: (0,utils.findMaxZIndex)(sortBtn) + 22 }, child: [ menuElt ], props: { followTarget: sortBtn } }).addTo(document.body); var finish = () => { document.removeEventListener('click', finish); followerElt.remove(); } setTimeout(() => { followerElt.addStyle('visibility', 'visible').addStyle('opacity', 1); }, 5) } }; DTHeadCell.prototype.updateCopyContent = function () { var makeCopyChildren = () => Array.prototype.map.call(this._elt.childNodes, elt => elt.cloneNode(true)); if (this._copyElt1) { this._copyElt1.clearChild().addChild(makeCopyChildren()); } if (this._copyElt2) { this._copyElt2.clearChild().addChild(makeCopyChildren()); } if (this._copyElt) { this._copyElt.clearChild().addChild(makeCopyChildren()); } ResizeSystem/* default.updateUp */.Z.updateUp(this._elt); ResizeSystem/* default.requestUpdateUpSignal */.Z.requestUpdateUpSignal(this._elt); }; DTHeadCell.prototype.requestUpdateContent = function () { if (this.ucTO > 0) return; // this.ucTO = setTimeout(() => { this.ucTO = -1; this.updateCopyContent(); // }, 20) }; DTHeadCell.prototype.updateCopyEltSize = function () { if (!this._copyElt && !this._copyElt1 && !this._copyElt2) return; // copyElt is in space var bound = this._copyElt.getBoundingClientRect(); var matchHeight = this._elt.hasClass('as-matched-head-height'); this._elt.addStyle('width', bound.width + 'px'); if (matchHeight) this._elt.addStyle('min-width', bound.width + 'px'); if (this._copyElt1) { this._copyElt1.addStyle('width', bound.width + 'px'); if (matchHeight) this._copyElt1.addStyle('min-width', bound.width + 'px'); } if (this._copyElt2) { this._copyElt2.addStyle('width', bound.width + 'px'); if (matchHeight) this._copyElt2.addStyle('min-width', bound.width + 'px'); } }; Object.defineProperty(DTHeadCell.prototype, 'elt', { get: function () { if (this._elt) return this._elt; var eventAdded = false; var onPointerDown = (event) => { if (event.target.hasClass && event.target.hasClass('as-dt-header-cell-resizer')) return; if (!eventAdded) { document.addEventListener('pointerup', onPointerUp); eventAdded = true; } } var onPointerUp = () => { document.removeEventListener('pointerup', onPointerUp); eventAdded = false; this.nextSortState(); }; this._elt = (0,ACore._)({ tag: 'th', class: 'as-dt-header-cell' }) .on('pointerdown', onPointerDown); if (this.data.attr) { this._elt.attr(this.data.attr); } if (this.data.style) { this._elt.addStyle(this.data.style); } if (this.data.id !== null && this.data.id !== undefined) { this._elt.attr('data-col-id', this.data.id + ''); } this.row.head.table.adapter.renderHeadCell(this._elt, this.data, this); var sortKeyArr = implicitSortKeyArr(this.data.sortKey) if (sortKeyArr.length > 0) { this._elt.attr('data-sort-key', sortKeyArr.join(';')); this._elt.attr('data-sort-order', 'none'); // this._elt.attr('title', 'Sort'); } this.$sortBtn = (0,ACore._)({ tag: 'span', class: 'as-dt-sort-btn', child: [ { tag: 'span', class: ['mdi', 'mdi-menu-up'] // child: { text: '🡑' } }, { tag: 'span', class: ['mdi', 'mdi-menu-down'] } ] }); this.$resizer = (0,ACore._)({ class: 'as-dt-header-cell-resizer' }); this._elt.addChild(this.$sortBtn); this._elt.addChild(this.$resizer); var ctrl = this; // setTimeout(() => { // var addChild = this._elt.addChild; // var clearChild = this._elt.clearChild; // this._elt.addChild = function () { // ctrl.requestUpdateContent(); // addChild.apply(this, arguments); // }; // this._elt.clearChild = function () { // ctrl.requestUpdateContent(); // clearChild.apply(this, arguments); // }; // }, 10); // listenDomContentChange(this._elt, (event) => { // this.requestUpdateContent(); // }); setTimeout(()=>{ (0,utils.listenDomContentChange)(this._elt, (event) => { this.requestUpdateContent(); }); }, 10); return this._elt; } }); Object.defineProperty(DTHeadCell.prototype, 'copyElt', { get: function () { if (this._copyElt) return this._copyElt; this._copyElt = (0,ACore.$)(this.elt.cloneNode(true)).addClass('as-copy-elt'); if (this.data.style && this.data.style.width) { var self = this; setTimeout(function wait() { if (self._copyElt.isDescendantOf(document.body)) { self._copyElt.addStyle('width', self._copyElt.getBoundingClientRect().width + 'px'); } else { setTimeout(wait, 10); } }, 10); } return this._copyElt; } }); Object.defineProperty(DTHeadCell.prototype, 'copyElt1', { get: function () { if (this._copyElt1) return this._copyElt1; this._copyElt1 = (0,ACore.$)(this.elt.cloneNode(true)).addClass('as-copy-elt-1'); return this._copyElt1; } }); Object.defineProperty(DTHeadCell.prototype, 'copyElt2', { get: function () { if (this._copyElt2) return this._copyElt2; this._copyElt2 = (0,ACore.$)(this.elt.cloneNode(true)).addClass('as-copy-elt-2'); return this._copyElt2; } }); Object.defineProperty(DTHeadCell.prototype, 'colspan', { get: function () { var value = this.data.attr && this.data.attr.colspan; if (typeof value === "string") value = parseInt(value); if (typeof value === "number") return value; else return 1; } }); Object.defineProperty(DTHeadCell.prototype, 'rowspan', { get: function () { var value = this.data.attr && this.data.attr.rowspan; if (typeof value === "string") value = parseInt(value); if (typeof value === "number") return value; else return 1; } }); /* harmony default export */ const dynamictable_DTHeadCell = (DTHeadCell); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTHeadRow.js /**** * table layer: copyElt * fixY layer : copyElt1 - elt * fixXY layer: elt * */ /*** * * @param {DTHead} head * @param data * @constructor */ function DTHeadRow(head, data) { this.head = head; this.data = data; this.cells = this.data.cells.map((cellData) => new dynamictable_DTHeadCell(this, cellData)); this._elt = null; this._copyElt = null; this._fixedXYElt = null; this._fixedXElt = null; } DTHeadRow.prototype.updateCopyEltSize = function () { if (!this._fixedXElt) return; var bound = this._copyElt.getBoundingClientRect(); if (this._fixedXElt) this._fixedXElt.addStyle('height', bound.height + 'px'); if (this._fixedXYElt) this._fixedXYElt.addStyle('height', bound.height + 'px'); this._elt.addStyle('height', bound.height + 'px'); this.cells.forEach(c => c.updateCopyEltSize()); }; Object.defineProperty(DTHeadRow.prototype, 'elt', { get: function () { if (this._elt) return this._elt; var fixedCol = this.adapter.fixedCol || 0; var child = this.cells.filter(c=> c.idx < fixedCol).map(c => c.copyElt1); var child1 = this.cells.filter(c=> c.idx >= fixedCol).map(c => c.elt); this._elt = (0,ACore._)({ tag: 'tr', class: 'as-dt-head-row', child: child.concat(child1) }); if (this.data.attr) { this.elt.attr(this.data.attr); } if (this.data.style) { this.elt.addStyle(this.data.style); } return this._elt; } }); Object.defineProperty(DTHeadRow.prototype, 'fixedXYElt', { get: function () { if (this._fixedXYElt) return this._fixedXYElt; var fixedCol = this.adapter.fixedCol || 0; this._fixedXYElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-xy', child: this.cells.filter(c=> c.idx < fixedCol).map(c => c.elt) }); return this._fixedXYElt; } }); Object.defineProperty(DTHeadRow.prototype, 'fixedXElt', { get: function () { if (this._fixedXElt) return this._fixedXElt; var fixedCol = this.adapter.fixedCol || 0; this._fixedXElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-x', child:this.cells.filter(c=> c.idx < fixedCol).map(c => c.copyElt2) }); return this._fixedXElt; } }); Object.defineProperty(DTHeadRow.prototype, 'copyElt', { get: function () { if (this._copyElt) return this.copyElt; var adapter = this.adapter; this._copyElt = (0,ACore._)({ elt: this.elt.cloneNode(false), child: this.cells.map(c => c.copyElt) }); return this._copyElt; } }); Object.defineProperty(DTHeadRow.prototype, 'adapter', { get: function () { return this.head.adapter; } }) /* harmony default export */ const dynamictable_DTHeadRow = (DTHeadRow); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTHead.js /*** * * @param {DTTable} table * @param {} data * @constructor */ function DTHead(table, data) { if (!data) data = {}; if (!data.rows) data.rows = []; this.table = table; this._elt = null; this._copyElt = null; this._fixedXYElt = null; this._fixedXElt = null; this.data = data; this.rows = this.data.rows.map((rowData) => new dynamictable_DTHeadRow(this, rowData)); this.makeCellIdx(); } DTHead.prototype.makeCellIdx = function () { var height = Array(200).fill(0); var i, j, k, row, cells, colIdx, cell, colspan, rowspan; for (i = 0; i < this.rows.length; ++i) { row = this.rows[i]; cells = row.cells; colIdx = 0; for (j = 0; j < cells.length; ++j) { while (height[colIdx] > i) ++colIdx; cell = cells[j]; cell.idx = colIdx; colspan = cell.colspan; rowspan = cell.rowspan; if (rowspan ===this.rows.length) { cell.elt.addClass('as-matched-head-height'); } for (k = 0; k < colspan; ++k) { height[colIdx] = i + rowspan; ++colIdx; } } } }; DTHead.prototype.lockWidth = function () { this.rows.forEach(r => r.lockWidth()); }; DTHead.prototype.updateCopyEltSize = function () { if (!this._copyElt) return; this.rows.forEach(r => r.updateCopyEltSize()); }; Object.defineProperty(DTHead.prototype, 'elt', { get: function () { if (this._elt) return this._elt; this._elt = (0,ACore._)({ tag: 'thead', class: 'as-dt-header', child: this.rows.map(r => r.elt) }); if (this.data.style) this._elt.addStyle(this.data.style); return this._elt; } }); Object.defineProperty(DTHead.prototype, 'copyElt', { get: function () { if (this._copyElt) return this._copyElt; this._copyElt = (0,ACore._)({ elt: this.elt.cloneNode(false), child: this.rows.map(r => r.copyElt) }); return this._copyElt; } }); Object.defineProperty(DTHead.prototype, 'fixedXYElt', { get: function () { if (this._fixedXYElt) return this._fixedXYElt; this._fixedXYElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-xy', child: this.rows.map(r => r.fixedXYElt) }); return this._fixedXYElt; } }); Object.defineProperty(DTHead.prototype, 'fixedXElt', { get: function () { if (this._fixedXElt) return this._fixedXElt; this._fixedXElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-x', child: this.rows.map(r => r.fixedXElt) }); return this._fixedXElt; } }); Object.defineProperty(DTHead.prototype, 'adapter', { get: function () { return this.table.wrapper.adapter; } }); /* harmony default export */ const dynamictable_DTHead = (DTHead); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTBodyCell.js /*** * * @param {DTBodyRow} row * @param data * @constructor */ function DTBodyCell(row, data) { this.row = row; this._elt = null; this._copyElt = null; this._idx = null; if (data.attr) { Object.keys(data.attr).forEach(key => { var key2 = key.toLowerCase(); if (key2 !== key) data.attr[key2] = data.attr[key]; }) } this.data = data; } DTBodyCell.prototype.revoke = function () { this.row = null; if (this._elt) this._elt.holder = null; this._elt = null; this._copyElt = null; this._idx = null; this.data = null; }; Object.defineProperty(DTBodyCell.prototype, 'elt', { get: function () { if (this._elt) return this._elt; this._elt = (0,ACore._)({ tag: 'td', class: 'as-dt-body-cell' }); this._elt.holder = this; var addChild = this._elt.addChild; this._elt.addChild = function () { addChild.apply(this, arguments); ResizeSystem/* default.requestUpdateUpSignal */.Z.requestUpdateUpSignal(this); return this; }; if (this.data.attr) this._elt.attr(this.data.attr); if (typeof this.data.class === "string") (0,utils.addElementClassName)(this._elt, this.data.class); if (this.data.style) this._elt.addStyle(this.data.style); if (this.data.on) { Object.keys(this.data.on).forEach(key => { var cb = this.data.on[key]; if (typeof cb !== "function") return; this._elt.on(key, event => { cb.call(this._elt, event, this); }); }); } if (this._idx !== null) this._elt.attr('data-col-idx', this._idx + ''); this.row.body.table.adapter.renderBodyCell(this.elt, this.data, this); (0,utils.listenDomContentChange)(this._elt, (event) => { this.requestUpdateContent(); }); return this._elt; } }); Object.defineProperty(DTBodyCell.prototype, 'copyElt', { get: function () { if (this._copyElt) return this._copyElt; this._copyElt = (0,ACore.$)(this.elt.cloneNode(true)).addClass('as-copy-elt'); return this._copyElt; } }); DTBodyCell.prototype.requestUpdateContent = function () { if (this._copyElt) { this._copyElt.clearChild(); this._copyElt.addChild(Array.prototype.map.call(this._elt.childNodes, c => c.cloneNode(true))); } ResizeSystem/* default.updateUp */.Z.updateUp(this._elt, true); ResizeSystem/* default.requestUpdateUpSignal */.Z.requestUpdateUpSignal(this._elt, true); } Object.defineProperty(DTBodyCell.prototype, 'innerText', { get: function () { var text = this.data.innerText; if (text === undefined || text === null) text = ''; else if (!text) { text = text + ''; } else if (text.substring) { } else if (typeof text === "number") { text = text + '' } else if (typeof text === "object") { if (text instanceof Date) { return (0,datetime.formatDateTime)(text, 'dd/MM/yyyy HH:mm'); } else { return (0,utils.jsStringOf)(text); } } else if (typeof text === "function") { text = text.call(this.data, this); } return text; if (this.data.innerText) return this.data.innerText; if (this.data.getInnerText) return this.data.getInnerText(); // if ('innerText' in this.data) return this.data.innerText || ''; var res = []; function visit(node) { if (node.nodeType === 3 && node.data) { res.push(node.data); } else if (node.childNodes && node.childNodes.length > 0) { Array.prototype.forEach.call(node.childNodes, visit); } } visit(this.elt); return res.join(' '); } }); Object.defineProperty(DTBodyCell.prototype, 'idx', { set: function (value) { this._idx = value; if (this._elt) this._elt.attr('data-col-idx', value + ''); }, get: function () { return this._idx; } }); Object.defineProperty(DTBodyCell.prototype, 'colspan', { get: function () { var value = this.data.attr && this.data.attr.colspan; if (typeof value === "string") value = parseInt(value); if (typeof value === "number") return value; else return 1; } }); /* harmony default export */ const dynamictable_DTBodyCell = (DTBodyCell); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTBodyRow.js /*** * * @param {DTBody} body * @param data * @constructor */ function DTBodyRow(body, data) { this.body = body; this.data = data; this.data.cells = this.data.cells || []; this._elt = null; this._fixedXElt = null; this.filterKeys = Object.assign({}, this.data.keys); this.data.cells.reduce((ac, cr, i) => { if (typeof cr.keySort === "string") { ac['[' + i + ']'] = (0,stringFormat.nonAccentVietnamese)(cr.keySort).toLowerCase(); } else if (typeof cr.keySort === "number") { ac['[' + i + ']'] = cr.keySort; } else if (typeof cr.innerText === "string") { ac['[' + i + ']'] = (0,stringFormat.nonAccentVietnamese)(cr.innerText).toLowerCase(); } return ac; }, this.filterKeys); if ('id' in data) { this.id = data.id; } else { this.id = (0,stringGenerate.randomIdent)(8); } this._idx = null; /*** * @type {DTBodyCell[]} */ this.cells = this.data.cells.map((cellData) => new dynamictable_DTBodyCell(this, cellData)); this.cells.reduce((ac, cell) => { cell.idx = ac; return ac + cell.colspan; }, 0); } DTBodyRow.prototype.revoke = function () { while (this.cells.length) { this.cells.pop().revoke(); } this.cells = null; this.data = null; this.body = null; if (this._elt) this._elt.dtBodyRow = null; this._elt = null; this.$id = null; this.draggable = null; }; DTBodyRow.prototype.revokeResource = function () { }; DTBodyRow.prototype.remove = function () { this.body.removeRow(this); }; DTBodyRow.prototype.viewInto = function () { return this.body.viewIntoRow(this); }; DTBodyRow.prototype.updateCopyEltSize = function () { if (!this._fixedXElt) return; if (!this._elt.parentElement) return; if (this._fixedXElt.childNodes.length === 0) return;//has no fixed column var bound = this._elt.getBoundingClientRect(); this._fixedXElt.addStyle('height', bound.height + 'px'); }; DTBodyRow.prototype.updateData = function (data) { var rowIdx = this.body.rowIndexOf(this.data); this.body.data.rows[rowIdx] = data; this.data = data; if ('id' in data) { this.id = data.id; } else { this.id = (0,stringGenerate.randomIdent)(8); } this.cells = this.data.cells.map((cellData) => new dynamictable_DTBodyCell(this, cellData)); this.cells.reduce((ac, cell) => { cell.idx = ac; return ac + cell.colspan; }, 0); if (this._elt) { this._elt.attr('data-id', this.id + ''); this._elt.clearChild().addChild(this.cells.map(function (cell) { return cell.elt; })); this.$idx = (0,ACore.$)('.as-dt-row-index', this._elt); this.draggable = !!(0,ACore.$)('.as-drag-zone', this._elt); if (this.$idx) this.$idx.attr('data-idx', this._idx + 1 + ''); } this.body.onRowSplice(rowIdx); }; Object.defineProperty(DTBodyRow.prototype, 'elt', { get: function () { if (this._elt) return this._elt; var fixedCol = this.adapter.fixedCol || 0; var child = this.cells.filter(c => c.idx < fixedCol).map(c => c.copyElt); var child1 = this.cells.filter(c => c.idx >= fixedCol).map(c => c.elt); this._elt = (0,ACore._)({ tag: 'tr', class: 'as-dt-body-row', props: { dtBodyRow: this }, child: child.concat(child1) }); this._elt.attr('data-id', this.id + ''); if (this.data.class) { (0,utils.addElementClassName)(this._elt, this.data.class); } if (this.data.attr) { this._elt.attr(this.data.attr); } if (this.data.style) { this._elt.addStyle(this.data.style); } if (this.data.on) { Object.keys(this.data.on).forEach(key => { var cb = this.data.on[key]; if (typeof cb !== "function") return; this._elt.on(key, event => { cb.call(this._elt, event, this); }); }); } this.$idx = this.cells.reduce((ac, c) => { return ac || (0,ACore.$)('.as-dt-row-index', c.elt); }, null); this.draggable = !!(0,ACore.$)('.as-drag-zone', this._elt); if (this.$idx) this.$idx.attr('data-idx', this._idx + 1 + ''); var originAddStyle = this._elt.addStyle; var originRemoveStyle = this._elt.removeStyle; var originAddClass = this._elt.addClass; var originRemoveClass = this._elt.removeClass; var isOverrideStyle = x=> ['background-color', 'backgroundColor', 'color'].includes(x); var thisCTL = this; this._elt.addStyle = function (key, value) { originAddStyle.apply(this, arguments); if (thisCTL._fixedXElt && isOverrideStyle(key)) { thisCTL._fixedXElt.addStyle(key, value); } return this; }; this._elt.removeStyle = function (key) { originRemoveStyle.apply(this, arguments); if (thisCTL._fixedXElt && isOverrideStyle(key)) { thisCTL._fixedXElt.removeStyle(key); } return this; }; this._elt.addClass = function () { originAddClass.apply(this, arguments); if (thisCTL._fixedXElt) { thisCTL._fixedXElt.addClass.apply(thisCTL._fixedXElt, arguments); } return this; }; this._elt.removeClass = function () { originRemoveClass.apply(this, arguments); if (thisCTL._fixedXElt) { thisCTL._fixedXElt.removeClass.apply(thisCTL._fixedXElt, arguments); } return this; }; return this._elt; } }); Object.defineProperty(DTBodyRow.prototype, 'fixedXElt', { get: function () { if (this._fixedXElt) return this._fixedXElt; var fixedCol = this.adapter.fixedCol || 0; this._fixedXElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-x', child: this.cells.slice(0, fixedCol).map(cell => cell.elt) }); return this._fixedXElt; } }); Object.defineProperty(DTBodyRow.prototype, 'innerText', { get: function () { if (this.data.innerText) return this.data.innerText; if (this.data.getInnerText) return this.data.getInnerText(); if ('innerText' in this.data) return this.data.innerText || ''; return this.cells.map(function (cell) { return cell.innerText.trim(); }).filter(text => !!text).join(' / '); } }); Object.defineProperty(DTBodyRow.prototype, 'idx', { set: function (value) { if (this.$idx) this.$idx.attr('data-idx', value + 1 + ''); this._idx = value; }, get: function () { return this._idx; } }); Object.defineProperty(DTBodyRow.prototype, 'adapter', { get: function () { return this.body.adapter; } }); /* harmony default export */ const dynamictable_DTBodyRow = (DTBodyRow); // EXTERNAL MODULE: ./node_modules/absol/src/Network/Thread.js + 1 modules var Thread = __webpack_require__(6672); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTSearchFactor.js function DTSearchFactor(global) { /*** * @typedef SelectionItem2 * @property {String} text * @property {String} desc * @property {String} __text__ * @property {String} __nvnText__ * @property {Array<String>} __words__ * @property {Array<String>} __nvnWords__ * @property {object} __wordDict__ * @property {object} __nvnWordDict__ * @module SelectionItem2 */ function nonAccentVietnamese(s) { return s.replace(/à|á|ạ|ả|ã|â|ầ|ấ|ậ|ẩ|ẫ|ă|ằ|ắ|ặ|ẳ|ẵ/g, "a") .replace(/À|Á|Ạ|Ả|Ã|Â|Ầ|Ấ|Ậ|Ẩ|Ẫ|Ă|Ằ|Ắ|Ặ|Ẳ|Ẵ/g, "A") .replace(/è|é|ẹ|ẻ|ẽ|ê|ề|ế|ệ|ể|ễ/g, "e") .replace(/È|É|Ẹ|Ẻ|Ẽ|Ê|Ề|Ế|Ệ|Ể|Ễ/g, "E") .replace(/ì|í|ị|ỉ|ĩ/g, "i") .replace(/Ì|Í|Ị|Ỉ|Ĩ/g, "I") .replace(/ò|ó|ọ|ỏ|õ|ô|ồ|ố|ộ|ổ|ỗ|ơ|ờ|ớ|ợ|ở|ỡ/g, "o") .replace(/Ò|Ó|Ọ|Ỏ|Õ|Ô|Ồ|Ố|Ộ|Ổ|Ỗ|Ơ|Ờ|Ớ|Ợ|Ở|Ỡ/g, "O") .replace(/ù|ú|ụ|ủ|ũ|ư|ừ|ứ|ự|ử|ữ/g, "u") .replace(/Ù|Ú|Ụ|Ủ|Ũ|Ư|Ừ|Ứ|Ự|Ử|Ữ/g, "U") .replace(/ỳ|ý|ỵ|ỷ|ỹ/g, "y") .replace(/Ỳ|Ý|Ỵ|Ỷ|Ỹ/g, "Y") .replace(/đ/g, "d") .replace(/Đ/g, "D") .replace(/\u0300|\u0301|\u0303|\u0309|\u0323/g, "") .replace(/\u02C6|\u0306|\u031B/g, ""); } function harmonicMean(a, b) { return 2 / (1 / a + 1 / b); } function wordLike(a, b) { var m = a.length; var n = b.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) if (a.charAt(i) == b.charAt(j)) { if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + 1) Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); return Q[map(m, n)] / harmonicMean(m, n); } function wordsMatch(sq1, sq2, matchWordPow) { matchWordPow = matchWordPow === undefined ? 1 : matchWordPow; var m = sq1.length; var n = sq2.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); var e = 0.0; for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) { e = Math.pow(wordLike(sq1[i], sq2[j]), matchWordPow); if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + e) Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; e = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); if (e > Q[map(i + 1, j + 1)]) Q[map(i + 1, j + 1)] = e; } return Q[map(m, n)]; } var EXTRA_MATCH_SCORE = 9; var NVN_EXTRA_MATCH_SCORE = 8; var EQUAL_MATCH_SCORE = 10; var WORD_MATCH_SCORE = 3; var HAS_WORD_SCORE = 30; var HAS_NVN_WORD_SCORE = 29; /*** * * @param {SelectionItem} item * @returns {*} */ function prepareSearchForItem(item) { if (!item.text || !item.text.charAt) item.text = item.text + ''; var splitter = /([_\s\b\-()\[\]"']| | | ")+/g; var text = item.text.replace(splitter, ' '); var __words__ = text.split(/\s+/).filter(w=>!!w).map(w=>w.toLowerCase()); var __text__ = __words__.join(' '); var __wordDict__ = __words__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); var __nvnText__ = nonAccentVietnamese(__text__); var __nvnWords__ = __words__.map(w=>nonAccentVietnamese(w)); var __nvnWordDict__ = __nvnWords__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); Object.defineProperties(item, { __text__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __words__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __wordDict__: { configurable: true, enumerable: false, writable: true, value: __wordDict__ }, __textNoneCase__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __wordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __nvnText__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWords__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ }, __nvnWordDict__: { configurable: true, enumerable: false, writable: true, value: __nvnWordDict__ }, __nvnTextNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ } }); return item; } function isItemMustIncluded(queryItem, item) { if (!queryItem) return true; if (item.__nvnText__.indexOf(queryItem.__nvnText__) >= 0) { return true; } var dict1 = queryItem.__nvnWordDict__; var dict2 = item.__nvnWordDict__; for (var i in dict1) { for (var j in dict2) { if (j.indexOf(i) < 0) return false; } } return true; } function calcItemMatchScore(queryItem, item) { var score = 0; if (!item.__text__) return 0; function calcByWordDict(queryWords, wordDict) { var hwScore = 0; var i; wordDict = Object.assign({}, wordDict); var bestWordMatched, bestWordMatchScore = 0; var word, wordScore; for (i = 0; i < queryWords.length; ++i) { bestWordMatchScore = 0; bestWordMatched = null; for (word in wordDict) { wordScore = wordLike(word, queryWords[i]) - 1e-3 * wordDict[word]; if (wordScore > bestWordMatchScore) { bestWordMatched = word; bestWordMatchScore = wordScore; } } if (bestWordMatchScore >0) { hwScore += bestWordMatchScore * WORD_MATCH_SCORE; delete wordDict[bestWordMatched]; } } return hwScore; } score += calcByWordDict(queryItem.__words__, item.__wordDict__); score += calcByWordDict(queryItem.__nvnWords__, item.__nvnWordDict__); if (item.__text__ === queryItem.__text__) { score += EQUAL_MATCH_SCORE; } var extraIndex = item.__text__.indexOf(queryItem.__text__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } extraIndex = item.__nvnText__.indexOf(queryItem.__nvnText__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } score += Math.max(wordsMatch(queryItem.__words__, item.__words__), wordsMatch(queryItem.__nvnWords__, item.__nvnWords__))/ Math.max(queryItem.__words__.length + 1, 1); return score; } function scoreCmp(a, b) { if (b.score === a.score) { if (b.item.__nvnText__ > a.item.__nvnText__) return -1; return 1; } return b.score - a.score; } function keyStringOf(o) { var type = typeof o; var keys; if (o && type === "object") { if (o.getTime) { return 'd(' + o.getTime() + ')'; } else if (o.length && o.map) { return 'a(' + o.map(val => keyStringOf(val)).join(',') + ')'; } else { keys = Object.keys(o); keys.sort(); return 'o(' + keys.map(key => key + ':' + keyStringOf(o[key])).join(',') + ')'; } } else { return type[0] + '(' + o + ')'; } } function matchFilter(item, filter) { if (!filter) return true; var keys = item.keys; if (!keys) return false; for (var i in filter) { if (!keyCmp(keys[i], filter[i])) return false; } return true; } function toComparable(x) { if (!x) return x; var type = typeof x; if (type === 'string') return x; if (type === "number") return x; if (type === "boolean") return x; if (type.getTime) return type.getTime(); return x; } function keyCmp(itemKey, filterKey) { if (itemKey === filterKey) return true; if (!itemKey !== !filterKey) return false; if (!itemKey || !filterKey) return false; var filterKeyString = keyStringOf(filterKey) function withFilter(x) { var xString = keyStringOf(x) var res = xString === filterKeyString; if (!res && (typeof filterKey === "object")) { if (filterKey.some) { res = filterKey.some(function (y) { return keyStringOf(y) === x; }); } else if (('min' in filterKey) || ('max' in filterKey)) { res = true; if ('min' in filterKey) { res = res && toComparable(x) >= toComparable(filterKey.min); } if ('max' in filterKey) { res = res && toComparable(x) <= toComparable(filterKey.max); } } } return res; } if (itemKey.some) { return itemKey.some(withFilter); } else return withFilter(itemKey); } var benchmark = global.calcBenchmark(); /******************************************************************************************************************/ var slaves = {}; function SearchingSlave(id) { this.id = id; this.items = []; this.itemVersion = -1; this.tranferFinished = true; this.pendingTask = null; this.taskSession = Math.random() + ''; this.scoredHolders = []; this.searchingSession = Math.random() + ''; } SearchingSlave.prototype.onReceiveItems = function (n, start, end, items, version) { if (this.scoredHolders.length > start) { this.scoredHolders.splice(start); } var cItems = this.items; if (cItems.length < n) { // sessionItems cItems.push(null); } if (cItems.length > n) { cItems.splice(n); } this.itemVersion = version; for (var i = start; i < end; ++i) { cItems[i] = items[i - start]; } if (end === n) { this.tranferFinished = true; this.doTask(); } else { this.tranferFinished = false; } }; SearchingSlave.prototype.doTask = function () { if (!this.pendingTask) return; if (this.searchingSession === this.taskSession) return; var self = this; this.searchingSession = this.taskSession; var session = this.searchingSession; var items = this.items; var its = this.scoredHolders; var taskData = this.pendingTask; var itemVersion = this.itemVersion; var queryText = taskData.query.text; var filter = taskData.query.filter; var sort = taskData.query.sort; var queryTextItem = null; if (queryText) queryTextItem = prepareSearchForItem({ text: queryText }); var sortCmp = (a, b) => { var aKeys = a.item.keys; var bKeys = b.item.keys; var key; var av, bv; var d = 0; if (aKeys && !bKeys) { d = 1; } else if (!aKeys && bKeys) { d = -1; } else if (aKeys && bKeys) { for (var i = 0; i < sort.length; ++i) { key = sort[i].key; d = aKeys[key] - bKeys[key]; if (isNaN(d)) { if (aKeys[key] < bKeys[key]) { d = -1; } else if (aKeys[key] === bKeys[key]) { d = 0; } else { d = 1; } } if (sort[i].order === 'descending') d = -d; if (d !== 0) break; } } if (d === 0) { d = a.i - b.i; } return d; }; function likeSort(items) { var minValue = Infinity; var maxValue = -Infinity; var i; var n = items.length; var item; for (i = 0; i < n; ++i) { item = items[i]; if (item.score < minValue) minValue = item.score; if (item.score > maxValue) maxValue = item.score; } var segments = [[], [], [], [], [], [], [], []]; var threshold = maxValue - (maxValue - minValue) / 4; if (maxValue < 3) threshold = maxValue - (maxValue - minValue) / 8; var d = (maxValue - threshold) / (segments.length - 1); var v; var k; for (i = 0; i < n; ++i) { item = items[i]; v = item.score; if (item.mustIncluded) v = Math.max(threshold + 0.1, v); if (v < threshold || v < 0.8) continue; if (v >= maxValue) segments[segments.length - 1].push(item) else { k = ((v - threshold) / d) >> 0; segments[k].push(item); } } var res = []; var segment; while (segments.length > 0) { segment = segments.pop(); if (segment.length > 0) { if (sort) { segment.sort(sortCmp); } else { if (segment.length + res.length < 1000) segment.sort(scoreCmp); } res = res.concat(segment); } } return res; } function sortScore() { var result = its; if (filter) { result = result.filter(function (x) { return !!x; }) } // var now = new Date().getTime(); if (queryTextItem) { result = likeSort(result); } else if (sort) { result.sort(sortCmp); } // console.log("SortTime:", new Date().getTime() - now) result = result.map(function (it) { return it.i; }); self.searchingSession = 'done'; global.emit('searchEnd', self.id, Object({ hash: taskData.hash, idx: taskData.idx, result: result, itemVersion: self.itemVersion })); } function tick() { if (self.taskSession !== session) return; if (self.itemVersion !== itemVersion) { return; } if (its.length >= items.length) { sortScore(); return; } var k = benchmark * 5; if (!queryTextItem) k *= 30; var i = its.length; var n = items.length while (k-- && i < n) { if (!filter || matchFilter(items[i], filter)) { if (!items[i].prepare && queryTextItem) { items[i].prepare = true; prepareSearchForItem(items[i]); } its.push({ i: i, item: items[i], score: queryTextItem ? calcItemMatchScore(queryTextItem, items[i]) : 0, mustIncluded: isItemMustIncluded(queryTextItem, items[i]) }); } else { its.push(null); } ++i; } setTimeout(tick, 5); } tick(); }; SearchingSlave.prototype.receiveTask = function (taskData) { this.pendingTask = taskData && taskData.query && taskData; this.taskSession = taskData && taskData.idx; this.scoredHolders = []; if (this.tranferFinished && this.pendingTask) this.doTask(); } SearchingSlave.prototype.destroy = function () { this.items = null; delete slaves[this.id]; }; global.destroySlave = function (id) { slaves[id] && slaves[id].destroy(); }; /******************************************************************************************************************/ var data = {}; global.transferTask = function (id, taskData) { slaves[id] = slaves[id] || new SearchingSlave(id); slaves[id] && slaves[id].receiveTask(taskData); }; global.transferSearchItems = function (id, n, start, end, items, version) { slaves[id] = slaves[id] || new SearchingSlave(id); slaves[id].onReceiveItems(n, start, end, items, version); }; global.search = function (session, query) { var holder = data[session]; if (!holder) return false; var searchingSession = Math.random() + ''; holder.searchingSession = searchingSession; var now = new Date().getTime(); var items = data[session] && data[session].items; var its = Array(items.length); var queryItem = prepareSearchForItem({ text: query }); var resolve; var sync = new Promise(function (rs) { resolve = rs; }); function calcValue() { var i = 0; var n = items.length; function tick() { if (searchingSession !== holder.searchingSession) { resolve(false); return; } var c = benchmark * 5; while (c-- && i < n) { its[i] = { i: i, item: items[i], score: calcItemMatchScore(queryItem, items[i]) }; ++i; } if (i < n) { setTimeout(tick, 3); } else { setTimeout(sortScore, 3); } } tick(); } function sortScore() { if (searchingSession !== holder.searchingSession) { resolve(false); return; } now = new Date().getTime(); var result = likeSort(its).map(function (it) { return it.i; }); resolve(result); } setTimeout(calcValue, 3); return sync; }; } /* harmony default export */ const dynamictable_DTSearchFactor = (DTSearchFactor); DTSearchFactor.exportCode = function () { var res = DTSearchFactor + '' + '\n\nDTSearchFactor(this)'; return res; } ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTBody.js /*** * * @param {DTBody} body * @constructor */ function SearchingMaster(body) { this.body = body; this.mode = body.modes.searching; this.waitingCtrl = body.table.wrapper.waitingCtl; this.initWorker(); this.id = (0,stringGenerate.randomIdent)(10); this.transferSession = Math.random() + ''; this.transferred = 0; this.isTranferring = false; this.share.instances[this.id] = this; this.itemVersion = 0; this.outputCache = {}; this.lastTaskIdx = 0; } SearchingMaster.prototype.destroy = function () { this.share.thread.invoke('destroySlave', this.id); this.share.instances[this.id] = null; this.transferSession = "DIE"; delete this.share.instances[this.id]; this.outputCache = {}; this.body = null; }; SearchingMaster.prototype.transferFrom = function (offset) { if (this.transferSession === "DIE") { return; } this.outputCache = {}; if (offset < this.transferred) { this.transferred = offset; this.itemVersion++; } if (this.isTranferring) return; var waitingCtrl = this.waitingCtrl; var wTkn = waitingCtrl.begin(); var self = this; var transferSession = Math.random() + ''; self.transferSession = transferSession; self.isTranferring = true; setTimeout(function tick() { if (self.transferSession !== transferSession) { waitingCtrl.end(wTkn); return; } var i = self.transferred; var rows = self.body.rows; var n = self.body.rows.length; if (i >= n) { if (n === 0) { self.share.thread.invoke('transferSearchItems', self.id, n, 0, 0, [], self.itemVersion); } self.isTranferring = false; self.onFinishTransfer(); waitingCtrl.end(wTkn); return; } self.share.benchmark = self.share.benchmark || BrowserDetector/* default.calcBenchmark */.Z.calcBenchmark(); var k = self.share.benchmark >> 2; var items = []; var item; var start = i; while (i < n && k--) { item = { text: rows[i].innerText, value: i, keys: rows[i].filterKeys }; items.push(item); ++i; } var sync = self.share.thread.invoke('transferSearchItems', self.id, n, start, i, items, self.itemVersion); self.transferred = i; Promise.all([sync, new Promise(function (rs) { setTimeout(rs, 5); })]).then(tick); }, 5); }; SearchingMaster.prototype.onFinishTransfer = function () { // console.log('finish'); }; SearchingMaster.prototype.sendTask = function (query) { if (this.transferSession === "DIE") { return; } this.lastTaskIdx++; var taskData = { idx: this.lastTaskIdx, query: query, hash: (0,utils.calcDTQueryHash)(query) }; if (this.outputCache[taskData.hash]) { setTimeout(this.onResult.bind(this, this.outputCache[taskData.hash], true), 5); } else { this.share.thread.invoke('transferTask', this.id, taskData); } return taskData; }; SearchingMaster.prototype.onResult = function (response, dontCache) { if (this.itemVersion !== response.itemVersion) return; if (!dontCache) { this.outputCache[response.hash] = response; } this.body.modes.searching.onResult(response); }; SearchingMaster.prototype.share = { thread: null, benchmark: 0, instances: {} }; SearchingMaster.prototype.initWorker = function () { if (!this.share.thread) { this.share.thread = new Thread/* default */.Z({ methods: { calcBenchmark: BrowserDetector/* default.calcBenchmark */.Z.calcBenchmark }, extendCode: dynamictable_DTSearchFactor.exportCode() }); this.share.thread.on('alert', function (mess) { alert(mess); }); this.share.thread.on('searchEnd', function (id, response) { this.share.instances[id] && this.share.instances[id].onResult(response); }.bind(this)); setTimeout(function () { this.share.benchmark = this.share.benchmark || BrowserDetector/* default.calcBenchmark */.Z.calcBenchmark(); }.bind(this)); } }; /*** * * @param {DTBody} body * @constructor */ function BaseMode(body) { this.body = body; this.offset = 0; this.rowOffset = -1000; this.boundCache = null; this.viewedRows = null; } BaseMode.prototype.name = 'base'; NormalMode.prototype.revoke = function () { this.body = null; }; BaseMode.prototype.resetViewParam = function () { this.offset = 0; this.rowOffset = -1000; this.boundCache = null; this.viewedRows = null; }; BaseMode.prototype.getBoundOfRows = function () { if (this.boundCache) return this.boundCache; if (!this.body.table.wrapper.isDescendantOf(document.body)) return null; var bodyBound = this.body.elt.getBoundingClientRect(); if (!bodyBound || bodyBound.width <= 0 || bodyBound.height <= 0) return null; var elt = this.body.elt; var childNodes = elt.childNodes; this.boundCache = Array.prototype.map.call(childNodes, elt => { var eBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect()); eBound.y -= bodyBound.top; return eBound; }); this.boundCache.body = Rectangle/* default.fromClientRect */.Z.fromClientRect(bodyBound); this.boundCache.header = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.body.table.header.elt.getBoundingClientRect()); return this.boundCache; }; BaseMode.prototype.updateRowsIfNeed = function () { throw Error("Not implement!"); }; BaseMode.prototype.render = function () { this.updateRowsIfNeed(); var bounds = this.getBoundOfRows(); if (!bounds) { setTimeout(() => { if (this.body.elt.isDescendantOf(document.body)) { this.render(); } }, 5); return; } var dy = 0, rowIdx; if (bounds.length > 0) { rowIdx = Math.floor(this.offset - this.rowOffset); //todo: fix bounds[rowIdx] undefined if (!bounds[rowIdx]) return; dy = bounds[rowIdx].y + (this.offset - this.rowOffset - rowIdx) * bounds[rowIdx].height; } var availableHeight; if (bounds.length > 0) { availableHeight = this.body.table.wrapper.$viewport.getBoundingClientRect().height - bounds.header.height; if (bounds[bounds.length - 1].y + bounds[bounds.length - 1].height - dy < availableHeight - 1) { dy = -availableHeight + bounds[bounds.length - 1].y + bounds[bounds.length - 1].height + 1;//1: last border } } dy = Math.max(0, dy); //small padding top var hs = this.body.table.wrapper.$vscrollbar.innerOffset / ((this.body.table.wrapper.$vscrollbar.innerHeight - this.body.table.wrapper.$vscrollbar.outerHeight) || 1) dy += hs * 100; this.body.table.wrapper.$space.addStyle('top', -dy + 'px'); this.body.table.wrapper.$fixedXCtn.addStyle('top', -dy + 'px'); }; /*** * @extends BaseMode * @param {DTBody} body * @constructor */ function SearchingMode(body) { BaseMode.call(this, body); this.status = 'STANDBY'; this.waitingToken = 'none'; this.waitingCtrl = body.table.wrapper.waitingCtl; this.taskHash = 0; this.renderingHash = -1; this.resultItems = []; this.viewedRows = []; } OOP/* default.mixClass */.ZP.mixClass(SearchingMode, BaseMode); SearchingMode.prototype.name = 'search'; SearchingMode.prototype.revoke = function () { this.resultItems = []; this.viewedRows = []; }; SearchingMode.prototype.start = function () { this.status = "RUNNING"; this.searchingCache = {}; this.body.table.wrapper.addClass('as-searching'); this.renderingHash = -1; }; SearchingMode.prototype.end = function () { this.body.table.wrapper.removeClass('as-searching'); this.searchingItems = null; this.status = "STOP"; this.waitingCtrl.end(this.waitingToken); if (this.body.master) this.body.master.sendTask(null); }; SearchingMode.prototype.updateRowsIfNeed = function () { var screenSize = (0,Dom/* getScreenSize */.tE)(); var rowPerPage = Math.ceil(Math.ceil(screenSize.height / 40) / 25) * 25; if (this.body.table.wrapper.hasClass('as-adapt-infinity-grow')) rowPerPage = 1e7; var newRowOffset = Math.floor(this.offset / rowPerPage) * rowPerPage; if (this.resultItems.length - newRowOffset < rowPerPage) { newRowOffset = Math.max(0, newRowOffset - rowPerPage); } if (newRowOffset === this.rowOffset) return; this.rowOffset = newRowOffset; var start = this.rowOffset; var end = Math.min(start + rowPerPage * 2, this.resultItems.length); var elt = this.body.elt; var fixedXElt = this.body.fixedXElt; var rows = this.body.rows; var nRows = []; for (var i = start; i < end; ++i) { nRows.push(rows[this.resultItems[i]]); } var nChildren = nRows.map(r => r.elt); var nFixedXChildren = nRows.map(r => r.fixedXElt); (0,utils.replaceChildrenInElt)(elt, nChildren); (0,utils.replaceChildrenInElt)(fixedXElt, nFixedXChildren); this.boundCache = null; var bounds = this.getBoundOfRows(); if (bounds) { for (var i = 0; i < nRows.length; ++i) { nRows[i].updateCopyEltSize(); } this.body.table.wrapper.layoutCtrl.onResize(); this.body.table.updateCopyEltSize(); } var updateFx = () => { if (counter > 20) return; if (this.body.elt.isDescendantOf(document.body)) { var bounds = this.getBoundOfRows(); if (bounds) { for (var i = 0; i < nRows.length; ++i) { nRows[i].updateCopyEltSize(); } this.body.table.wrapper.layoutCtrl.onResize(); this.body.table.updateCopyEltSize(); } counter += 3; setTimeout(updateFx, (counter++) * 5); } else { setTimeout(updateFx, (counter++) * 5) } }; var counter = 1; if (!bounds) { setTimeout(updateFx, 1); } }; SearchingMode.prototype.onRowSplice = function (idx) { this.rowOffset = -1000; this.render(); } SearchingMode.prototype.onRowRemoved = function (idx, n) { n = n || 1; this.resultItems = this.resultItems.reduce(function (ac, cr) { if (cr >= idx + n) { ac.push(cr - n); } else if (cr < idx) { ac.push(cr); } return ac; }, []); }; SearchingMode.prototype.onRowAdded = function (idx, n) { n = n || 1; this.resultItems = this.resultItems.reduce(function (ac, cr) { if (cr >= idx) { ac.push(cr + n); } else { ac.push(cr); } return ac; }, []); }; SearchingMode.prototype.viewIntoRow = function (row) { console.log(row); }; SearchingMode.prototype.query = function (query) { this.waitingCtrl.end(this.waitingToken); this.waitingToken = this.waitingCtrl.begin(); if (!this.body.master) { this.body.master = new SearchingMaster(this.body); this.body.master.transferFrom(0); } var taskHolder = this.body.master.sendTask(query); this.taskHash = taskHolder.hash; }; SearchingMode.prototype.onResult = function (response) { if (this.status !== 'RUNNING' || response.hash !== this.taskHash) return; this.waitingCtrl.end(this.waitingToken); if (this.renderingHash !== response.hash) { this.renderingHash = response.hash; this.offset = 0; this.rowOffset = -1000; } this.resultItems = response.result; this.viewedRows = this.resultItems.map(rIdx => this.body.rows[rIdx]); this.render(); }; SearchingMode.prototype.share = { thread: null }; /*** * @extends BaseMode * @param {DTBody} body * @constructor */ function NormalMode(body) { BaseMode.call(this, body); } OOP/* default.mixClass */.ZP.mixClass(NormalMode, BaseMode); NormalMode.prototype.name = 'normal'; NormalMode.prototype.start = function () { this.resetViewParam(); this.viewedRows = this.body.rows; this.render(); }; NormalMode.prototype.end = function () { }; NormalMode.prototype.updateRowsIfNeed = function () { var screenSize = (0,Dom/* getScreenSize */.tE)(); var rowPerPage = Math.ceil(Math.ceil(screenSize.height / 40 + 1) / 100) * 100; if (this.body.table.wrapper.hasClass('as-adapt-infinity-grow')) rowPerPage = 1e7; var newRowOffset = Math.floor(this.offset / rowPerPage) * rowPerPage; var data = this.body.data; if (data.rows.length - newRowOffset < rowPerPage) { newRowOffset = Math.max(0, newRowOffset - rowPerPage); } if (newRowOffset === this.rowOffset) return; this.rowOffset = newRowOffset; var start = this.rowOffset; var elt = this.body.elt; var fixedXElt = this.body.fixedXElt; var end = Math.min(start + rowPerPage * 2, data.rows.length); var rows = this.body.rows; elt.clearChild(); fixedXElt.clearChild(); for (var i = start; i < end; ++i) { elt.addChild(rows[i].elt); fixedXElt.addChild(rows[i].fixedXElt); } this.boundCache = null; var bounds = this.getBoundOfRows(); if (bounds) { for (var i = start; i < end; ++i) { rows[i].updateCopyEltSize(); } this.body.table.wrapper.layoutCtrl.onResize(); this.body.table.updateCopyEltSize(); } var counter = 1; var fx = () => { if (counter> 20) return; if (this.body.elt.isDescendantOf(document.body)) { var bounds = this.getBoundOfRows(); if (bounds) { for (var i = start; i < end; ++i) { rows[i].updateCopyEltSize(); } this.body.table.wrapper.layoutCtrl.onResize(); this.body.table.updateCopyEltSize(); } counter += 3; setTimeout(fx, counter * 5); } else { setTimeout(fx, (counter++) * 5); } }; if (!bounds) { setTimeout(fx, 1); } this.body.table.wrapper.rowDragCtrl.ev_rowRenderChange(); ResizeSystem/* default.requestUpdateUpSignal */.Z.requestUpdateUpSignal(this.body.elt); } NormalMode.prototype.onRowSplice = function (idx) { this.rowOffset = -1; this.render(); }; NormalMode.prototype.viewIntoRow = function (o) { var idx = this.viewedRows.findIndex(row => { if (o === row._elt) return true; if (o === row) return true; if (o === row.data) return true; if (o === row.id || row.data.id === o) return true; return false; }); if (idx <= 0) return; var scrollbar = this.body.table.wrapper.$vscrollbar; scrollbar.innerOffset = Math.max(0, Math.min(idx - scrollbar.outerHeight / 3, scrollbar.innerHeight - scrollbar.outerHeight)); scrollbar.emit('scroll'); }; /*** * * @param {DTTable} table * @param data * @constructor */ function DTBody(table, data) { this.table = table; this.data = data; this._elt = null; this._fixedXElt = null; /** * @type {DTBodyRow[]} */ this.rows = this.data.rows.map((rowData, i) => { var row = new dynamictable_DTBodyRow(this, rowData); row.idx = i; return row; }); this.modes = { normal: new NormalMode(this), searching: new SearchingMode(this) }; // // this.curentMode = this.modes.normal; this.curentMode.start(); this.curentMode.render(); this.master = null; // // this.master = new SearchingMaster(this); // this.master.transferFrom(0); /*** * @name offset * @type {number} * @memberOf DTBody# */ } DTBody.prototype.revokeResource = function () { if (this.master) { this.master.destroy(); this.master = null; } while (this.rows.length) { this.rows.pop().revoke(); } this.modes.normal.revoke(); this.modes.searching.revoke(); this.rows = []; this.data = null; }; DTBody.prototype.requireRows = function (start, end) { if (typeof start !== "number") start = 0; if (typeof end !== "number") end = Infinity; end = Math.min(end, this.data.rows.length); return this.rows.slice(start, end); }; DTBody.prototype.reindexRows = function (start, end) { if (typeof start !== "number") start = 0; if (typeof end !== "number") end = Infinity; end = Math.min(end, this.data.rows.length); for (var i = start; i < end; ++i) { if (this.rows[i]) this.rows[i].idx = i; } }; DTBody.prototype.onRowSplice = function (idx) { this.curentMode.onRowSplice(idx); if (this.master) this.master.transferFrom(idx); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } DTBody.prototype.rowIndexOf = function (o) { var n = this.rows.length; for (var i = 0; i < n; ++i) { if (o === this.rows[i]._elt) return i; if (o === this.rows[i]) return i; if (o === this.data.rows[i]) return i; if (o === this.data.rows[i].id) return i; } return -1; }; DTBody.prototype.addRowBefore = function (rowData, bf) { var idx; if (bf === null || bf === undefined) { return this.addRow(rowData); } else { idx = this.rowIndexOf(bf); if (idx < 0) throw new Error("$bf not is a row in table"); return this.addRow(rowData, idx); } }; DTBody.prototype.addRowAfter = function (rowData, at) { var idx; if (at === null || at === undefined) { return this.addRow(rowData, 0); } else { idx = this.rowIndexOf(at); if (idx < 0) throw new Error("$bf not is a row in table"); return this.addRow(rowData, idx + 1); } }; DTBody.prototype.addRow = function (rowData, idx) { if (!(0,utils.isNaturalNumber)(idx) || idx >= this.rows.length) { idx = this.rows.length; } var row; if (idx >= this.rows.length) { idx = this.rows.length; this.data.rows.push(rowData); row = new dynamictable_DTBodyRow(this, rowData) row.idx = idx; this.rows.push(row); if (this.curentMode.onRowAdded) this.curentMode.onRowAdded(idx, 1); this.onRowSplice(this.rows.length - 1); } else { row = new dynamictable_DTBodyRow(this, rowData); row.idx = idx; this.rows.splice(idx, 0, row); this.data.rows.splice(idx, 0, rowData); this.reindexRows(idx + 1); this.onRowSplice(idx); } return row; }; DTBody.prototype.addRows = function (rowsData, idx) { if (!(0,utils.isNaturalNumber)(idx) || idx >= this.rows.length) { idx = this.rows.length; } var res = []; var row, i, rowData; if (idx >= this.rows.length) { idx = this.rows.length; for (i = 0; i < rowsData.length; ++i) { rowData = rowsData[i]; row = new dynamictable_DTBodyRow(this, rowData); row.idx = i + idx; this.data.rows.push(rowData); res.push(row); this.rows.push(row); } } else { for (i = 0; i < rowsData.length; ++i) { rowData = rowsData[i]; row = new dynamictable_DTBodyRow(this, rowData); row.idx = i + idx; res.push(row); this.data.rows.splice(idx + i, 0, rowData); this.rows.splice(idx + i, 0, row); } this.reindexRows(idx + rowsData.length); } if (this.curentMode.onRowAdded) this.curentMode.onRowAdded(idx, rowsData.length); this.onRowSplice(idx); return res; }; DTBody.prototype.removeRow = function (row) { var idx = this.rowIndexOf(row); if (idx < 0) return; this.rows.splice(idx, 1); this.data.rows.splice(idx, 1); this.reindexRows(idx); if (this.curentMode.onRowRemoved) this.curentMode.onRowRemoved(idx); this.onRowSplice(idx); }; DTBody.prototype.moveRowAt = function (idx, newIdx) { var row = this.rows.splice(idx, 1)[0]; var rowData = this.data.rows.splice(idx, 1)[0]; this.rows.splice(newIdx, 0, row); this.data.rows.splice(newIdx, 0, rowData); this.reindexRows(Math.min(idx, newIdx)); this.onRowSplice(Math.min(idx, newIdx)); }; DTBody.prototype.clearRows = function () { var n = this.rows.length; this.rows.splice(0); this.data.rows.splice(0); if (this.curentMode.onRowRemoved) this.curentMode.onRowRemoved(0, n); this.onRowSplice(0); }; DTBody.prototype.rowAt = function (idx) { if (this.rows[idx]) return this.rows[idx]; var rowData = this.data.rows[idx]; if (rowData) { this.rows[idx] = new dynamictable_DTBodyRow(this, rowData); this.rows[idx].idx = idx; } else return null; }; DTBody.prototype.rowOf = function (o) { var idx = this.rowIndexOf(o); return this.rowAt(idx); }; DTBody.prototype.viewIntoRow = function (row) { return this.curentMode.viewIntoRow(row); }; DTBody.prototype.startSearchingIfNeed = function () { if (this.curentMode !== this.modes.searching) { this.curentMode.end(); this.curentMode = this.modes.searching; this.curentMode.start(); } }; DTBody.prototype.stopSearchIfNeed = function () { if (this.curentMode === this.modes.searching) { this.curentMode.end(); this.curentMode = this.modes.normal; this.curentMode.start(); } }; DTBody.prototype.query = function (query) { var now = new Date().getTime(); if (query) { this.startSearchingIfNeed(); } else if (!query) { this.stopSearchIfNeed(); this.curentMode.render(); } if (this.curentMode.query && query) { this.curentMode.query(query); } }; DTBody.prototype.updateCopyEltSize = function () { this.rows.forEach(row => row.updateCopyEltSize()); }; Object.defineProperties(DTBody.prototype, { offset: { set: function (value) { this._offset = value; this.curentMode.offset = value; this.curentMode.render(); }, get: function () { return this._offset; } }, searching: { get: function () { return this.elt.hasClass('as-searching'); } } }); Object.defineProperty(DTBody.prototype, 'elt', { get: function () { if (this._elt) return this._elt; this._elt = (0,ACore._)({ tag: 'tbody', class: 'as-dt-body', }); if (this.data.on) { Object.keys(this.data.on).forEach(key => { var cb = this.data.on[key]; if (typeof cb !== "function") return; this._elt.on(key, event => { cb.call(this._elt, event, this); }); }); } return this._elt; } }); Object.defineProperty(DTBody.prototype, 'fixedXElt', { get: function () { if (this._fixedXElt) return this._fixedXElt; this._fixedXElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-fixed-x', }); return this._fixedXElt; } }); Object.defineProperty(DTBody.prototype, 'adapter', { get: function () { return this.table.adapter; } }); /* harmony default export */ const dynamictable_DTBody = (DTBody); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTTable.js /*** * * @param {DynamicTable} elt * @param {} data * @constructor */ function DTTable(wrapper, data) { this.wrapper = wrapper; this._elt = null; this._fixedXElt = null; this._fixedXYElt = null; this._fixedYElt = null; /*** * * @type {DTDataTable|null|*|string} */ this.adapter = this.wrapper._adapter; this.data = data; this.header = new dynamictable_DTHead(this, this.data.head); this.body = new dynamictable_DTBody(this, this.data.body); } DTTable.prototype.updateCopyEltSize = function () { if (!this._fixedYElt) return; var bound = this._elt.getBoundingClientRect(); this._fixedYElt.parentElement.addStyle('width', bound.width + 'px'); this.header.updateCopyEltSize(); this.body.updateCopyEltSize(); } DTTable.prototype.revokeResource = function () { this.wrapper = null; this._elt = null; this.adapter = null; this.data = null; this.body.revokeResource(); }; Object.defineProperty(DTTable.prototype, 'elt', { get: function () { if (this._elt) return this._elt; this._elt = (0,ACore._)({ tag: 'table', class: 'as-dynamic-table', child: [ this.header.copyElt, this.body.elt ] }); return this._elt; } }); Object.defineProperty(DTTable.prototype, 'fixedXElt', { get: function () { if (this._fixedXElt) return this._fixedXElt; this._fixedXElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-fixed-x', child: [this.header.fixedXElt, this.body.fixedXElt] }); return this._fixedXElt; } }); Object.defineProperty(DTTable.prototype, 'fixedYElt', { get: function () { if (this._fixedYElt) return this._fixedYElt; this._fixedYElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-y', child: [this.header.elt] }); return this._fixedYElt; } }); Object.defineProperty(DTTable.prototype, 'fixedXYElt', { get: function () { if (this._fixedXYElt) return this._fixedXYElt; this._fixedXYElt = (0,ACore._)({ elt: this.elt.cloneNode(false), class: 'as-dt-fixed-y', child: [this.header.fixedXYElt] }); return this._fixedXYElt; } }); /* harmony default export */ const dynamictable_DTTable = (DTTable); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTDataAdapter.js /*** * @typedef DTDataRow * @property */ /*** * @typedef DTDataBody * @property {DTDataRow[]} row */ /*** * @typedef DTDataHead * @property {DTDataHRow[]} row */ /*** * @typedef DTDataTable * @property head * @property body * @property {number} rowsPerPage * @property {number} fixedCol */ /*** * * @param {DynamicTable} tableElt * @param {DTDataAdapter} opt * @constructor */ function DTDataAdapter(tableElt, opt) { this.tableElt = tableElt; /*** * * @type {null|DTDataTable} */ this.data = null; this.rowsPerPage = 20; this.fixedCol = 0; Object.assign(this, opt); if (this.fixedCol === 0) { this.tableElt.removeClass('as-has-fixed-col'); } else { this.tableElt.addClass('as-has-fixed-col'); } } DTDataAdapter.prototype.revoke = function () { this.tableElt = null; this.data = null; }; DTDataAdapter.prototype.render = function () { if (this.tableElt.table) this.tableElt.table.revokeResource(); this.tableElt.table = new dynamictable_DTTable(this.tableElt, this.data); }; DTDataAdapter.prototype.renderHeadCell = function (elt, data, controller) { if (data.child) { if (data.child.map) { elt.addChild(data.child.map(function (it) { return (0,ACore._)(it); })); } else { elt.addChild((0,ACore._)(data.child)); } } if (data.render) { data.render.call(null, elt, data, controller); } }; DTDataAdapter.prototype.renderBodyCell = function (elt, data, controller) { if (data.child) { if (data.child.map) { elt.addChild(data.child.map(function (it) { return (0,ACore._)(it); })) } else { elt.addChild((0,ACore._)(data.child)); } } if (data.render) { data.render.call(null, elt, data, controller); } if (data.style) { elt.addStyle(data.style); } }; /* harmony default export */ const dynamictable_DTDataAdapter = (DTDataAdapter); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dynamictable.css var dynamictable = __webpack_require__(5984); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DTWaitingViewController.js /*** * * @param {DynamicTable} tableElt * @constructor */ function DTWaitingViewController(tableElt) { this.tableElt = tableElt; this.tokens = {}; this.traceToken = {}; this.timeoutIdx = -1; } DTWaitingViewController.prototype.begin = function () { var token = Math.random() + ''; if (this.tableElt.$searchInput) this.tableElt.$searchInput.waiting = true; this.tokens[token] = true; this.traceToken[token] = new Error(token); if (this.timeoutIdx > 0) { clearTimeout(this.timeoutIdx); this.timeoutIdx = -1; } return token; }; DTWaitingViewController.prototype.end = function (token) { delete this.tokens[token]; delete this.traceToken[token]; if (this.timeoutIdx > 0) { clearTimeout(this.timeoutIdx); } this.timeoutIdx = setTimeout(function () { this.timeoutIdx = -1; for (var i in this.tokens) return; if (this.tableElt.$searchInput) this.tableElt.$searchInput.waiting = false; }.bind(this), 100); }; /* harmony default export */ const dynamictable_DTWaitingViewController = (DTWaitingViewController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dynamictable/DynamicTable.js var loadStyleSheet = function () { var dynamicStyleSheet = {}; var key = Array(20).fill(0).map((u, i) => [ '.as-dynamic-table-wrapper.as-hide-col-' + i + ' td[data-col-idx="' + i + '"]', '.as-dynamic-table-wrapper.as-hide-col-' + i + ' th[data-col-idx="' + i + '"]' ].join(', ')).join(',\n'); dynamicStyleSheet[key] = { display: 'none' }; (0,utils.buildCss)(dynamicStyleSheet); loadStyleSheet = noop/* default */.Z; } function DynamicTableManager() { this.tables = []; this.storageChanged = false; } DynamicTableManager.prototype.STORE_KEY = 'DynamicTableSetting'; DynamicTableManager.prototype.VER = 2; DynamicTableManager.prototype.initIfNeed = function () { if (this.css) return; this.css = new DynamicCSS/* default */.Z(); this.css.elt.setAttribute('id', "dynamic_mng"); this.tables = []; try { var json = localStorage.getItem(this.STORE_KEY); if (json) { this.data = JSON.parse(json); if (!this.data || this.data.ver !== this.VER) this.data = null; } } catch (er) { } this.data = this.data || { ver: this.VER, colWidth: {} }; this.initCss(); }; DynamicTableManager.prototype.initCss = function () { Object.keys(this.data.colWidth).forEach(tableId => { Object.keys(this.data.colWidth[tableId]).forEach(colId => { var value = this.data.colWidth[tableId][colId]; this.css.setProperty(`#${tableId} th[data-col-id="${colId}"]`, 'width', value + 'px') }); }); this.css.commit(); }; DynamicTableManager.prototype.add = function (table) { this.tables.push(table); }; DynamicTableManager.prototype.removeTrash = function () { this.tables = this.tables.filter(table => table.isDescendantOf(document.body)); }; DynamicTableManager.prototype.commitColWidth = function (sender, tableId, colId, value, storage) { this.setColWidth(tableId, colId, value, storage); this.removeTrash(); this.commit(); this.tables.forEach(table => { if (table.id === table && table !== sender) { table.requestUpdateSize(); } }); }; DynamicTableManager.prototype.hasColSize = function (tableId, colId) { return this.data.colWidth[tableId] && this.data.colWidth[tableId][colId]; }; DynamicTableManager.prototype.setColWidth = function (tableId, colId, value, storage) { if (storage) { this.data.colWidth[tableId] = this.data.colWidth[tableId] || {}; this.data.colWidth[tableId][colId] = value; this.storageChanged = true; } this.css.setProperty(`#${tableId} th[data-col-id="${colId}"]:not([colspan])`, 'width', value + 'px'); }; DynamicTableManager.prototype.commit = function () { if (this.storageChanged) { localStorage.setItem(this.STORE_KEY, JSON.stringify(this.data)); this.storageChanged = false; } this.css.commit(); } var manager = new DynamicTableManager(); var pendingTables = {}; /*** * @extends AElement * @constructor */ function DynamicTable() { this._pendingId = (0,stringGenerate.randomIdent)(4); pendingTables[this._pendingId] = this; manager.initIfNeed(); loadStyleSheet(); this.css = new DynamicCSS/* default */.Z(); this._hiddenColumns = []; /*** * * @type {SearchTextInput|null} */ this.$searchInput = null; /*** * * @type {AElement} */ this.$table = (0,ACore.$)('.as-dynamic-table', this); /*** * * @type {AElement} */ this.$thead = (0,ACore.$)('.as-dynamic-table>thead', this.$table); /*** * * @type {AElement} */ this.$tbody = (0,ACore.$)('.as-dynamic-table>tbody', this.$table); this.$filterInputs = []; this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$domSignal = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); //controller this.table = null; this.$space = (0,ACore.$)('.as-dynamic-table-space', this); this.$fixedYCtn = (0,ACore.$)('.as-dynamic-table-fixed-y-ctn', this); this.$fixedXCtn = (0,ACore.$)('.as-dynamic-table-fixed-x-ctn', this); this.$fixedXYCtn = (0,ACore.$)('.as-dynamic-table-fixed-xy-ctn', this); this.$viewport = (0,ACore.$)('.as-dynamic-table-viewport', this); this.$hscrollbar = (0,ACore.$)('.as-dynamic-table-hb', this); this.$vscrollbar = (0,ACore.$)('.as-dynamic-table-vb', this); this.$pageSelector = new VirtualPageSelector(this); this.extendStyle = Object.assign(new AppPattern_Attributes(this), this.extendStyle); this.extendStyle.loadAttributeHandlers(this.styleHandlers); // this.$attachhook.requestUpdateSize = this.fixedContentCtrl.updateSize.bind(this.fixedContentCtrl); this.$attachhook.requestUpdateSize = this.requestUpdateSize.bind(this); var trashTO = -1; this.readySync = new Promise(rs => { this.onReady = rs; }); this.$attachhook.once('attached', () => { delete pendingTables[this._pendingId]; // setTimeout(()=>{ // Object.values(pendingTables).forEach(table=>{ // if (!table.isDescendantOf(document.body)) // table.revokeResource(); // }); // }, 5000); ResizeSystem/* default.add */.Z.add(this.$attachhook); this.layoutCtrl.onAttached(); this.colSizeCtrl.onAttached(); manager.add(this); setTimeout(() => { this.requestUpdateSize(); if (this.onReady) { this.onReady(); this.onReady = null; } }, 10); clearTimeout(trashTO); var checkAlive = () => { if (this.isDescendantOf(document.body)) { setTimeout(checkAlive, 2000); } else { this.revokeResource(); } }; setTimeout(checkAlive, 500); }); /*** * * @type {{data: DTDataTable}||null} */ this.adapter = null; this.waitingCtl = new dynamictable_DTWaitingViewController(this); this.layoutCtrl = new LayoutController(this); this.pointerCtrl = new PointerController(this); this.colSizeCtrl = new ColSizeController(this); this.rowDragCtrl = new RowDragController(this); } DynamicTable.tag = 'DynamicTable'.toLowerCase(); DynamicTable.render = function (data, domDesc) { var width = domDesc.style && domDesc.style.width; var classList = ['as-dynamic-table-wrapper']; if (width === 'match_parent' || width === '100%') { classList.push('as-width-match-parent'); } return (0,ACore._)({ id: 'no-id-' + (0,stringGenerate.randomIdent)(10), extendEvent: ['orderchange', 'colresize'], class: classList, child: [ { tag: Hanger/* default.tag */.Z.tag, class: 'as-dynamic-table-viewport', child: [ { class: 'as-dynamic-table-space', }, { class: 'as-dynamic-table-fixed-y-ctn' }, { class: 'as-dynamic-table-fixed-x-ctn' }, { class: 'as-dynamic-table-fixed-xy-ctn' } ] }, { tag: Scroller/* VScrollbar */.eP, class: 'as-dynamic-table-vb' }, { tag: Scroller/* HScrollbar */.MP, class: 'as-dynamic-table-hb' }, ] }); }; DynamicTable.prototype.extendStyle = {};//init value DynamicTable.prototype.extendStyle.tableLayout = 'fixed'; DynamicTable.prototype.extendStyle.width = 'auto'; DynamicTable.prototype.extendStyle.minWidth = 'unset'; DynamicTable.prototype.styleHandlers = {}; DynamicTable.prototype.styleHandlers.minWidth = { set: function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (!parsedValue) value = 'unset'; else if (parsedValue.value === 'match_parent') value = '100%'; else if (parsedValue.unit === 'px') value = parsedValue.value + parsedValue.unit; if (parsedValue && parsedValue.unit) { this.style.minWidth = value; this.addClass('as-has-min-width'); } else { this.removeClass('as-has-min-width'); } return value; } }; DynamicTable.prototype.styleHandlers.width = { set: function (value) { var parsedValue = (0,attribute.parseMeasureValue)(value); if (!parsedValue) value = 'auto'; else if (parsedValue.value === 'match_parent') value = '100%'; else if (parsedValue.unit === 'px') value = parsedValue.value + parsedValue.unit; if (parsedValue && parsedValue.unit) { this.style.width = value; this.removeClass('as-width-auto'); } else { this.addClass('as-width-auto'); } return value; } }; DynamicTable.prototype.styleHandlers.height = { set: function (value) {//todo: handle expression var parsedValue; if (value && value.indexOf && value.indexOf('--') > 0) { this.style.height = value; } else { parsedValue = (0,attribute.computeMeasureExpression)(value, { elt: this, parentSize: 0 }); if (!parsedValue) value = 'auto'; else if (parsedValue.value === 'match_parent') value = '100%'; else if (parsedValue.unit === 'px') value = parsedValue.value + parsedValue.unit; if (parsedValue && parsedValue.unit) { this.style.height = value; this.removeClass('as-auto-height'); } else { this.addClass('as-auto-height'); } } return value; } }; // // DynamicTable.prototype.width = function (value) { // this.extendStyle.minWidth = value; // }; // DynamicTable.prototype.styleHandlers.tableLayout = { /*** * @this {DynamicTable} * @param value */ set: function (value) { if (value === 'fixed') { this.addClass('as-table-layout-fixed'); } else { this.removeClass('as-table-layout-fixed'); value = 'auto'; } return value; } }; DynamicTable.prototype.addStyle = function (arg0, arg1) { if ((typeof arg0 === "string") && (arg0 in this.extendStyle)) { if (arg0.indexOf('-') > 0) arg0 = (0,stringFormat.kebabCaseToCamelCase)(arg0);//not -- this.extendStyle[arg0] = arg1; } else { AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } return this; }; DynamicTable.prototype.requestUpdateSize = function () { this.layoutCtrl.onResize(); }; DynamicTable.prototype.revokeResource = function () { this.$attachhook.cancelWaiting(); delete pendingTables[this._pendingId]; this.css.stop(); this.css = null; this.revokeResource = noop/* default */.Z; return; var row, cell, keys, key; var rows = this._adapterData && this._adapterData.data && this._adapterData.data.body && this._adapterData.data.body.rows; // if (rows) { // while (rows.length) { // row = rows.pop(); // while (row.cells.length) { // cell = row.cells.pop(); // keys = Object.keys(cell); // while (keys.length){ // key = keys.pop(); // cell[key] = null; // delete cell[key]; // } // } // } // } // revokeResource(rows); if (this.table) { this.table.revokeResource(); this.table = null; } if (this._adapter) { this._adapter.revoke(); this._adapter = null; } this.attachSearchInput(null); this.filterInputs = []; this.waitingCtl = null; this.layoutCtrl = null; this.pointerCtrl = null; this.colSizeCtrl = null; this.rowDragCtrl = null; manager.removeTrash(); ResizeSystem/* default.removeTrash */.Z.removeTrash(); }; DynamicTable.prototype.getSavedState = function () { var res = {}; res.scrollTop = this.$vscrollbar.innerOffset; res.scrollLeft = this.$hscrollbar.innerOffset; return res; }; DynamicTable.prototype.setSavedState = function (state) { this.readySync.then(() => { state = state || {}; this.$vscrollbar.innerOffset = state.scrollTop || 0; this.$hscrollbar.innerOffset = state.scrollLeft || 0; this.$hscrollbar.emit('scroll'); this.$vscrollbar.emit('scroll'); }); }; DynamicTable.prototype.addRowBefore = function (rowData, bf) { return this.table.body.addRowBefore(rowData, bf); }; DynamicTable.prototype.addRowAfter = function (rowData, at) { return this.table.body.addRowAfter(rowData, at); }; DynamicTable.prototype.replaceRow = function (rowData, rp) { var row = this.rowOf(rp); if (row) { row.updateData(rowData); } ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }; DynamicTable.prototype.addRow = function (rowData, idx) { return this.table.body.addRow(rowData, idx); }; DynamicTable.prototype.addRows = function (rowsData, idx) { return this.table.body.addRows(rowsData, idx); }; DynamicTable.prototype.removeRow = function (row) { return this.table.body.removeRow(row); }; DynamicTable.prototype.rowAt = function (idx) { return this.table.body.rowAt(idx); }; DynamicTable.prototype.rowOf = function (o) { return this.table.body.rowOf(o); }; DynamicTable.prototype.rowIndexOf = function (o) { return this.table.body.rowIndexOf(o); }; DynamicTable.prototype.getRows = function () { return this.table.body.rows.slice(); }; DynamicTable.prototype.requireRows = function (start, end) { return this.table.body.requireRows(start, end); }; DynamicTable.prototype.clearRows = function () { return this.table.body.clearRows(); }; DynamicTable.prototype.viewIntoRow = function (row) { var counter = 300; var wait = () => { counter--; if (this.isDescendantOf(document.body)) { if (this.hasClass('as-adapt-infinity-grow') || !this.hasClass('as-overflow-y')) { row = this.rowOf(row); if (row) { (0,utils.vScrollIntoView)(row.elt); } } else { this.table.body.viewIntoRow(row);//TODO: CHECK MORE } } else if (counter > 0) { setTimeout(wait, 30); } } setTimeout(wait, 130); }; DynamicTable.prototype.attachSearchInput = function (inputElt) { if (this.$searchInput) { this.$searchInput.off('stoptyping', this.eventHandler.searchModify); this.$searchInput.off('keyup', this.eventHandler.searchKeyUp); } this.$searchInput = inputElt; if (this.$searchInput) { if (this.$searchInput.$table) { this.$searchInput.off('stoptyping', this.$searchInput.$table.eventHandler.searchModify); this.$searchInput.off('keyup', this.$searchInput.$table.eventHandler.searchKeyUp); } this.$searchInput.$table = this; this.$searchInput.on('stoptyping', this.eventHandler.searchModify); this.$searchInput.on('keyup', this.eventHandler.searchKeyUp); } }; DynamicTable.prototype.filter = function (filter) { var query = {}; var queryText = (this.$searchInput && this.$searchInput.value) || ''; queryText = queryText.trim().replace(/\s\s+/g, ' '); var i; if (filter) { for (i in filter) { query.filter = filter; break; } } if (queryText && queryText.length > 0) query.text = queryText; for (i in query) { this.query(query); return; } this.query(null); }; DynamicTable.prototype.makeQuery = function () { var query = {}; var textQuery = this.$searchInput && this.$searchInput.value.trim().replace(/\s\s+/, ' '); if (textQuery && textQuery.length > 0) query.text = textQuery; var i; var filter = this.$filterInputs.reduce(function (ac, elt) { if (elt.exportFilter) { elt.exportFilter(ac); } else if (elt.name) { ac[elt.name] = elt.value; } return ac; }, {}); var sort = (0,ACore.$$)('th', this.table.header.elt).reduce((ac, cr) => { var key = cr.attr('data-sort-key'); var order = cr.attr('data-sort-order'); if (key && order && order !== 'none') { ac.push({ key: key, order: order }); } return ac; }, []); for (i in filter) { query.filter = filter; break; } if (sort.length > 0) { query.sort = sort; } for (i in query) { return query; } return null; }; DynamicTable.prototype.requestQuery = function () { var query = this.makeQuery(); this.query(query); }; DynamicTable.prototype.query = function (query) { this.table.body.query(query); }; DynamicTable.prototype.addFilter = function (inputElt) { if (inputElt.$dynamicTable) { inputElt.$dynamicTable.removeFilter(inputElt); } inputElt.$dynamicTable = this; inputElt.on('change', this.eventHandler.searchModify); this.$filterInputs.push(inputElt); }; DynamicTable.prototype.removeFilter = function (inputElt) { if (inputElt.$dynamicTable !== this) return; inputElt.$dynamicTable = null; inputElt.off('change', this.eventHandler.searchModify); var idx = this.$filterInputs.indexOf(inputElt); if (idx >= 0) this.$filterInputs.splice(idx, 1); }; DynamicTable.prototype.notifyRowChange = function (row) { var idx = this.table.body.rowIndexOf(row); if (idx >= 0) this.table.body.onRowSplice(idx) }; DynamicTable.prototype.notifyRowsChange = noop/* default */.Z; DynamicTable.property = {}; DynamicTable.property.adapter = { /*** * @this DynamicTable * @param data */ set: function (data) { if (!data) return this._adapterData = data; this._adapter = new dynamictable_DTDataAdapter(this, data); this.layoutCtrl.onAdapter(); this.table = new dynamictable_DTTable(this, this._adapterData.data); this.$space.clearChild().addChild(this.table.elt); this.$fixedYCtn.clearChild().addChild(this.table.fixedYElt); this.$fixedXCtn.clearChild().addChild(this.table.fixedXElt); this.$fixedXYCtn.clearChild().addChild(this.table.fixedXYElt); if (this.extendStyle) this.addStyle(this.extendStyle); setTimeout(() => { this.requestUpdateSize(); }, 10); setTimeout(() => { this.requestUpdateSize(); }, 30); setTimeout(() => { this.requestUpdateSize(); }, 100); }, get: function () { return this._adapterData; } }; DynamicTable.property.filterInputs = { set: function (inputs) { inputs = inputs || []; this.$filterInputs.slice().forEach(input => { this.removeFilter(input); }); inputs.forEach(input => this.addFilter(input)); }, get: function () { return this.$filterInputs; } }; DynamicTable.property.hiddenColumns = { set: function (value) { value = value || []; this._hiddenColumns.forEach(function (idxV) { this.removeClass('as-hide-col-' + idxV); }.bind(this)); this._hiddenColumns = value; this._hiddenColumns.forEach(function (idxV) { this.addClass('as-hide-col-' + idxV); }.bind(this)); var c = this.parentElement; while (c) { if (c.hasClass && c.hasClass('absol-table-vscroller') && c.update) { c.update(); break; } c = c.parentElement; } ResizeSystem/* default.update */.Z.update(); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }, get: function () { return this._hiddenColumns; } } /*** * @memberOf {DynamicTable#} * @type {{}} */ DynamicTable.eventHandler = {}; /*** * @this DynamicTable# * @param event */ DynamicTable.eventHandler.searchModify = function (event) { this.requestQuery(); }; /*** * @this DynamicTable# * @param event */ DynamicTable.eventHandler.searchKeyUp = function (event) { setTimeout(function () { var query = this.$searchInput.value; query = query.trim().replace(/\s+/, ' '); if (query.length) this.table.body.startSearchingIfNeed(); }.bind(this), 30); }; DynamicTable.prototype.getColWidth = function () { return this.colSizeCtrl.getColWidth(); }; DynamicTable.prototype.setColWidth = function (colId, value) { return this.colSizeCtrl.setColWidth(colId, value); }; ACore/* default.install */.Z.install(DynamicTable); /* harmony default export */ const dynamictable_DynamicTable = (DynamicTable); /*** * * @param {DynamicTable} elt * @constructor */ function LayoutController(elt) { /*** * * @type {DynamicTable} */ this.elt = elt; this.maxRows = Math.ceil(Math.max((0,Dom/* getScreenSize */.tE)().height / 40, 1080 / 40)); this.offset = Vec2/* default.ZERO */.Z.ZERO; Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) this[key] = this[key].bind(this); }); this.elt.$hscrollbar.on('scroll', this.ev_hScrollbarScroll); this.elt.$vscrollbar.on('scroll', this.ev_vScrollbarScroll); this.elt.$viewport.on('scroll', this.ev_viewportScroll); this.elt.on('wheel', this.ev_wheel); this.scrollingDir = Vec2/* default.ZERO */.Z.ZERO; this.scrollingStartOffset = Vec2/* default.ZERO */.Z.ZERO; } /*** * * @param {WheelEvent} event */ LayoutController.prototype.ev_wheel = function (event) { var vScroller = (0,utils.findVScrollContainer)(event.target); if (vScroller && vScroller.hasClass && vScroller.hasClass('as-bscroller')) return; var isOverflowY = this.elt.hasClass('as-overflow-y'); var isOverflowX = this.elt.hasClass('as-overflow-x'); var dy = event.deltaY; var prevOffset; if (isOverflowY && (!event.shiftKey || !isOverflowX)) { prevOffset = this.elt.$vscrollbar.innerOffset; if (dy > 0) { this.elt.$vscrollbar.innerOffset = Math.max( Math.min(prevOffset + 100 / 40, this.elt.$vscrollbar.innerHeight - this.elt.$vscrollbar.outerHeight), 0); if (prevOffset !== this.elt.$vscrollbar.innerOffset) { event.preventDefault(); this.elt.$vscrollbar.emit('scroll'); } } else if (dy < 0) { this.elt.$vscrollbar.innerOffset = Math.max( Math.min(prevOffset - 100 / 40, this.elt.$vscrollbar.innerHeight - this.elt.$vscrollbar.outerHeight), 0); if (prevOffset !== this.elt.$vscrollbar.innerOffset) { event.preventDefault(); this.elt.$vscrollbar.emit('scroll'); } } } else if (isOverflowX && (event.shiftKey || !isOverflowY)) { prevOffset = this.elt.$hscrollbar.innerOffset; if (dy > 0) { this.elt.$hscrollbar.innerOffset = Math.max( Math.min(prevOffset + 100, this.elt.$hscrollbar.innerWidth - this.elt.$hscrollbar.outerWidth), 0); if (prevOffset !== this.elt.$hscrollbar.innerOffset) { event.preventDefault(); this.elt.$hscrollbar.emit('scroll'); } } else if (dy < 0) { this.elt.$hscrollbar.innerOffset = Math.max( Math.min(prevOffset - 100, this.elt.$hscrollbar.innerWidth - this.elt.$hscrollbar.outerWidth), 0); if (prevOffset !== this.elt.$hscrollbar.innerOffset) { event.preventDefault(); this.elt.$hscrollbar.emit('scroll'); } } } }; LayoutController.prototype.onAdapter = function () { var adapter = this.elt.adapter; if (this.elt.style.height === 'auto') { this.elt.removeStyle('height'); this.elt.addClass('as-adapt-infinity-grow'); } if (adapter.fixedCol > 0) { this.elt.addClass('as-has-fixed-col'); } else { this.elt.removeClass('as-has-fixed-col'); } if (adapter.rowsPerPage === Infinity) { this.elt.addClass('as-adapt-infinity-grow'); } if (!adapter.data.head || !adapter.data.head.rows || !adapter.data.head.rows[0] || !adapter.data.head.rows[0].cells || !adapter.data.head.rows[0].cells[0]) { this.elt.addClass('as-headless'); } else { this.elt.removeClass('as-headless'); } }; LayoutController.prototype.handleMinWidth = function () { var minWidth = this.elt.extendStyle.minWidth || this.elt.table.elt.getComputedStyleValue('min-width'); var mv = (0,attribute.parseMeasureValue)(minWidth); if (!mv) return; if (mv.unit !== 'px') return; if (!this.elt.table.elt.firstChild || !this.elt.table.elt.firstChild.firstChild) return; var bound = this.elt.table.elt.firstChild.firstChild.getBoundingClientRect(); if (bound.width >= mv.value) return; //copyElt var cells = this.elt.table.header.rows[0].cells; var freeCells = cells.filter(cell => { return !cell.data.style || !cell.data.style.width; }); if (freeCells.length === 0) return; var cellWidths = freeCells.map(cell => cell.copyElt.getBoundingClientRect().width); var sumWidth = cellWidths.reduce((ac, w) => ac + w, 0); var needGrowUp = mv.value - bound.width; freeCells.forEach((cell, i) => { var width = cellWidths[i]; var newWidth = width + width / sumWidth * needGrowUp; var paddingLeft = cell.copyElt.getComputedStyleValue('padding-left') || '0px'; var paddingRight = cell.copyElt.getComputedStyleValue('padding-right') || '0px'; paddingLeft = parseFloat(paddingLeft.replace('px', '')); paddingRight = parseFloat(paddingRight.replace('px', '')); cell.copyElt.addStyle('width', newWidth + 'px'); cell.copyElt.addStyle('--as-force-min-width', newWidth - paddingLeft - paddingRight - 1 + 'px'); cell.elt.addClass('as-col-width-auto'); cell.copyElt.addClass('as-col-width-auto'); cell.elt.addStyle('--as-force-min-width', newWidth - paddingLeft - paddingRight - 1 + 'px'); if (cell._copyElt1) { cell._copyElt1.addStyle('--as-force-min-width', newWidth - paddingLeft - paddingRight - 1 + 'px'); cell._copyElt1.addClass('as-col-width-auto'); } if (cell._copyElt2) { cell._copyElt2.addClass('as-col-width-auto'); cell._copyElt2.addStyle('--as-force-min-width', newWidth - paddingLeft - paddingRight - 1 + 'px'); } }); }; LayoutController.prototype.handleDisplay = function () { if (!this.elt.hasClass('as-width-match-parent')) { return; } var tableWidth = this.elt.table.elt.getBoundingClientRect().width; var viewportWidth = this.elt.$viewport.getBoundingClientRect().width; if (tableWidth < viewportWidth - 17 && !this.elt.hasClass('as-table-layout-fixed')) { this.elt.table.elt.addStyle('width', viewportWidth - 17 + 'px'); } if (!this.elt.hasClass('as-table-layout-fixed')) { this.elt.table.elt.addStyle('min-width', viewportWidth - 17 + 'px'); } }; LayoutController.prototype.onAttached = function () { ResizeSystem/* default.updateUp */.Z.updateUp(this.elt.parentElement); this.update(); if (this.elt.table) { this.handleDisplay(); this.handleMinWidth(); this.elt.table.updateCopyEltSize(); this.updateOverflowStatus(); this.elt.$vscrollbar.once('scroll', () => { // return; setTimeout(() => { if (this.elt.table.body.rows.length === 0) return; var tableId = this.elt.id; var rows = this.elt.table.header.rows; if (!rows || rows.length === 0) return; var changed = false; var colDict = {}; rows.forEach(row => { var cells = row.cells; if (!cells) return; cells.forEach(cell => { var colId = cell.data.id; var bound; if (cell.colspan > 1) return; if (!colId && !colDict[cell.idx]) {//local style bound = cell.copyElt.getBoundingClientRect(); if (bound.width > 0) { this.elt.css.setProperty(`#${this.elt.id} th[data-col-idx="${cell.idx}"]:not(colspan)`, 'width', bound.width + 'px') .commit(); } return; } if (!manager.hasColSize(tableId, colId)) { bound = cell.copyElt.getBoundingClientRect(); if (bound.width) { manager.setColWidth(tableId, colId, bound.width); changed = true; } } }); }) if (changed) manager.commit(); }, 100); }); } }; LayoutController.prototype.update = function () { var stWidth = this.elt.extendStyle.width; var psWidth = (0,attribute.parseMeasureValue)(this.elt.extendStyle.width); var stHeight = this.elt.extendStyle.height; var psHeight = (0,attribute.computeMeasureExpression)(stHeight, { elt: this, parentSize: (this.elt.parentElement ? this.elt.parentElement.getBoundingClientRect().height : 0) }); var cpStyle = getComputedStyle(this.elt); var psMaxHeight = (0,attribute.parseMeasureValue)(cpStyle.getPropertyValue('max-height')); var psMinWidth = (0,attribute.parseMeasureValue)(cpStyle.getPropertyValue('min-width')); var parentElt = this.elt.parentElement; var parentCpStyle; var parentBound; var screenSize; var singleView = (() => { var ctn = this.elt.parentElement && this.elt.parentElement.parentElement; if (!ctn) return false; if (!ctn.hasClass || !ctn.hasClass('absol-single-page-scroller-viewport')) return false; if (ctn.lastChild === ctn.firstChild && ctn.firstChild === this.elt) return singleView; })(); var singleViewBound; var getMaxBoundHeight = () => { var mxH = Infinity; if (this.elt.hasClass('as-adapt-infinity-grow')) return Infinity; if (!psHeight) { } else if (psHeight.unit === 'px') { mxH = psHeight.value; } else if (psHeight.unit === '%' && parentElt) { parentBound = parentBound || parentElt.getBoundingClientRect(); mxH = parentBound.height * psHeight.value / 100; } else if (psHeight.unit === 'vh') { screenSize = screenSize || (0,Dom/* getScreenSize */.tE)(); mxH = screenSize.height * psHeight.value / 100; } if (psMaxHeight && psMaxHeight.unit === 'px') { mxH = Math.min(mxH, psMaxHeight.value); } return mxH; } var getMinInnerWidth = () => { var mnWidth = 0; var paddingLeft, paddingRight; if (!psWidth) { } else if (psWidth.unit === 'px') { mnWidth = psWidth.value; } else if (psWidth.unit === '%' && parentElt) { parentBound = parentBound || parentElt.getBoundingClientRect(); parentCpStyle = parentCpStyle || getComputedStyle(parentElt); paddingLeft = parseFloat((parentCpStyle.getPropertyValue('padding-left') || '0px').replace('px', '')); paddingRight = parseFloat((parentCpStyle.getPropertyValue('padding-right') || '0px').replace('px', '')); mnWidth = (parentBound.width - paddingLeft - paddingRight) * psWidth.value / 100; } else if (psWidth.unit === 'vw') { screenSize = screenSize || (0,Dom/* getScreenSize */.tE)(); mnWidth = screenSize.width * psWidth.value / 100; } if (psMinWidth && psMinWidth.unit === 'px') { mnWidth = Math.max(mnWidth, psMinWidth.value); } return mnWidth; }; var bound, tbBound; var maxHeight; if (!this.elt.table) return; if (stWidth === 'auto') {//table max-width is 100% of parentWidth this.elt.table.elt.addStyle('min-width', Math.max(getMinInnerWidth() - 17, 0) + 'px'); } else if (psWidth.unit === 'px' || psWidth.unit === 'vw' || psWidth.unit === '%') { this.elt.table.elt.addStyle('min-width', getMinInnerWidth() - 17 + 'px'); bound = this.elt.getBoundingClientRect(); if (bound.width > 0 && !this.elt.table.body.offset) {//if overflowY this.elt.table.body.offset >0 tbBound = this.elt.table.elt.getBoundingClientRect(); // if (singleView) { // // singleViewBound = // } // if (this.elt.parentElement && this.elt.parentElement.) maxHeight = getMaxBoundHeight(); if (!maxHeight || maxHeight.value >= tbBound) { this.elt.table.elt.addStyle('min-width', getMinInnerWidth() + 'px'); //isOverflowY = false; } else { //isOverflowY = true; } } } }; LayoutController.prototype.onResize = function () { this.update(); this.updateOverflowStatus(); this.updateScrollbarStatus(); if (this.elt.table) { this.elt.table.updateCopyEltSize(); this.updateLines(); } }; LayoutController.prototype.updateOverflowStatus = function () { var contentBound = this.elt.table ? this.elt.table.elt.getBoundingClientRect() : { width: 0, height: 0 }; var bound = this.elt.getBoundingClientRect(); var cpStyle = getComputedStyle(this.elt); var psMaxHeight = (0,attribute.parseMeasureValue)(cpStyle.getPropertyValue('max-height')); if (bound.width < contentBound.width) { this.elt.addClass('as-overflow-x'); } else { this.elt.removeClass('as-overflow-x'); this.elt.$space.removeStyle('left'); } if (this.elt.hasClass('as-adapt-infinity-grow')) { this.elt.removeClass('as-overflow-y'); this.elt.$space.removeStyle('top'); } else if (bound.height < contentBound.height || (psMaxHeight && psMaxHeight.unit === 'px' && bound.width < contentBound.width + 17 && psMaxHeight.value < contentBound.height + 18)) { this.elt.addClass('as-overflow-y'); } else { this.elt.removeClass('as-overflow-y'); this.elt.$space.removeStyle('top'); } this.elt.addStyle('--dt-content-height', contentBound.height + 'px'); this.elt.addStyle('--dt-content-width', contentBound.width + 'px'); }; LayoutController.prototype.updateScrollbarStatus = function () { //todo: not overflow y if (!this.elt.table) return; var childNodes = this.elt.table.body.elt.childNodes; var vBound = this.elt.$viewport.getBoundingClientRect(); var headBound = this.elt.table.header.elt.getBoundingClientRect(); var availableHeight = vBound.height - headBound.height; var rBound; var outer = 0; var sHeight = 1;//border of last row for (var i = 0; i < childNodes.length; ++i) { rBound = childNodes[childNodes.length - 1 - i].getBoundingClientRect(); sHeight += rBound.height; if (sHeight >= availableHeight) { outer = i + (1 - (sHeight - availableHeight) / rBound.height); break; } } this.elt.$vscrollbar.outerHeight = outer; this.elt.$vscrollbar.innerHeight = this.elt.table.body.curentMode.viewedRows.length; this.elt.$vscrollbar.innerOffset = this.elt.table.body.curentMode.offset; var viewportBound = this.elt.$viewport.getBoundingClientRect(); var tableBound = this.elt.table.elt.getBoundingClientRect(); this.elt.$hscrollbar.innerWidth = tableBound.width; this.elt.$hscrollbar.outerWidth = viewportBound.width; if (this.elt.$hscrollbar.innerOffset + this.elt.$hscrollbar.outerWidth > this.elt.$hscrollbar.innerWidth) { this.elt.$hscrollbar.innerOffset = Math.max(0, this.elt.$hscrollbar.innerWidth - this.elt.$hscrollbar.outerWidth); this.elt.$hscrollbar.emit('scroll'); } if (tableBound.width < viewportBound.width) { this.elt.$vscrollbar.addStyle('right', viewportBound.width - tableBound.width + 'px'); } else { this.elt.$vscrollbar.removeStyle('right'); } // this.$vscrollbar }; LayoutController.prototype.updateLines = function () { var fixXBound, headerBound; if (this.elt.hasClass('as-overflow-x') && this.elt.hasClass('as-has-fixed-col')) { fixXBound = this.elt.$fixedXCtn.getBoundingClientRect(); this.elt.addStyle('--dt-fixed-x-width', fixXBound.width + 'px'); } if (this.elt.hasClass('as-overflow-y')) { headerBound = this.elt.$fixedYCtn.firstChild.getBoundingClientRect(); this.elt.addStyle('--dt-header-height', headerBound.height + 'px'); } }; LayoutController.prototype.ev_hScrollbarScroll = function (event) { this.elt.$space.addStyle('left', -this.elt.$hscrollbar.innerOffset + 'px'); this.elt.$fixedYCtn.addStyle('left', -this.elt.$hscrollbar.innerOffset + 'px'); this.elt.$viewport.emit('scroll'); }; LayoutController.prototype.ev_vScrollbarScroll = function () { if (!this.elt.table || !this.elt.table.body) return; this.elt.table.body.offset = this.elt.$vscrollbar.innerOffset; this.elt.$viewport.emit('scroll'); }; LayoutController.prototype.ev_dragStart = function (event) { var isOverflowY = this.elt.hasClass('as-overflow-y'); var isOverflowX = this.elt.hasClass('as-overflow-x'); var dir = event.currentPoint.sub(event.startingPoint); if (isOverflowY && Math.abs(dir.y) > Math.abs(dir.x)) { this.scrollingDir = new Vec2/* default */.Z(0, 1); event.preventDefault(); } else if (isOverflowX && Math.abs(dir.y) < Math.abs(dir.x)) { this.scrollingDir = new Vec2/* default */.Z(1, 0); event.preventDefault(); } else { this.scrollingDir = Vec2/* default.ZERO */.Z.ZERO; } this.scrollingStartOffset = new Vec2/* default */.Z(this.elt.$hscrollbar.innerOffset, this.elt.$vscrollbar.innerOffset); }; LayoutController.prototype.ev_drag = function (event) { var changed = false; var dir = event.currentPoint.sub(event.startingPoint); var newOffset = new Vec2/* default */.Z(0, 0); if (this.scrollingDir.x !== 0) { newOffset.x = Math.max(0, Math.min(this.elt.$hscrollbar.innerWidth - this.elt.$hscrollbar.outerWidth, this.scrollingStartOffset.x - dir.x)); if (this.elt.$hscrollbar.innerOffset !== newOffset.x) { changed = true; this.elt.$hscrollbar.innerOffset = newOffset.x; this.elt.$hscrollbar.emit('scroll'); } } else if (this.scrollingDir.y !== 0) { newOffset.y = Math.max(0, Math.min(this.elt.$vscrollbar.innerHeight - this.elt.$vscrollbar.outerHeight, this.scrollingStartOffset.y - dir.y / 40)); if (this.elt.$vscrollbar.innerOffset !== newOffset.y) { changed = true; this.elt.$vscrollbar.innerOffset = newOffset.y; this.elt.$vscrollbar.emit('scroll'); } } if (changed) event.preventDefault(); }; LayoutController.prototype.ev_dragEnd = function (event) { }; LayoutController.prototype.ev_viewportScroll = function (event) { if (this.elt.$viewport.scrollLeft !== 0) { this.elt.$hscrollbar.innerOffset += this.elt.$viewport.scrollLeft; this.elt.$viewport.scrollLeft = 0; this.elt.$hscrollbar.emit('scroll'); } if (this.elt.$viewport.scrollTop !== 0) { this.elt.$vscrollbar.innerOffset += this.elt.$viewport.scrollTop / 30;//todo: better solution this.elt.$viewport.scrollTop = 0; this.elt.$vscrollbar.emit('scroll'); } }; /*** * * @param {DynamicTable} elt * @constructor */ function PointerController(elt) { Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) this[key] = this[key].bind(this); }); /*** * * @type {DynamicTable} */ this.elt = elt; this.elt.$viewport.hangon = 5; this.elt.$viewport.on('draginit', this.ev_dragInit); this.elt.$viewport.on('dragstart', this.ev_dragStart); this.elt.$viewport.on('drag', this.ev_drag); this.elt.$viewport.on('dragend', this.ev_dragEnd); this.destHandler = null; } PointerController.prototype.isInDragZone = function (elt) { while (elt && elt !== this.elt) { if (elt.classList.contains('as-drag-zone')) return true; elt = elt.parentElement; } return false; }; PointerController.prototype.isInInput = function (elt) { while (elt) { if (elt.tagName === 'INPUT') return true; if (elt.tagName === 'TD') return false; var clazz = elt.getAttribute('class') || ''; if (clazz.indexOf('input') >= 0) return true; if (clazz.indexOf('input') >= 0) return true; if (clazz.indexOf('menu') >= 0) return true; elt = elt.parentElement; } return false; }; PointerController.prototype.isInColResizer = function (elt) { return !!(elt.hasClass && elt.hasClass('as-dt-header-cell-resizer')); }; PointerController.prototype.ev_dragInit = function (event) { if (this.isInDragZone(event.target)) { event.preventDefault(); this.destHandler = this.elt.rowDragCtrl; } if (this.isInColResizer(event.target)) { event.preventDefault(); this.destHandler = this.elt.colSizeCtrl; } else if (this.isInInput(event.target)) { event.cancel(); return; } else if (event.isTouch) { // event.preventDefault();//todo: check } } PointerController.prototype.ev_dragStart = function (event) { var dir = event.currentPoint.sub(event.startingPoint).normalized(); var ox = new Vec2/* default */.Z(1, 0); var oy = new Vec2/* default */.Z(0, 1); if (this.destHandler) { event.preventDefault && event.preventDefault(); this.destHandler.ev_dragStart(event); } else if (event.isTouch && (Math.abs(dir.dot(ox)) < 0.3 || Math.abs(dir.dot(oy)) < 0.3)) { event.preventDefault && event.preventDefault(); this.destHandler = this.elt.layoutCtrl; this.destHandler.ev_dragStart(event); } else { this.destHandler = null; } }; PointerController.prototype.ev_drag = function (event) { if (this.destHandler) { event.preventDefault && event.preventDefault(); this.destHandler.ev_drag(event); } } PointerController.prototype.ev_dragEnd = function (event) { if (this.destHandler) { event.preventDefault && event.preventDefault(); this.destHandler.ev_dragEnd(event); } this.destHandler = null; }; PointerController.prototype.ev_dragDeinit = function (event) { }; /*** * * @param {DynamicTable} elt * @constructor */ function ColSizeController(elt) { this.elt = elt; this.colId = null;//number: col index, string: ident this.startingBound = null; this.cellElt = null; this.cell = null; } ColSizeController.prototype.onAttached = function () { }; ColSizeController.prototype.onAdapter = function () { }; ColSizeController.prototype.ev_dragStart = function (event) { if (!this.elt.isDescendantOf(document.body)) return; this.dragOK = true; this.colId = event.target.parentElement.attr('data-col-id') || parseInt(event.target.parentElement.attr('data-col-idx')); this.cell = this.elt.table.header.rows[0].cells.find(cell => cell.data.id === this.colId || cell.idx === this.colId); if (!this.cell) { this.dragOK = false; return; } this.cellElt = this.cell.copyElt; this.startingBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.cellElt.getBoundingClientRect()); }; ColSizeController.prototype.ev_drag = function (event) { if (!this.dragOK) return; if (!this.elt.isDescendantOf(document.body)) return; var newWidth = this.startingBound.width + event.currentPoint.sub(event.startingPoint).x; this.cellElt.addStyle('width', newWidth + 'px'); this.elt.table.updateCopyEltSize(); //todo: split code var viewportBound = this.elt.$viewport.getBoundingClientRect(); var tableBound = this.elt.table.elt.getBoundingClientRect(); if (tableBound.width < viewportBound.width) { this.elt.$vscrollbar.addStyle('right', viewportBound.width - tableBound.width + 'px'); } else { this.elt.$vscrollbar.removeStyle('right'); } this.elt.addStyle('--dt-content-height', tableBound.height + 'px'); this.elt.addStyle('--dt-content-width', tableBound.width + 'px'); }; ColSizeController.prototype.ev_dragEnd = function (event) { if (!this.dragOK) return; if (!this.cell) return; if (!this.elt.isDescendantOf(document.body)) return; if (typeof this.colId === "string") { if (this.cell.colspan === 1) manager.commitColWidth(this.elt, this.elt.id, this.cell.data.id, this.cellElt.getBoundingClientRect().width, true); this.notifyColResize(event); } else { if (this.cell.colspan === 1) this.elt.css.setProperty(`#${this.elt.id} th[data-col-idx="${this.colId}"]:not([colspan])`, 'width', this.cellElt.getBoundingClientRect().width + 'px').commit(); } this.elt.requestUpdateSize(); setTimeout(() => { if (!this.cellElt.isDescendantOf(document.body)) return; this.cellElt.removeStyle('width'); this.elt.requestUpdateSize(); }, 150); }; ColSizeController.prototype.getColWidth = function () { var res = {}; this.elt.table.header.rows[0].cells.forEach(cell => { var id = cell.data.id; if (typeof id === "string" || typeof id === "number") id = '' + id; if (!id) return; Object.defineProperty(res, id, { enumerable: true, get: () => { return cell.copyElt.getBoundingClientRect().width; } }) }); return res; }; ColSizeController.prototype.setColWidth = function (colId, value) { var cell = this.elt.table.header.rows[0].cells.find(cell => cell.data.id === colId || cell.idx === colId); cell.copyElt.removeStyle('width'); if (typeof colId === "string") { if (cell.colspan !== 1) manager.commitColWidth(this.elt, this.elt.id, colId, value, true); } else { this.elt.css.setProperty(`#${this.elt.id} th[data-col-idx="${colId}"]:not([colspan])`, 'width', value + 'px').commit(); } this.elt.requestUpdateSize(); }; ColSizeController.prototype.notifyColResize = function (originalEvent) { var event = { type: 'colresize', target: this, colId: this.colId, width: this.cellElt.getBoundingClientRect().width, originalEvent: originalEvent.originalEvent || event }; var colWidth; Object.defineProperty(event, 'colWidth', { get: () => { if (colWidth) return colWidth; colWidth = this.getColWidth(); return colWidth; } }); this.elt.emit('colresize', event, this); }; /** * new version * @param {DynamicTable} elt * @constructor */ function RowDragController(elt) { this.elt = elt; this._isDragging = false; this.prevDragedRow = null; this.ev_clickOutDraggedRow = this.ev_clickOutDraggedRow.bind(this); } RowDragController.prototype._findRow = function (cElt) { while (cElt && cElt !== this.elt) { if (cElt.dtBodyRow) { return cElt.dtBodyRow; } cElt = cElt.parentElement; } return null; } RowDragController.prototype._getZIndex = function () { var e = this.elt.$fixedXYCtn; return (0,utils.findMaxZIndex)(e); }; RowDragController.prototype._updateClass = function () { this.row.body.rows.forEach((row, i) => { if (!row._elt) return; if (this.newIdx < this.rowIdx) { if (i < this.newIdx || i >= this.rowIdx) { row._elt.addStyle('transform', `translate(0, 0)`); } else if (i < this.rowIdx) { row._elt.addStyle('transform', `translate(0, ${this.rowRect.height}px)`); } } else if (this.newIdx > this.rowIdx) { if (i <= this.rowIdx || i > this.newIdx) { row._elt.addStyle('transform', `translate(0, 0)`); row._elt._transformY = this.rowRect.height; } else if (i <= this.newIdx) { row._elt.addStyle('transform', `translate(0, ${-this.rowRect.height}px)`); row._elt._transformY = -this.rowRect.height; } } else { row._elt.addStyle('transform', `translate(0, 0)`); row._elt._transformY = 0; } }) }; RowDragController.prototype._computeRowBound = function () { this.firstBoundIdx = this.elt.rowIndexOf(this.row.body.elt.firstChild); this.bounds = Array.prototype.map.call(this.row.body.elt.childNodes, (elt, i) => { var rect = Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect()); rect.y -= elt._transformY || 0; return rect; }); }; RowDragController.prototype._computeNewIdx = function () { var firstBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.row.body.elt.firstChild.getBoundingClientRect()); var delta = firstBound.A().sub(this.bounds[0].A()); var cBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.ctn.getBoundingClientRect()); var y0 = this.bounds[0].y + delta.y; var nearest = Infinity; this.newIdx = this.firstBoundIdx; var cur; var S = []; S['-1'] = 0; var i, y; for (i = 0; i < this.bounds.length; ++i) { S.push(S[i - 1] + this.bounds[i].height); } for (i = 0; i < this.bounds.length; ++i) { cur = this.firstBoundIdx + i; if (cur <= this.rowIdx) { y = y0 + S[i - 1]; } else { y = y0 + S[i] - cBound.height; } if (nearest > Math.abs(cBound.y - y) + 0.1 && this.row.body.rows[cur].draggable) { nearest = Math.abs(cBound.y - y); this.newIdx = cur; } } }; RowDragController.prototype.ev_dragStart = function (event) { if (this.elt.table.body.curentMode.name !== 'normal') return; if (this.prevDragRow) { this.prevDragRow.elt.removeClass('as-dragged'); this.prevDragRow = null; } this.elt.addClass('as-row-dragging'); this.row = this._findRow(event.target); this.body = this.row.body; this.rowIdx = this.elt.rowIndexOf(this.row); this.newIdx = this.rowIdx; this.clonedTable = this._cloneTableRow(this.row); this.ctn = (0,ACore._)({ class: 'as-dt-body-row-cloned-ctn', style: { zIndex: this._getZIndex() + 20, cursor: 'move', opacity: 0.9 }, child: (0,ACore.$)(this._cloneTableRow(this.row)).removeStyle('transform') }).addTo(document.body); this.row.elt.addClass('as-dragging'); this.rowRect = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.row.elt.getBoundingClientRect()); this.elt.addStyle('--dt-dragging-row-height', this.rowRect.height); this.viewportRect = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.$viewport.getBoundingClientRect()); this.headerRect = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.$fixedYCtn.getBoundingClientRect()); this.pointeroffset = event.startingPoint.sub(this.rowRect.A()); this.ctn.addStyle({ top: this.rowRect.y + 'px', left: this.rowRect.x + 'px' }); this._computeRowBound(); this._computeNewIdx(); this._updateClass(); this._isDragging = true; }; RowDragController.prototype.ev_rowRenderChange = function () { if (!this._isDragging) return; this._computeRowBound(); this._computeNewIdx(); this._computeNewIdx(); this._updateClass(); }; /** * * @param {DTBodyRow}row * @private */ RowDragController.prototype._cloneTableRow = function (row) { var tableElt = (0,ACore.$)(row.body.table.elt.cloneNode(false)) .addStyle({ tableLayout: 'fixed', width: row.body.table.elt.getBoundingClientRect().width + 'px' }); var tBodyElt = (0,ACore.$)(row.body.elt.cloneNode(false)); tableElt.addChild(tBodyElt); var rowElt = (0,ACore.$)(this.row.elt.cloneNode(false)).addStyle({ height: this.row.elt.getBoundingClientRect().height + 'px', backgroundColor: '#FFF9C4'//this.row.elt.getComputedStyleValue('background-color') }); tBodyElt.addChild(rowElt); this.row.cells.forEach(cell => { var width = cell.elt.getBoundingClientRect().width; (0,ACore.$)(cell.elt.cloneNode(true)).addStyle({ width: width + 'px' }).addTo(rowElt); }); return tableElt; }; RowDragController.prototype.ev_drag = function (event) { var newY = event.currentPoint.sub(this.pointeroffset).y; this.ctn.addStyle('top', newY + 'px'); clearTimeout(this._dragOutTO); var ctnBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.ctn.getBoundingClientRect()); var onDragOutPositive = () => { var dy = ctnBound.D().y - this.viewportRect.D().y; dy /= 1000 / 60 / 4 * this.rowRect.height; dy = Math.min(dy, this.elt.$vscrollbar.innerHeight - this.elt.$vscrollbar.outerHeight - this.elt.$vscrollbar.innerOffset); if (dy > 0.5) {//dy may be very small this.elt.$vscrollbar.innerOffset += dy; this.elt.$vscrollbar.emit('scroll'); } this._computeNewIdx(); this._updateClass(); clearTimeout(this._dragOutTO); this._dragOutTO = setTimeout(onDragOutPositive, 33); }; var onDragOutNegative = () => { var dy = ctnBound.y - this.headerRect.D().y; dy /= 1000 / 60 / 4 * this.rowRect.height; dy = Math.max(dy, -this.elt.$vscrollbar.innerOffset); if (dy < -0.5) {//dy may be very small this.elt.$vscrollbar.innerOffset += dy; this.elt.$vscrollbar.emit('scroll'); } this._computeNewIdx(); this._updateClass(); clearTimeout(this._dragOutTO); this._dragOutTO = setTimeout(onDragOutNegative, 33); }; if (this.viewportRect.D().y < ctnBound.D().y) { this._dragOutTO = setTimeout(onDragOutPositive, 1000 / 60); } else if (this.headerRect.D().y > ctnBound.y) { this._dragOutTO = setTimeout(onDragOutNegative, 100 / 60); } else { this._computeNewIdx(); this._updateClass(); } }; RowDragController.prototype.ev_dragEnd = function (event) { this.elt.addClass('as-row-dragging'); this.elt.removeClass('as-row-dragging'); this.elt.removeStyle('--dragging-row-height'); this.row.elt.removeClass('as-dragging'); this._isDragging = false; clearTimeout(this._dragOutTO); this.ctn.remove(); this.row.body.rows.forEach(row => { if (row._elt) { row._elt.removeStyle('transform'); row._elt._transformY = 0; } }); if (this.newIdx !== this.rowIdx) { this.row.body.moveRowAt(this.rowIdx, this.newIdx); var eventData = { type: 'orderchange', target: this.row, from: this.rowIdx, to: this.newIdx, originalEvent: event, row: this.row, data: this.row.data } if (this.row.data.on && this.row.data.on.orderchange) { this.row.data.on.orderchange.call(this.row, eventData, this.row) } if (this.prevDragRow) { this.prevDragRow.elt.removeClass('as-dragged'); } this.prevDragRow = this.row; this.prevDragRow.elt.addClass('as-dragged'); this.elt.emit('orderchange', eventData, this.body.table.wrapper); setTimeout(() => { document.addEventListener('click', this.ev_clickOutDraggedRow); }, 400); } }; RowDragController.prototype.ev_clickOutDraggedRow = function (event) { var finished = false; if (!this.prevDragRow) { finished = true; } else if (event.target && AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(event.target, this.prevDragRow.elt)) { finished = false; } else if (event.target && event.target.classList && (event.target.classList.contains('absol-scrollbar-button') || event.target.classList.contains('absol-scrollbar'))) { finished = false; } else { finished = true; } if (finished) { if (this.prevDragRow) { this.prevDragRow.elt.removeClass('as-dragged'); this.prevDragRow = null; } document.removeEventListener('click', this.ev_clickOutDraggedRow); } }; function VirtualPageSelector(elt) { this.elt = elt; } VirtualPageSelector.prototype.getSelectedPage = function () { return this.elt.$vscrollbar.innerOffset / 25; }; VirtualPageSelector.prototype.selectPage = function (value) { this.elt.$vscrollbar.innerOffset = value * 25; this.elt.$vscrollbar.emit('scroll'); }; // EXTERNAL MODULE: ./node_modules/absol-acomp/css/objectmergetool.css var objectmergetool = __webpack_require__(4112); // EXTERNAL MODULE: ./node_modules/absol/src/JSMaker/generator.js var generator = __webpack_require__(2914); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/dialog/OMTSelectOptionsDialog.js /*** * @extends Fragment * @param {OMTBaseType} node * @constructor */ function OMTSelectOptionsDialog(node) { Fragment/* default.call */.Z.call(this); this.node = node; this.calc(); this.getView(); this.start(); } OOP/* default.mixClass */.ZP.mixClass(OMTSelectOptionsDialog, Fragment/* default */.Z); OMTSelectOptionsDialog.prototype.calc = function () { this.options = this.node.getSelectOptions(); this.curHash = this.node.getHash(); this.selectedHash = this.curHash; this.selectedOption = null; this.ident = (0,stringGenerate.randomIdent)(5); }; OMTSelectOptionsDialog.prototype.onStart = function () { this.$modal.addTo(document.body); }; OMTSelectOptionsDialog.prototype.onStop = function () { this.$modal.remove(); }; OMTSelectOptionsDialog.prototype.assignResult = function () { if (this.curHash !== this.selectedHash) { this.node.assign(this.selectedOption); this.node.updateRaw(); this.node.notifyChange(); } }; OMTSelectOptionsDialog.prototype._makeOptionRow = function (opt, i, dict) { var descriptor = Object.assign({}, this.node.descriptor); if (i < 0) { descriptor.desc = '(current-mixed)'; } var clazz = this.node.constructor; var node = new clazz(this.node.tool, this.node.parent, descriptor); node.assign(opt); var nodeHash = node.getHash(); if (dict[nodeHash]) return null; dict[nodeHash] = node; var self = this; var radio = (0,ACore._)({ tag: RadioButton/* default.tag */.Z.tag, style: { marginRight: '10px' }, props: { name: this.ident, checked: nodeHash === this.curHash }, on: { change: function () { if (radio.checked) { self.selectedHash = nodeHash; self.selectedOption = opt; } } } }); return (0,ACore._)({ class: 'as-omt-option-row', child: [ radio, node.elt ] }); }; OMTSelectOptionsDialog.prototype.createView = function () { var self = this; this.$view = (0,ACore._)({ tag: MessageDialog/* default.tag */.Z.tag, class: 'as-omt-dialog', props: { dialogTitle: {mlKey:'txt_option'}, dialogActions: [ { text: {mlKey:'txt_ok'}, name: 'ok' }, { text: {mlKey:'txt_cancel'}, name: 'cancel' } ] }, on: { action: function (event) { self.stop() var action = event.action; if (action.name === 'cancel') return; if (action.name === 'ok') { self.assignResult(); } } } }); var dict = {}; var rows = this.options.map((opt, i) => this._makeOptionRow(opt, i, dict)).filter(x => !!x); if (!dict[this.curHash]) { rows.unshift(this._makeOptionRow(this.node.export(), -1, dict)); } this.$view.addChild(rows); this.$modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style:{ zIndex: 1000000, }, child: this.$view }); }; /* harmony default export */ const dialog_OMTSelectOptionsDialog = (OMTSelectOptionsDialog); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTBaseType.js /** * * @constructor */ function OMTBaseType(tool, parent, descriptor) { this.tool = tool; this.parent = parent; this.level = parent ? parent.level + 1 : 0; this.descriptor = descriptor; this.render(); this.elt.omtNode = this; } OMTBaseType.prototype.type = 'base'; OMTBaseType.prototype.commands = [ { name: 'select_other', icon: 'span.mdi.mdi-menu-down', title: 'Select' } ]; OMTBaseType.prototype.render = function () { var self = this; var displayName = 'ROOT'; if (this.descriptor.displayName !== undefined) displayName = this.descriptor.displayName + ''; else if (this.descriptor.name !== undefined) displayName = this.descriptor.name + ''; if (this.descriptor.desc) displayName += this.descriptor.desc; this.elt = (0,ACore._)({ class: ['as-omt-field', 'as-type-' + this.type], style: { '--level': this.level }, child: [ { class: 'as-omt-field-header', child: [ { class: 'as-omt-field-name', child: { text: displayName } } ] }, { class: 'as-omt-field-body' }, { class: 'as-omt-field-raw-ctn' }, { class: 'as-omt-field-command-ctn', child: this.commands.map(command => ({ tag: FlexiconButton/* default.tag */.Z.tag, attr: { 'data-command': command.name }, props: { icon: command.icon, title: command.title }, on: { click: this.execCmd.bind(this, command.name, command) } })) } ], on: { dblclick: function (event) { var target = event.target; while (target) { if (target === this) break; if (target.tagName === 'BUTTON') return; target = target.parentElement; } this.execCmd('select_other'); }.bind(this) } }); this.$commandCtn = (0,ACore.$)('.as-omt-field-command-ctn', this.elt); this.$rawCtn = (0,ACore.$)('.as-omt-field-raw-ctn', this.elt); this.$viewModeBtn = (0,ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, attr: { 'data-command': 'view_mode' }, props: { icon: 'span.mdi.mdi.mdi-code-braces',//code-braces title: 'View Raw' }, on: { click: function () { if (self.elt.hasClass('as-mode-raw')) { self.elt.removeClass('as-mode-raw'); this.icon = 'span.mdi.mdi-code-braces'; this.title = 'View Raw'; } else { self.elt.addClass('as-mode-raw'); this.icon = 'span.mdi.mdi-view-dashboard-edit-outline'; this.title = 'View Guide'; self.updateRaw(); } } } }); this.$commandCtn.addChild(this.$viewModeBtn); this.$body = (0,ACore.$)('.as-omt-field-body', this.elt); }; OMTBaseType.prototype.updateRaw = function () { var rawElt = (0,ACore._)(this.getRaw()); this.$rawCtn.clearChild().addChild(rawElt); }; OMTBaseType.prototype.notifyChange = function () { this.descriptor.onchange && this.descriptor.onchange.call(this, { type: 'change', target: this, descriptor: this.descriptor }, this); this.tool.notifyChange(); }; OMTBaseType.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: {text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': '} }, { tag: 'code', child: {text: (0,generator/* generateJSVariable */.NQ)(this.export())} } ] }; }; OMTBaseType.prototype.assign = function (o) { this.value = o; this.$body.clearChild().addChild((0,ACore._)({ tag: 'code', child: { text: (0,generator/* generateJSVariable */.NQ)(o) } })); }; OMTBaseType.prototype.getHash = function () { return (0,stringUtils/* stringHashCode */.$)((0,generator/* generateJSVariable */.NQ)(this.export())); }; OMTBaseType.prototype.export = function () { return this.value; }; OMTBaseType.prototype.execCmd = function (commandName, command) { if (commandName === 'select_other') { this.userSelect(); } }; OMTBaseType.prototype.getSelectOptions = function () { if (!this.parent) return this.tool.objects; var parentOptions = this.parent.getSelectOptions().filter(x => !!x); var name = this.descriptor.name; return parentOptions.map(ot => ot[name]).filter(ot => ot !== undefined); }; OMTBaseType.prototype.userSelect = function () { new dialog_OMTSelectOptionsDialog(this); }; OMTBaseType.classes = {}; /*** * * @param tool * @param parent * @param descriptor * @returns {OMTBaseType} */ OMTBaseType.make = function (tool, parent, descriptor) { var clazz = OMTBaseType.classes[descriptor.type] || OMTBaseType; return new clazz(tool, parent, descriptor); }; /* harmony default export */ const type_OMTBaseType = (OMTBaseType); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTStruct.js /*** * @extends OMTBaseType * @constructor */ function OMTStruct() { type_OMTBaseType.apply(this, arguments); this.children = (this.descriptor.fields || []).map(field => type_OMTBaseType.make(this.tool, this, field)); this.$body.addChild(this.children.map(child => child.elt)); this.data = null; } OOP/* default.mixClass */.ZP.mixClass(OMTStruct, type_OMTBaseType); OMTStruct.prototype.type = 'struct'; OMTStruct.prototype.assign = function (o) { if (o !== null && typeof o === "object") { this.elt.removeClass('as-null'); this.children.forEach(child => { var name = child.descriptor.name; child.assign(o[name]); }); } else { this.elt.addClass('as-null'); } }; OMTStruct.prototype.export = function () { return this.children.reduce((ac, cr) => { ac[cr.descriptor.name] = cr.export(); return ac; }, {}); }; OMTStruct.prototype.getHash = function () { var hash = this.children.map(c => c.getHash()).join('_'); return (0,stringUtils/* stringHashCode */.$)(hash); }; OMTStruct.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT")+': ' } }, { style:{paddingLeft: '25px'}, child: this.children.map((child=> child.getRaw())) } ] }; }; type_OMTBaseType.classes.struct = OMTStruct; /* harmony default export */ const type_OMTStruct = ((/* unused pure expression or super */ null && (OMTStruct))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTString.js /*** * @extends OMTBaseType * @constructor */ function OMTString() { type_OMTBaseType.apply(this, arguments); this.value = null; } OOP/* default.mixClass */.ZP.mixClass(OMTString, type_OMTBaseType); type_OMTBaseType.classes.string = OMTString; OMTString.prototype.assign = function (o) { this.value = o; this.$body.clearChild(); this.$value = (0,ACore._)({ tag: 'span', child: { text: (o || '') + '' } }); this.$body.addChild(this.$value); }; OMTString.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { tag: 'span', child: { text: this.export() } } ] }; }; /* harmony default export */ const type_OMTString = ((/* unused pure expression or super */ null && (OMTString))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTFile.js /*** * @extends OMTBaseType * @constructor */ function OMTFile() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTFile, type_OMTBaseType); type_OMTBaseType.classes.file = OMTFile; type_OMTBaseType.prototype.type = 'file'; OMTFile.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_FileListItem.tag, class: 'as-omt-field-value' }); this.$body.addChild(this.$value); }; OMTFile.prototype.assign = function (o) { this.value = o; if (o) { this.$value.value = o; this.$value.removeStyle('display'); } else { this.$value.addStyle('display', 'none'); } }; OMTFile.prototype.getRaw = function () { var info = (0,utils.fileInfoOf)(this.value); var href = info.url; return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { tag: 'a', props: { href: href, target:'_blank' }, child: { text: info.name } } ] }; }; /* harmony default export */ const type_OMTFile = (OMTFile); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTImage.js /*** * @extends OMTBaseType * @constructor */ function OMTImage() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTImage, type_OMTBaseType); type_OMTBaseType.classes.image = OMTImage; type_OMTBaseType.prototype.type = 'image'; OMTImage.prototype.assign = function (o) { this.value = o; var title = ''; this.$body.clearChild(); var handle = (val) => { if (!val) return; if (val && val.then) { val.then(handle); return; } if (val && val.url) { handle(val.url); return; } if ((val instanceof File) || (val instanceof Blob)) { val.url = val.url || URL.createObjectURL(val); if (!title && val.filename) title = val.filename; handle(val); return; } if (!title) title = val.split('/').pop().split('?').shift(); this.$value = (0,ACore._)({ tag: 'img', class: 'as-omt-field-value', props: { src: val, title: title } }); this.$body.addChild(this.$value); } handle(o); }; OMTImage.prototype.getRaw = type_OMTFile.prototype.getRaw; /* harmony default export */ const type_OMTImage = ((/* unused pure expression or super */ null && (OMTImage))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTEnum.js /*** * @extends OMTBaseType * @constructor */ function OMTEnum() { type_OMTBaseType.apply(this, arguments); this.value = null; } OOP/* default.mixClass */.ZP.mixClass(OMTEnum, type_OMTBaseType); type_OMTBaseType.classes["enum"] = OMTEnum; OMTEnum.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_SelectTreeMenu.tag, class: 'as-border-none', style: { height: '18px' }, props: { readOnly: true, } }); this.$body.addChild(this.$value); if (this.descriptor.items && this.descriptor.items.then) { this.descriptor.items.then(items => { this.$value.items = items; }); } else { this.$value.items = this.descriptor.items; } } OMTEnum.prototype.assign = function (o) { this.value = o; this.$value.value = o; }; OMTEnum.prototype.getRaw = function () { var text = ''; var holders = this.$value.findItemsByValue(this.export()); if (holders && holders.length > 0) { text = holders[0].item.text; if (holders[0].item.desc) text += ' - ' + holders[0].item.desc; } return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { tag: 'span', child: { text: text } } ] }; }; /* harmony default export */ const type_OMTEnum = ((/* unused pure expression or super */ null && (OMTEnum))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/dialog/OMTArrayMergeDialog.js function hashArrayOf(node) { var res = (node.children || []).map(child => child.getHash()); res.sort((a, b) => a - b); return (0,DataStructure_Array.arrayUnique)(res); } /*** * @extends Fragment * @param {OMTArray} node * @constructor */ function OMTArrayMergeDialog(node) { Fragment/* default.call */.Z.call(this); this.node = node; this.calc(); this.getView(); this.start(); } OOP/* default.mixClass */.ZP.mixClass(OMTArrayMergeDialog, Fragment/* default */.Z); OMTArrayMergeDialog.prototype.calc = function () { this.options = this.node.getSelectOptions(); this.curHash = hashArrayOf(this.node); this.selectedNodes = {}; }; OMTArrayMergeDialog.prototype.onStart = function () { this.$modal.addTo(document.body); }; OMTArrayMergeDialog.prototype.onStop = function () { this.$modal.remove(); }; OMTArrayMergeDialog.prototype.assignResult = function () { var dict = {}; var itemArr = []; var hashArr = []; var node for (var key in this.selectedNodes) { node = this.selectedNodes[key]; if (node.children) { node.children.forEach(cr => { var hash = cr.getHash(); if (dict[hash]) return; dict[hash] = true; itemArr.push(cr.export()); hashArr.push(hash); }); } } if (this.curHash === hashArr && (0,DataStructure_Array.arrayUnique)(this.curHash.concat(hashArr)).length === this.curHash.length) return; this.node.assign(itemArr); this.node.updateRaw(); this.node.notifyChange(); }; OMTArrayMergeDialog.prototype._makeOptionRow = function (opt, i, dict) { var self = this; var descriptor = Object.assign({}, this.node.descriptor); var clazz = this.node.constructor; var node = new clazz(this.node.tool, this.node.parent, descriptor); node.assign(opt); var nodeHash = (0,stringUtils/* stringHashCode */.$)(hashArrayOf(node).join(',')); if (dict[nodeHash]) return null; dict[nodeHash] = node; var checked = (0,DataStructure_Array.arrayUnique)(this.curHash.concat(hashArrayOf(node))).length === this.curHash.length; if (checked) this.selectedNodes[nodeHash] = node; var radio = (0,ACore._)({ tag: CheckBoxInput/* default.tag */.Z.tag, style: { marginRight: '10px' }, props: { checked: checked }, on: { change: function () { if (radio.checked) { self.selectedNodes[nodeHash] = node; } else { delete self.selectedNodes[nodeHash]; } self.$view.$actionBtns[1].disabled = Object.keys(self.selectedNodes).length === 0; } } }); return (0,ACore._)({ class: 'as-omt-option-row', child: [ radio, node.elt ] }); }; OMTArrayMergeDialog.prototype.createView = function () { var self = this; /*** * @type MessageDialog */ this.$view = (0,ACore._)({ tag: MessageDialog/* default.tag */.Z.tag, class: 'as-omt-dialog', props: { dialogTitle: {mlKey:'txt_option'}, dialogActions: [ { text: 'OK', name: 'ok' }, { text: 'Cancel', name: 'cancel' } ] }, on: { action: function (event) { self.stop() var action = event.action; if (action.name === 'cancel') return; if (action.name === 'ok') { self.assignResult(); } } } }); var dict = {}; var rows = this.options.map((opt, i) => this._makeOptionRow(opt, i, dict)).filter(x => !!x); this.$view.addChild(rows); this.$modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style:{ zIndex: 1000000, }, child: this.$view }); }; /* harmony default export */ const dialog_OMTArrayMergeDialog = (OMTArrayMergeDialog); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTArray.js /*** * @extends OMTBaseType * @constructor */ function OMTArray() { type_OMTBaseType.apply(this, arguments); this.value = null; } OOP/* default.mixClass */.ZP.mixClass(OMTArray, type_OMTBaseType); type_OMTBaseType.classes.array = OMTArray; OMTArray.prototype.commands = OMTArray.prototype.commands.concat([ { name: 'merge', icon: 'span.mdi.mdi-set-merge', title: 'Merge' } ]); OMTArray.prototype.execCmd = function (commandName) { type_OMTBaseType.prototype.execCmd.call(this, commandName); if (commandName === 'merge') { new dialog_OMTArrayMergeDialog(this); } }; OMTArray.prototype.assign = function (o) { this.$body.clearChild(); this.children = (o || []).map((it, i) => { var desc = Object.assign({ name: i, displayName: i + 1 + '' }, this.descriptor.of); if (!desc.displayName) desc.displayName = i + 1 + ''; var res = type_OMTBaseType.make(this.tool, this.parent, desc); res.assign(it); return res; }); this.$body.addChild(this.children.map(c => c.elt)); }; OMTArray.prototype.export = function () { return this.children.map(c => c.export()); }; OMTArray.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: {text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': '} }, { style: {paddingLeft: '25px'}, child: this.children.map((child => child.getRaw())) } ] }; }; /* harmony default export */ const type_OMTArray = (OMTArray); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/dialog/OMTEnumSetMergeDialog.js /*** * @extends Fragment * @param {OMTEnumSet} node * @constructor */ function OMTEnumSetMergeDialog(node) { Fragment/* default.call */.Z.call(this); this.node = node; this.calc(); this.getView(); this.start(); } OOP/* default.mixClass */.ZP.mixClass(OMTEnumSetMergeDialog, Fragment/* default */.Z); OMTEnumSetMergeDialog.prototype.calc = function () { this.currentValues = this.node.export(); this.descriptor = this.node.descriptor; this.selectOptions = this.node.getSelectOptions(); this.selected = {}; }; OMTEnumSetMergeDialog.prototype.onStart = function () { this.$modal.addTo(document.body); }; OMTEnumSetMergeDialog.prototype.onStop = function () { this.$modal.remove(); }; OMTEnumSetMergeDialog.prototype.assignResult = function () { var selectedValues = this._getCurrent(); if (selectedValues.length > 0) { this.node.assign((0,DataStructure_Array.arrayUnique)(this.currentValues.concat(selectedValues))); this.node.notifyChange(); } }; OMTEnumSetMergeDialog.prototype._getCurrent = function () { var selectedValues = this.selectOptions.reduce((ac, cr, i) => { if (this.selected[i]) ac = ac.concat(cr); return ac; }, []); selectedValues = (0,DataStructure_Array.arrayUnique)(selectedValues); return selectedValues; } OMTEnumSetMergeDialog.prototype._makeOptionRow = function (opt, i) { var self = this; var checked = (0,DataStructure_Array.arrayUnique)(this.currentValues.concat(opt)).length === (0,DataStructure_Array.arrayUnique)(this.currentValues).length; this.selected[i] = checked; var checkbox = (0,ACore._)({ tag: CheckBoxInput/* default.tag */.Z.tag, style: { marginRight: '10px', }, props: { checked: checked }, on: { change: function () { self.selected[i] = checkbox.checked; var currentValues = self._getCurrent(); self.previewNode.assign(currentValues); self.$view.$actionBtns[1].disabled = currentValues.length === 0; } } }); var mSelect = (0,ACore._)({ tag: js_MultiCheckTreeMenu.tag, class: 'as-border-none', props: { pendingValues: opt, readOnly: true } }); return (0,ACore._)({ class: 'as-omt-option-row', child: [ checkbox, mSelect ] }); }; OMTEnumSetMergeDialog.prototype.createView = function () { var self = this; this.$optionRows = this.selectOptions.map((opt, i) => this._makeOptionRow(opt, i)); this.previewNode = new this.node.constructor(this.node.tool, this.node.parent, this.node.descriptor); this.previewNode.assign(this.currentValues); this.$view = (0,ACore._)({ tag: MessageDialog/* default.tag */.Z.tag, class: ['as-omt-dialog'], props: { dialogTitle: 'Merge', dialogActions: [ { text: 'OK', name: 'ok' }, { text: 'Cancel', name: 'cancel' } ], }, on: { action: function (event) { self.stop(); if (event.action.name === 'ok') { self.assignResult(); } } }, child: [ this.previewNode, { child: [ { class: 'as-omt-field-name', child: { text: 'Merge From' } } ].concat(this.$optionRows) } ] }); Promise.resolve(this.descriptor.items).then(items => { (0,ACore.$$)(js_MultiCheckTreeMenu.tag, this.$view).forEach(elt => { elt.items = items; elt.values = elt.pendingValues; }); }); this.$modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style:{ zIndex: 1000000, }, child: this.$view }); }; /* harmony default export */ const dialog_OMTEnumSetMergeDialog = (OMTEnumSetMergeDialog); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTEnumSet.js /*** * @extends OMTBaseType * @constructor */ function OMTEnumSet() { type_OMTBaseType.apply(this, arguments); this.value = null; this._flatTreeItems(); } OOP/* default.mixClass */.ZP.mixClass(OMTEnumSet, type_OMTBaseType); type_OMTBaseType.classes["{enum}"] = OMTEnumSet; OMTEnumSet.prototype.commands = type_OMTArray.prototype.commands.slice(); OMTEnumSet.prototype._flatTreeItems = function () { if (!this.descriptor.flat) { this.descriptor.flat = true; this.descriptor.items = this.descriptor.items.reduce(function visit(ac, cr) { var item = Object.assign({}, cr); ac.push(item); if (item.items && item.items.length > 0) { item.items.reduce(visit, ac); } delete item.items; return ac; }, []); } }; OMTEnumSet.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_MultiCheckMenu.tag, class: 'as-border-none', style: { height: '18px' }, props: { readOnly: true, strictValue: false } }); this.$body.addChild(this.$value); this.$value.items = this.descriptor.items; this.$value.values = this.value; } OMTEnumSet.prototype.assign = function (o) { this.value = o; this.$value.values = o; }; OMTEnumSet.prototype.execCmd = function (commandName) { type_OMTBaseType.prototype.execCmd.call(this, commandName); if (commandName === 'merge') { this.userMerge(); } }; OMTEnumSet.prototype.userMerge = function () { //as-omt-option-row new dialog_OMTEnumSetMergeDialog(this); }; OMTEnumSet.prototype.getRaw = function () { var textItems = this.export().map(value => { var text = ''; var holders = this.$value.findItemsByValue(value); if (holders && holders.length > 0) { text = holders[0].item.text; if (holders[0].item.desc) text += ' - ' + holders[0].item.desc; } return text; }) return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { style: { paddingLeft: '25px' }, child: textItems.map(text => ({ tag: 'li', child: { text: text } })) } ] }; }; /* harmony default export */ const type_OMTEnumSet = ((/* unused pure expression or super */ null && (OMTEnumSet))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTFileArray.js /*** * @extends OMTBaseType * @constructor */ function OMTFileArray() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTFileArray, type_OMTBaseType); type_OMTBaseType.classes["file[]"] = OMTFileArray; OMTFileArray.prototype.type = 'file[]'; OMTFileArray.prototype.commands = type_OMTArray.prototype.commands.slice(); OMTFileArray.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_FileListInput.tag, class: ['as-omt-field-value', 'as-border-none'], props: { readOnly: true } }); this.$body.addChild(this.$value); }; OMTFileArray.prototype.assign = function (o) { this.value = o; if (o instanceof Array) { this.$value.files = o; this.$value.removeStyle('display'); } else { this.$value.addStyle('display', 'none'); } }; OMTFileArray.prototype.getHash = function () { return (0,utils.calcDTQueryHash)(this.value); }; OMTFileArray.prototype.getRaw = function () { var infoArr = (this.value || []).map(it => (0,utils.fileInfoOf)(it)); return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { style: { paddingLeft: '25px' }, child: infoArr.map(info => ({ tag: 'a', props: info.url ? { href: info.url, target: '_blank' } : {}, child: { text: info.name } })) } ] }; }; /* harmony default export */ const type_OMTFileArray = ((/* unused pure expression or super */ null && (OMTFileArray))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTColor.js /*** * @extends OMTBaseType * @constructor */ function OMTColor() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTColor, type_OMTBaseType); type_OMTBaseType.classes.color = OMTColor; OMTColor.prototype.type = 'color'; OMTColor.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ class: "as-omt-field-color-value-bg", child: '.as-omt-field-color-value' }); this.$body.addChild(this.$value); }; OMTColor.prototype.assign = function (o) { this.value = o; var color = 'transparent'; try { if (o instanceof Color_Color/* default */.Z) { color = o.toString("hex8"); } else if (typeof o === "string") { color = Color_Color/* default.parse */.Z.parse(o).toString("hex8"); } } catch (err) { } this.color = color; this.$value.addStyle('--omt-color-value', color); }; OMTColor.prototype.getHash = function () { return (0,stringUtils/* stringHashCode */.$)(this.color+''); }; OMTColor.prototype.getRaw = function () { var color = Color_Color/* default.parse */.Z.parse(this.color); return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { tag: 'span', style: {color: color.toString('hex6')}, child: { text: this.color } } ] } }; /* harmony default export */ const type_OMTColor = ((/* unused pure expression or super */ null && (OMTColor))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTBool.js /*** * @extends OMTBaseType * @constructor */ function OMTBool() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTBool, type_OMTBaseType); type_OMTBaseType.classes.bool = OMTBool; OMTBool.prototype.type = 'bool'; OMTBool.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: CheckBoxInput/* default */.Z, props: { readOnly: true } }); this.$body.addChild(this.$value); }; OMTBool.prototype.assign = function (o) { this.value = o; this.$value.checked = !!o; }; /* harmony default export */ const type_OMTBool = ((/* unused pure expression or super */ null && (OMTBool))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTHtml.js /*** * @extends OMTBaseType * @constructor */ function OMTHtml() { type_OMTBaseType.apply(this, arguments); this.value = null; } OOP/* default.mixClass */.ZP.mixClass(OMTHtml, type_OMTBaseType); type_OMTBaseType.classes.html = OMTHtml; OMTHtml.prototype.type = 'html'; OMTHtml.prototype.assign = function (o) { this.value = o; this.$body.clearChild(); this.$value = (0,ACore._)({ tag: 'div', props:{ innerHTML: o } }); this.$body.addChild(this.$value); }; OMTHtml.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: { text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': ' } }, { tag: 'span', child: { text: this.export() } } ] }; }; /* harmony default export */ const type_OMTHtml = ((/* unused pure expression or super */ null && (OMTHtml))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMDateTime.js /*** * @extends OMTBaseType * @constructor */ function OMTDateTime() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTDateTime, type_OMTBaseType); type_OMTBaseType.classes.datetime = OMTDateTime; OMTDateTime.prototype.type = 'datetime'; OMTDateTime.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_DateTimeInput.tag, class: 'as-border-none', props: { readOnly: true } }); if (this.descriptor.format) this.$value.format = this.descriptor.format; this.$body.addChild(this.$value); }; OMTDateTime.prototype.assign = function (o) { this.value = o; this.$value.value = o; }; OMTDateTime.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: {text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': '} }, { tag: 'span', child: { text: this.$value.text } } ] } }; /* harmony default export */ const OMDateTime = ((/* unused pure expression or super */ null && (OMTDateTime))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMDate.js /*** * @extends OMTBaseType * @constructor */ function OMTDate() { type_OMTBaseType.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(OMTDate, type_OMTBaseType); type_OMTBaseType.classes.date = OMTDate; OMTDate.prototype.type = 'date'; OMTDate.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_DateInput2.tag, class: 'as-border-none', props: { readOnly: true } }); if (this.descriptor.format) this.$value.format = this.descriptor.format; this.$body.addChild(this.$value); }; OMTDate.prototype.assign = function (o) { this.value = o; this.$value.value = o; }; OMTDate.prototype.getRaw = function () { return { child: [ { tag: 'span', class: 'as-omt-field-name', child: {text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': '} }, { tag: 'span', child: { text: this.$value.text } } ] } }; /* harmony default export */ const OMDate = ((/* unused pure expression or super */ null && (OMTDate))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/type/OMTEnumOfPair.js /*** * @extends OMTBaseType * @constructor */ function OMTEnumOfPair() { type_OMTBaseType.apply(this, arguments); this.value = null; } OOP/* default.mixClass */.ZP.mixClass(OMTEnumOfPair, type_OMTBaseType); type_OMTBaseType.classes["enum<pair>"] = OMTEnumOfPair; OMTEnumOfPair.prototype.type = 'enum<pair>'; OMTEnumOfPair.prototype.render = function () { type_OMTBaseType.prototype.render.call(this); this.$value = (0,ACore._)({ tag: js_DualSelectMenu.tag, class: 'as-border-none', style: {height: '18px'}, props: { readOnly: true, } }); this.$body.addChild(this.$value); if (this.descriptor.items && this.descriptor.items.then) { this.descriptor.items.then(items => { this.$value.items = items; }); } else { this.$value.items = this.descriptor.items; } } OMTEnumOfPair.prototype.assign = function (o) { this.value = o; this.$value.value = o; }; OMTEnumOfPair.prototype.getRaw = function () { var text = this.$value.$item && this.$value.$item.innerText; return { child: [ { tag: 'span', class: 'as-omt-field-name', child: {text: (this.descriptor.displayName || this.descriptor.name || "ROOT") + ': '} }, { tag: 'span', child: {text: text} } ] }; }; /* harmony default export */ const type_OMTEnumOfPair = ((/* unused pure expression or super */ null && (OMTEnumOfPair))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/objectmergetool/ObjectMergeTool.js /*** * @extends AElement * @constructor */ function ObjectMergeTool() { this._descriptors = null; this._objects = null; this.root = null; this.$body = (0,ACore.$)('.as-omt-body', this) .on('mouseover', this.eventHandler.mouseOverNode); this.hoveringNode = null; /** * @type {Object[]} * @memberOf ObjectMergeTool# * @name objects */ /** * @type {Object} * @memberOf ObjectMergeTool# * @name descriptors */ } ObjectMergeTool.tag = 'ObjectMergeTool'.toLowerCase(); ObjectMergeTool.render = function () { return (0,ACore._)({ class: 'as-omt', extendEvent: ['change'], child: [ { class: 'as-omt-body' } ] }); }; ObjectMergeTool.prototype._tryFlushData = function () { if (this.root && this.objects && this.objects.length > 0) { this.root.assign(this.objects[0]); } }; ObjectMergeTool.prototype._findNode = function (targetElt) { while (targetElt && targetElt !== this) { if (targetElt.omtNode) return targetElt.omtNode; targetElt = targetElt.parentElement; } return null; }; ObjectMergeTool.prototype.notifyChange = function () { this.emit('change', { type: 'change', target: this }, this); }; ObjectMergeTool.property = {}; ObjectMergeTool.property.descriptor = { set: function (value) { this._descriptor = value || {}; this.$body.clearChild(); this.root = type_OMTBaseType.make(this, null, this._descriptor); this.$body.addChild(this.root.elt); this._tryFlushData(); }, get: function () { return this._descriptor; } }; ObjectMergeTool.property.objects = { set: function (value) { this._objects = value || []; this._tryFlushData(); }, get: function () { return this._objects; } }; ObjectMergeTool.property.data = { get: function () { if (this.root) { return this.root.export(); } if (this._objects && this.objects.length > 0) return this._objects[0]; return null; } }; /*** * @type {{}} * @memberOf ObjectMergeTool# */ ObjectMergeTool.eventHandler = {}; /*** * @this ObjectMergeTool * @param {MouseEvent} event */ ObjectMergeTool.eventHandler.mouseOverNode = function (event) { var node = this._findNode(event.target); if (this.hoveringNode === node) return; if (this.hoveringNode) { this.hoveringNode.elt.removeClass('as-hover'); } this.hoveringNode = node; if (this.hoveringNode) { this.hoveringNode.elt.addClass('as-hover'); } }; ACore/* default.install */.Z.install(ObjectMergeTool); /* harmony default export */ const objectmergetool_ObjectMergeTool = (ObjectMergeTool); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tokenizeinput.css var tokenizeinput = __webpack_require__(1323); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/tokenizeiput/TIHistory.js /*** * @param {TokenizeInput} elt * @constructor */ function TIHistory(elt){ this.elt = elt; this.stack = []; this.topIdx = -1; } TIHistory.prototype.commit = function (text, offset){ while (this.topIdx < this.stack.length - 1) { this.stack.pop(); } var lastText = this.stack.length > 0 ? this.stack[this.stack.length - 1].text : null; if (text === lastText) { if (this.stack[this.stack.length - 1].offset !== offset) this.stack[this.stack.length - 1].offset = offset; } else { this.topIdx = this.stack.length; var record = { text: text, offset: offset }; this.stack.push(record); this.elt.emit('change', { target: this, value: record.text, action: 'commit', record: record, type: 'change' }, this); } }; TIHistory.prototype.undo = function (){ if (this.topIdx <= 0) return; this.topIdx--; var record = this.stack[this.topIdx]; this.elt.applyData(record.text, record.offset); this.elt.emit('change', { target: this, value: record.text, action: 'undo', record: record, type: 'change' }, this); }; TIHistory.prototype.redo = function (){ if (this.topIdx + 1 >= this.stack.length) return; this.topIdx++; var record = this.stack[this.topIdx]; this.elt.applyData(record.text, record.offset); this.elt.emit('change', { target: this, value: record.text, action: 'redo', record: record, type: 'change' }, this); }; /* harmony default export */ const tokenizeiput_TIHistory = (TIHistory); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tokenizeiput/TITextController.js var TITextController = __webpack_require__(1875); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tokenizeiput/tiutils.js var tiutils = __webpack_require__(3421); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/tokenizeiput/TISelectionController.js /**** * * @param {TokenizeInput} elt * @constructor */ function TISelectionController(elt) { this.elt = elt; this.prevRange = null; } TISelectionController.prototype.onSelect = function () { var key = (this.elt.prevKey && (new Date().getTime() - this.elt.prevKey.time < 100)) ? this.elt.prevKey.value : ''; var sel = document.getSelection(); var range = sel.getRangeAt(0); var direction = (0,utils.getSelectionRangeDirection)(range); var newRange; var handleEmojiToken = () => { var startCtn = range.startContainer; var startOffset = range.startOffset; var startToken; var endCtn = range.endContainer; var endOffset = range.endOffset; var endToken; var changed = 0; var textData; var nextTextNode; var prevTextNode; var displayText; var newText; if ((0,tiutils/* isTokenText */.tk)(startCtn)) { startToken = startCtn.parentElement; displayText = startToken.getAttribute('data-display'); textData = startCtn.data; if (range.collapsed) { if (textData.length < displayText.length) { prevTextNode = this.getPrevTextNode(startCtn); if (!(0,tiutils/* isText */.Gs)(prevTextNode)) { prevTextNode = document.createTextNode(''); startToken.parentElement.insertBefore(prevTextNode, startToken); } startToken.remove(); startCtn = prevTextNode; startOffset = prevTextNode.data.length; changed = 1; } else if (textData === displayText && startOffset < displayText.length && startOffset > 0) { if (key === 'arrowright' || !key) { startOffset = displayText.length; changed = 1; } else if (key === 'arrowleft') { startOffset = 0; changed = 1; } else if (key === 'mouseup') { startOffset = 0; endOffset = displayText.length; changed = 2; } } else if (textData.length > displayText.length) { if (startOffset === textData.length) { nextTextNode = startToken.nextSibling; if (!(0,tiutils/* isText */.Gs)(nextTextNode)) { newText = document.createTextNode(''); nextTextNode.parentElement.insertBefore(newText, nextTextNode); nextTextNode = newText; } nextTextNode.data = textData.substring(displayText.length) + nextTextNode.data; startCtn.data = displayText; startCtn = nextTextNode; startOffset = textData.length - displayText.length; changed = 1; } else { prevTextNode = startToken.previousSibling; if (!(0,tiutils/* isText */.Gs)(prevTextNode)) { newText = document.createTextNode(''); startToken.parentElement.insertBefore(newText, startToken); prevTextNode = newText; } prevTextNode.data += textData.substring(0, textData.length - displayText.length); startCtn.data = displayText; startCtn = prevTextNode; startOffset = startCtn.data.length; } } } else { if (startOffset > 0 && startOffset < displayText.length) { startOffset = 0; changed = 2; } } } if ((0,tiutils/* isTokenText */.tk)(endCtn)) { endToken = endCtn.parentElement; displayText = endToken.getAttribute('data-display'); if (!range.collapsed) { if (endOffset < displayText.length) { endOffset = displayText.length changed = 2; } } } if (changed > 0) { newRange = document.createRange(); newRange.setStart(startCtn, startOffset); if (changed > 1) { newRange.setEnd(endCtn, endOffset); } else { //for saving endOffset = startOffset; endCtn = startCtn; } (0,utils.setSelectionRange)(newRange, direction === 'backward'); } var nextToken, nextText; if ((0,tiutils/* isToken */.hD)(endCtn.nextSibling)) { nextToken = endCtn.nextSibling; displayText = nextToken.getAttribute('data-display'); nextText = (0,tiutils/* getFirstTextNode */.ot)(nextToken); if (!nextText || nextText.data !== displayText) nextToken.remove(); } this.prevRange = { startOffset: startOffset, startContainer: startCtn, endOffset: endOffset, endContainer: endCtn }; } handleEmojiToken(); }; TISelectionController.prototype.getNextTextNode = function (current) { return (0,tiutils/* findNextTextNode */.M4)(this.elt, current); }; TISelectionController.prototype.getPrevTextNode = function (current) { return (0,tiutils/* findPrevTextNode */.LD)(this.elt, current); }; TISelectionController.prototype.setRangeByOffset = function (offset) { var start, end, direction; if (typeof offset === "number") { start = offset; end = offset; direction = 'forward'; } else { start = offset.start; end = offset.end; direction = offset.direction || 'forward'; } var startCtn = null; var startOffset = 0; var endCtn = null; var endOffset = 0; var st = ''; var nodes = Array.prototype.slice.call(this.elt.childNodes); if ((0,tiutils/* isNewLine */.K0)(nodes[nodes.length - 1])) nodes.pop(); var node; for (var i = 0; i < nodes.length; ++i) { node = nodes[i]; if ((0,tiutils/* isText */.Gs)(node)) { st += node.data; if (!startCtn && st.length >= start) { startCtn = node; startOffset = node.data.length - (st.length - start); } if (!endCtn && st.length >= end) { endCtn = node; endOffset = node.data.length - (st.length - end); } } else if ((0,tiutils/* isToken */.hD)(node)) { st += node.getAttribute('data-text'); if (!startCtn && st.length >= start) { startCtn = (0,tiutils/* getFirstTextNode */.ot)(node); startOffset = startCtn.data.length; } if (!endCtn && st.length >= end) { endCtn = (0,tiutils/* getFirstTextNode */.ot)(node); endOffset = endCtn.data.length; } } else if ((0,tiutils/* isNewLine */.K0)(node)) { st += '\n'; if (!startCtn && st >= start) { startCtn = this.elt; startOffset = i + 1; } if (!endCtn && st.length >= end) { endCtn = this.elt; endOffset = i + 1; } } } if (!startCtn) { if (nodes.length > 0) { node = nodes[nodes.length - 1] if ((0,tiutils/* isNewLine */.K0)(node)) { startCtn = this.elt; startOffset = nodes.length; } else if ((0,tiutils/* isText */.Gs)(node)) { startCtn = node; startOffset = node.length; } else { startCtn = (0,tiutils/* getLastTextNode */.No)(node); startOffset = node.length; } } else { startCtn = this.elt; startOffset = 0; } } if (!endCtn) { endCtn = startCtn; endOffset = startOffset; } this.prevRange = { startContainer: startCtn, startOffset: startOffset, endContainer: endCtn, endOffset: endOffset } var range = document.createRange(); range.setStart(startCtn, startOffset); range.setEnd(endCtn, endOffset); (0,utils.setSelectionRange)(range, direction === 'backward'); }; TISelectionController.prototype.getOffset = function (range) { range = range || this.elt.selectionCtrl.prevRange; if (!range) return null; var nodes = Array.prototype.slice.call(this.elt.childNodes); if ((0,tiutils/* isNewLine */.K0)(nodes[nodes.length - 1])) nodes.pop(); var startCtn = range.startContainer; var startOffset = range.startOffset; var endCtn = range.endContainer; var endOffset = range.endOffset; if (startCtn === this.elt) { startCtn = this.elt.childNodes[startOffset - 1]; startOffset = 1; } else if ((0,tiutils/* isTokenText */.tk)(startCtn)) { startCtn = startCtn.parentElement; if (startOffset > 0) startOffset = startCtn.getAttribute('data-text').length; } if (endCtn === this.elt) { endCtn = this.elt.childNodes[endOffset]; endOffset = 1; } else if ((0,tiutils/* isTokenText */.tk)(endCtn)) { endCtn = endCtn.parentElement; if (endOffset > 0) endOffset = endCtn.getAttribute('data-text').length; } var start = undefined; var end = undefined; var direction = (0,utils.getSelectionRangeDirection)(range); var st = ''; var node; for (var i = 0; i < nodes.length; ++i) { node = nodes[i]; if ((0,tiutils/* isText */.Gs)(node)) { if (start === undefined && node === startCtn) { start = st.length + startOffset; } if (end === undefined && node === endCtn) { end = st.length + endOffset; } st += node.data; } else if ((0,tiutils/* isToken */.hD)(node)) { if (start === undefined && node === startCtn) { start = st.length + startOffset; } if (end === undefined && node === endCtn) { end = st.length + endOffset; } st += node.getAttribute('data-text'); } else if ((0,tiutils/* isNewLine */.K0)(node)) { st += '\n'; if (start === undefined && node === startCtn) { start = st.length; } if (end === undefined && node === endCtn) { end = st.length; } } } if (start === undefined) start = 0; if (end === undefined) { end = start; } return { start: start, end: end, direction: direction } } /* harmony default export */ const tokenizeiput_TISelectionController = (TISelectionController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/tokenizeiput/TokenizeHyperInput.js var TokenizeHyperInput_textDelay = BrowserDetector/* default.isSafari */.Z.isSafari ? 100 : 1; /*** * @extends AElement * @constructor */ function TokenizeHyperInput() { this._tagMap = {}; this.$br = (0,ACore.$)('br', this); this.historyCtrl = new tokenizeiput_TIHistory(this); this.textCtrl = new TITextController/* default */.Z(this); this.selectionCtrl = new tokenizeiput_TISelectionController(this); this.prevKey = null; this.defineEvent(['pasteimg', 'pastefile', 'pastetext', 'change']); this.on('paste', this.eventHandler.paste); this.on('keydown', this.eventHandler.keydown); this.on('mouseup', this.eventHandler.mouseup); this.value = ''; this.historyCtrl.commit('', 0); /*** * @type {{}} * @name tagMap *@memberOf TokenizeHyperInput# * */ } TokenizeHyperInput.tag = 'TokenizeHyperInput'.toLowerCase(); TokenizeHyperInput.render = function () { return (0,ACore._)({ tag: 'pre', class: 'as-tokenize-hyper-input', attr: { contenteditable: 'true', spellcheck: "false" }, child: 'br' }); }; TokenizeHyperInput.prototype.applyData = function (text, offset) { this.textCtrl.applyData(text, offset); }; TokenizeHyperInput.prototype.select = function (offset) { if (document.activeElement !== this) this.focus(); this.applyData(this.value, offset); }; TokenizeHyperInput.prototype.scrollIntoRange = function (range) { var elementBound = range.getBoundingClientRect(); var viewportBound = this.getBoundingClientRect(); var dBottom = 0; if (range.startContainer && range.startContainer.data && range.startContainer.data.charAt(range.startContainer.data.length - 1) == '\n') dBottom += this.getFontSize() * 1.5; var currentScrollTop = this.scrollTop; var newScrollTop = currentScrollTop; if (elementBound.bottom + dBottom > viewportBound.bottom) { newScrollTop = currentScrollTop + (elementBound.bottom + dBottom - viewportBound.bottom); } if (elementBound.top < viewportBound.top) { newScrollTop = currentScrollTop - (viewportBound.top - elementBound.top); } if (newScrollTop != currentScrollTop) { this.scrollTop = newScrollTop; } var currentScrollLeft = this.scrollLeft; var newScrollLeft = currentScrollLeft; if (elementBound.right > viewportBound.right) { newScrollLeft = currentScrollLeft + (elementBound.right - viewportBound.right); } if (elementBound.left < viewportBound.left) { newScrollLeft = currentScrollLeft - (viewportBound.left - elementBound.left); } if (newScrollLeft != currentScrollLeft) { this.scrollLeft = newScrollLeft; } }; TokenizeHyperInput.prototype.undo = function () { this.historyCtrl.undo(); }; TokenizeHyperInput.prototype.redo = function () { this.historyCtrl.redo(); }; TokenizeHyperInput.prototype.commitChange = function (text, offset) { this.historyCtrl.commit(text, offset); this.emit('change', {}, this); }; TokenizeHyperInput.prototype.waitToCommit = function (text, offset) { var thisInput = this; if (this._commitTimeout > 0) clearTimeout(this._commitTimeout); this._commitTimeout = setTimeout(function () { thisInput.commitChange(text, offset); }, TokenizeHyperInput_textDelay); }; TokenizeHyperInput.prototype.getPosition = function (node, offset) { if (!node) return NaN; if (node === this) return offset; var parent = node.parentElement; if (!parent) return NaN; var text = ''; var child; var lastBr = false; for (var i = 0; i < parent.childNodes.length; ++i) { child = parent.childNodes[i]; if (child == node) break; text += this.stringOf(child); } return this.getPosition(parent, text.length + offset); }; TokenizeHyperInput.prototype.getSelectPosition = function () { return this.selectionCtrl.getOffset(); }; /** * @type {TokenizeHyperInput} */ TokenizeHyperInput.eventHandler = {}; TokenizeHyperInput.eventHandler.paste = function (event) { var clipboardData = (event.clipboardData || window.clipboardData); if (!clipboardData) { alert('Input not support browser without clipboard API!'); return; } if (clipboardData.items) { var items = Array.prototype.slice.call(clipboardData.items); var imgItems = items.filter(item => item.type.indexOf('image') >= 0); var fileItems = items.filter(item => item.type !== 'text/plain' && item.type.indexOf('image') < 0); var plainTextItems = items.filter((item) => item.type.indexOf('text/plain') >= 0); if (imgItems.length > 0) { var imgFiles = imgItems.map(function (it) { return it.getAsFile(); }); this.emit('pasteimg', { target: this, imageFile: imgFiles[0], imageFiles: imgFiles, originalEvent: event }, this); } if (fileItems.length > 0) { var files = fileItems.map(item => item.getAsFile()); this.emit('pastefile', { target: this, file: files[0], files: files, originalEvent: event }, this); } if (plainTextItems.length > 0) { var plainTextItem = plainTextItems[0];//only one item plainTextItem.getAsString(text => { this.textCtrl.insertText(text); }); } event.preventDefault(); } else { var text = event.clipboardData.getData('text/plain'); if (text) { event.preventDefault(); this.textCtrl.insertText(text); } } this.waitToCommit(); }; TokenizeHyperInput.eventHandler.keydown = function (event) { this.prevKey = { time: new Date().getTime(), value: (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event) }; setTimeout(() => { this.selectionCtrl.onSelect(); this.waitToCommit(); }, TokenizeHyperInput_textDelay); }; /*** * @this TokenizeHyperInput * @param event */ TokenizeHyperInput.eventHandler.mouseup = function (event) { this.prevKey = { time: new Date().getTime(), value: 'mouseup' }; this.selectionCtrl.onSelect(); } TokenizeHyperInput.property = {}; TokenizeHyperInput.property.value = { set: function (value) { value = value || ''; this.textCtrl.setText(value); // this.applyData(value, value.length); this.commitChange(value, value.length); }, get: function () { return this.textCtrl.getText(); } }; TokenizeHyperInput.property.disabled = { set: function (value) { value = !!value; if (value === this.hasClass('as-disabled')) return; if (value) { this.addClass('as-disabled'); this.attr({ contenteditable: undefined, oncut: 'return false', onpaste: 'return false', onkeydown: 'if(event.metaKey) return true; return false;' }); } else { this.removeClass('as-disabled'); this.attr({ contenteditable: true, oncut: undefined, onpaste: undefined, onkeydown: undefined }); } }, get: function () { return this.hasClass('as-disabled'); } }; TokenizeHyperInput.property.tagList = { get: function () { return (0,utils.getTagListInTextMessage)(this.value); } }; TokenizeHyperInput.property.tagMap = { set: function (o) { o = o || {}; this._tagMap = o; Array.prototype.forEach.call(this.childNodes, child => { var id, text; if (child.classList && child.classList.contains('as-tag-token')) { id = (child.getAttribute('data-text') || ''); id = id.substring(5, id.length - 1); text = this._tagMap[id]; if (text) { child.getAttribute('data-display', '@' + text); child.firstChild.data = '@' + text; } } }) }, get: function () { return this._tagMap; } } ACore/* default.install */.Z.install(TokenizeHyperInput); /* harmony default export */ const tokenizeiput_TokenizeHyperInput = (TokenizeHyperInput); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/SelectListBoxPropHandlers.js var SelectListBoxPropHandlers = {}; SelectListBoxPropHandlers.enableSearch = { /*** * @this SelectListBox * @param {boolean} value */ set: function (value) { if (value) this.addClass('as-enable-search'); else this.removeClass('as-enable-search'); }, /*** * @this SelectListBox */ get: function () { return this.hasClass('as-enable-search'); } }; SelectListBoxPropHandlers.items = { /*** * @this SelectListBox * @param {{}} items */ set: function (items) { this.itemListCtrl.setItems(items); }, get: function () { return this.itemListCtrl.getItems(); } }; /* harmony default export */ const selectlistbox_SelectListBoxPropHandlers = (SelectListBoxPropHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/SLBItemHolder.js function SLBItemHolder(parent, data) { this.data = data; this.parent = parent; this._elt = null; } Object.defineProperty(SLBItemHolder.prototype, 'elt', { get: function () { if (!this._elt) { this._elt = (0,ACore._)({ tag: SelectListItem/* default.tag */.ZP.tag, props: { data: this.data } }); } return this._elt; } }); /* harmony default export */ const selectlistbox_SLBItemHolder = (SLBItemHolder); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/SLBModes.js function SLBModeNormal(elt, items) { this.elt = elt; this.$scroller = this.elt.$scroller; this.$content = this.elt.$content; this.items = items; this.children = items.map(item => new selectlistbox_SLBItemHolder(this, item)); this.children.forEach((child, i) => { child.idx = i; // child.elt; }); this.$pages = []; } SLBModeNormal.prototype._getPageElt = function (idx) { if (this.$pages[idx]) return this.$pages[idx]; while (this.$pages.length <= idx) this.$pages.push(undefined); var children = this.children.slice(idx * 50, idx * 50 + 50); var pageElt = (0,ACore._)({ class: 'as-select-list-box-page', style: { top: 20 * idx * 50 + 'px' }, child: children.map(child => child.elt) }); this.$pages[idx] = pageElt; return pageElt; }; SLBModeNormal.prototype._getPageCount = function () { return Math.ceil(this.items.length / 50); } SLBModeNormal.prototype.onStart = function () { this.elt.$content.addStyle('height', this.items.length * 20 + 'px'); // var n = this._getPageCount(); // for (var i =0; i < n; ++i){ // this.$content.addChild(this._getPageElt(i)); // } this.updateListView(); }; SLBModeNormal.prototype.onStop = function () { }; SLBModeNormal.prototype.updateListView = function () { var maxHeight = Math.max(4096, (0,Dom/* getScreenSize */.tE)().height); var startIdx = Math.floor(this.$scroller.scrollTop / 1000) - 1; var endIdx = startIdx + Math.ceil(maxHeight / 1000) + 1; startIdx = Math.max(0, startIdx); endIdx = Math.min(this._getPageCount(), endIdx); var needViewPages = Array(endIdx - startIdx).fill(null).map((u, i) => this._getPageElt(startIdx + i)); Array.prototype.forEach.call(this.$content.childNodes, elt => { if (needViewPages.indexOf(elt) < 0) { elt.remove(); } }); needViewPages.forEach(elt=>{ if (!elt.parentElement){ this.$content.addChild(elt); } }); } function SLBModeSearch(elt, items) { this.items = items; } OOP/* default.mixClass */.ZP.mixClass(SLBModeSearch, SLBModeNormal); // SLBModeSearch.prototype.onStart ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/SLBItemListController.js /*** * @extends ListDictionary * @param {SelectListBox} elt * @constructor */ function SLBItemListController(elt) { this.elt = elt; this.items = []; this.elt.$scroller.on('scroll', this.updateListView.bind(this)); } OOP/* default.mixClass */.ZP.mixClass(SLBItemListController, ListDictionary/* default */.Z) SLBItemListController.itemHeight = 20; SLBItemListController.preLoadN = 3; SLBItemListController.prototype.toLoadNextY = 200; SLBItemListController.prototype.getItems = function () { return (0,utils.copySelectionItemArray)(this.items); }; SLBItemListController.prototype.setItems = function (items) { this.items = (0,utils.copySelectionItemArray)(items ||[]); var mode = new SLBModeNormal(this.elt, this.items); this.elt.modes.normal = mode; this.elt.mode = mode; mode.onStart(); }; SLBItemListController.prototype.updateListView = function (){ this.elt.mode.updateListView(); } /* harmony default export */ const selectlistbox_SLBItemListController = (SLBItemListController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selectlistbox/SelectListBox.js /*** * @extends AElement * @constructor */ function SelectListBox_SelectListBox() { this.$box = this; this.$content = $('.as-select-list-box-content', this); this.$scroller = $('.as-select-list-box-scroller', this); this.itemListCtrl = new selectlistbox_SLBItemListController(this); this.modes = { normal: new SLBModeNormal(this, []), search: null }; this.mode = this.modes.normal; } SelectListBox_SelectListBox.tag = 'selectlistbox_v2'.toLowerCase(); SelectListBox_SelectListBox.render = function () { return (0,ACore._)({ tag: 'follower', attr: { tabindex: 0 }, class: 'as-select-list-box', extendEvent: ['pressitem'], child: [ { class: 'as-select-list-box-search-ctn', child: 'searchtextinput' }, { class: ['as-bscroller', 'as-select-list-box-scroller'], child: [ { class: ['as-select-list-box-content'], child: Array(SelectListBox_SelectListBox.prototype.preLoadN).fill('.as-select-list-box-page') } ] }, 'attachhook.as-dom-signal' ], props: { anchor: [1, 6, 2, 5] } }); } SelectListBox_SelectListBox.property = selectlistbox_SelectListBoxPropHandlers; ACore/* default.install */.Z.install('selectlistbox_v2', SelectListBox_SelectListBox); /* harmony default export */ const selectlistbox_SelectListBox = (SelectListBox_SelectListBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/pathmenu.css var pathmenu = __webpack_require__(924); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PathMenu.js /*** * @extends AElement * @constructor */ function PathMenu() { this._path = []; this.$items = []; } PathMenu.tag = 'PathMenu'.toLowerCase(); PathMenu.render = function () { return (0,ACore._)({ attr: { tabindex: '1' }, extendEvent: ['press', 'change'], class: 'as-path-menu' }); }; PathMenu.prototype._makeItem = function (data, idx) { var self = this; var button = (0,ACore._)({ class: ['as-ribbon-split-button', 'as-path-menu-item'], child: { class: 'as-ribbon-split-button-content', child: [{ tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-primary', child: { tag: 'span', class: 'as-ribbon-split-button-text', child: { text: (data.name || data.text || '') + '' } } }, { tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-extend', child: ['span.mdi.mdi-chevron-right'] } ] } }); button.on('mouseenter', function () { if (document.activeElement && AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(document.activeElement, self) && self.hasClass('as-opening-item')) { if (button.quickMenu) button.quickMenu.open(); } }); var extendIconElt = (0,ACore.$)('.as-ribbon-split-button-extend .mdi', button); var primaryBtn = (0,ACore.$)('.as-ribbon-split-button-primary', button) .on('click', function () { self.emit('press', { target: self, pathItem: data, index: idx }, self); }); //as-ribbon-split-button-icon var icon = null; if (data.icon) { icon = (0,ACore._)(data.icon); } else if (data.iconSrc) { icon = (0,ACore._)({ tag: 'img', props: { src: data.iconSrc } }) } if (icon) { if (icon.parentElement) icon = (0,ACore.$)(icon.cloneNode(true)); icon.addClass('as-ribbon-split-button-icon'); primaryBtn.addChildBefore(icon, primaryBtn.firstChild); } var quickTrigger = (0,ACore.$)('.as-ribbon-split-button-extend', button); if (data.items && data.items.length > 0) { button.quickMenu = QuickMenu/* default.toggleWhenClick */.Z.toggleWhenClick(quickTrigger, { getMenuProps: function () { return { items: data.items.map(function (it, menuIndex) { if (typeof it === "string") return it; if (typeof it === "object") { if (it.icon || it.iconSrc || it.name || it.text) { return { text: it.name || it.text, menuIndex: menuIndex, icon: it.iconSrc ? { tag: 'img', props: { src: it.iconSrc } } : (it.icon || undefined), extendStyle: it.extendStyle || {}, extendClass: it.extendClass || [], } } } return it; }) } }, anchor: [1, 6, 0, 7], onOpen: function () { self.addClass('as-opening-item'); extendIconElt.addClass('mdi-rotate-90'); }, onClose: function () { self.removeClass('as-opening-item'); extendIconElt.removeClass('mdi-rotate-90'); }, onSelect: function (item) { var dataItem = data.items[item.menuIndex]; self.emit('change', { target: self, pathItem: data, item: dataItem, index: idx }, self); button.removeClass('as-open'); } }); } else { button.addClass('as-has-no-item'); } return button; }; PathMenu.property = {}; PathMenu.property.path = { set: function (path) { this._path = path || []; this.$items.forEach(elt => elt.remove()); this.$items = this._path.map((it, i) => this._makeItem(it, i)); this.addChild(this.$items); }, get: function () { return this._path; } }; ACore/* default.install */.Z.install(PathMenu); /* harmony default export */ const js_PathMenu = (PathMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreemenu/MCTMPropHandlers.js var MCTMPropHandlers = {}; MCTMPropHandlers.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; MCTMPropHandlers.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; MCTMPropHandlers.items = { set: function (items) { this.$box.items = items; this.tokenCtrl.updateFromViewValues(); }, get: function () { return this.$box.items; } }; MCTMPropHandlers.values = { set: function (values) { this.$box.values = values || []; this.tokenCtrl.updateFromViewValues(); }, get: function () { if (this.isFocus) { return this.savedValues; } else { return this.$box.values; } } }; MCTMPropHandlers.leafOnly = { set: function (value) { if (!!value === this.hasClass('as-leaf-only')) return; if (value) { this.addClass('as-leaf-only'); this.$box.leafOnly = true; } else { this.removeClass('as-leaf-only'); this.$box.leafOnly = false; } this.tokenCtrl.updateFromViewValues(); }, get: function () { return this.hasClass('as-leaf-only'); } }; MCTMPropHandlers.isFocus = { /*** * @this MultiCheckTreeMenu * @param value */ set: function (value) { if (value && (this.disabled || this.readOnly)) return; if (!!value === this.hasClass('as-focus')) return; if (value) { this.savedValues = this.$box.values; this.addClass('as-focus'); this.boxCtrl.onFocus(); } else { this.removeClass('as-focus'); this.boxCtrl.onBlur(); var newValues = this.values; if (!(0,DataStructure_Array.arrayCompare)(this.savedValues, newValues)) { this.notifyChange(); } else { this.tokenCtrl.updateFromViewValues(); } this.savedValues = this.values; } }, get: function () { return this.hasClass('as-focus'); } }; MCTMPropHandlers.enableSearch = { set: function (value){ this.$box.enableSearch = value; }, get: function (){ return this.$box.enableSearch ; } }; /* harmony default export */ const multichecktreemenu_MCTMPropHandlers = (MCTMPropHandlers); /**************************** ADAPT OLD VERSION **********************************************************************/ MCTMPropHandlers.$checkTreeBox = { get: function () { return this.$box; } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreeleafmenu/MCTLMPropHandler.js var MCTLMPropHandler = Object.assign({}, multichecktreemenu_MCTMPropHandlers); MCTLMPropHandler.leafOnly = { value: true, enumerable: true }; /* harmony default export */ const multichecktreeleafmenu_MCTLMPropHandler = (MCTLMPropHandler); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreemenu/MMCTMBoxController.js /*** * * @param elt * @constructor */ function MMCTMBoxController(elt) { this.elt = elt; this.$box = elt.$box; for (var key in this) { if (key.startsWith('ev_')) this[key] = this[key].bind(this); } this.elt.on('click', this.ev_click); this.$box.on('close', this.ev_close); this.$box.on('cancel', this.ev_cancel); this.$box.on('change', this.ev_boxValuesChange); } MMCTMBoxController.prototype.onFocus = function () { this.$box.addTo(document.body); this.elt.off('click', this.ev_click); }; MMCTMBoxController.prototype.onBlur = function () { this.$box.remove(); setTimeout(() => { this.elt.on('click', this.ev_click); }, 50) }; MMCTMBoxController.prototype.ev_click = function (event) { if (!this.elt.disabled && !this.elt.readOnly && (event.target === this.elt || event.target === this.elt.$itemCtn)) { this.elt.isFocus = true; } }; MMCTMBoxController.prototype.ev_close = function (event) { this.elt.isFocus = false; }; MMCTMBoxController.prototype.ev_cancel = function (event) { this.$box.values = this.elt.savedValues; this.elt.isFocus = false; }; MMCTMBoxController.prototype.ev_boxValuesChange = function () { this.elt.tokenCtrl.updateFromViewValues(); }; /* harmony default export */ const multichecktreemenu_MMCTMBoxController = (MMCTMBoxController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreemenu/MCTMTokenController.js /**** * * @param {MultiCheckTreeMenu} elt * @constructor */ function MCTMTokenController(elt) { this.elt = elt; this.$box = elt.$box; this.$itemCtn = elt.$itemCtn; } MCTMTokenController.prototype.updateFromViewValues = function () { var values = this.$box.viewValues; this.requireItems(values.length); var holder; for (var i = 0; i < values.length; ++i) { holder = this.$box.getHolderByValue(values[i]); this.$itemCtn.childNodes[i].data = holder.data; } }; MCTMTokenController.prototype.requireItems = function (count) { while (this.$itemCtn.childNodes.length < count) { this.$itemCtn.addChild(this.makeToken()); } while (this.$itemCtn.childNodes.length > count) { this.$itemCtn.lastChild.remove(); } }; MCTMTokenController.prototype.removeValue = function (targetValue) { this.$box.select(targetValue, false); this.updateFromViewValues(); if (!this.elt.isFocus) { this.elt.notifyChange(); } }; MCTMTokenController.prototype.makeToken = function () { var ctrl = this; return (0,ACore._)({ tag: js_SelectBoxItem, on: { close: function () { ctrl.removeValue(this.value); } } }); }; /* harmony default export */ const multichecktreemenu_MCTMTokenController = (MCTMTokenController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreemenu/MultiCheckTreeMenu.js /*** * @extends AElement * @constructor */ function MultiCheckTreeMenu_MultiCheckTreeMenu() { this.$box = (0,ACore._)({ tag: this.classes.Box }); this.$itemCtn = (0,ACore.$)('.as-multi-select-menu-item-ctn', this); this.boxCtrl = new multichecktreemenu_MMCTMBoxController(this); this.tokenCtrl = new multichecktreemenu_MCTMTokenController(this);//mobile only } MultiCheckTreeMenu_MultiCheckTreeMenu.tag = 'MultiCheckTreeMenu'.toLowerCase(); MultiCheckTreeMenu_MultiCheckTreeMenu.prototype.classes = { Box: checktreebox_MCheckTreeBox }; MultiCheckTreeMenu_MultiCheckTreeMenu.render = function () { return (0,ACore._)({ class: ['as-multi-select-menu', 'as-multi-check-tree-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { class: ['as-multi-select-menu-item-ctn', 'as-bscroller'] }, { tag: 'button', class: 'as-multi-select-menu-toggle-btn', child: 'dropdown-ico' }, 'attachhook' ] }); }; MultiCheckTreeMenu_MultiCheckTreeMenu.prototype.notifyChange = function () { this.emit('change', { type: 'change', target: this }, this); }; MultiCheckTreeMenu_MultiCheckTreeMenu.property = multichecktreemenu_MCTMPropHandlers; ACore/* default.install */.Z.install(MultiCheckTreeMenu_MultiCheckTreeMenu); /* harmony default export */ const multichecktreemenu_MultiCheckTreeMenu = (MultiCheckTreeMenu_MultiCheckTreeMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreeleafbox/CTLBPropHandlers.js var CTLBPropHandlers = Object.keys(checktreebox_CTBPropHandlers).reduce((ac, key) => { ac[key] = Object.assign({}, checktreebox_CTBPropHandlers[key]); return ac; }, {}); CTLBPropHandlers.leafOnly = { enumerable: true, value: true }; /* harmony default export */ const checktreeleafbox_CTLBPropHandlers = (CTLBPropHandlers); /*** * * @type {boolean} * @name enableSearch * @memberOf MCheckTreeBox# */ ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreeleafbox/CTLIPropHandlers.js var CTLIPropHandlers = Object.keys(checktreebox_CTIPropHandlers).reduce((ac, key) => { ac[key] = Object.assign({}, checktreebox_CTIPropHandlers[key]); return ac; }, {}); /* harmony default export */ const checktreeleafbox_CTLIPropHandlers = (CTLIPropHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreeleafbox/CheckTreeLeafItem.js /*** * @extends AElement * @constructor */ function CheckTreeLeafItem() { this._data = null; this._status = 'none'; this.$text = (0,ACore.$)('.am-check-tree-item-text', this).firstChild; this.$desc = (0,ACore.$)('.am-check-tree-item-desc', this).firstChild; this.$iconCtn = (0,ACore.$)('.am-check-tree-item-icon-ctn', this); this.$checkbox = (0,ACore.$)('checkboxinput', this) .on('change', this.eventHandler.checkboxChange); this.addEventListener('click', this.eventHandler.click); } OOP/* default.mixClass */.ZP.mixClass(CheckTreeLeafItem, MCheckTreeItem); CheckTreeLeafItem.tag = 'CheckTreeLeafItem'.toLowerCase(); CheckTreeLeafItem.render = function () { return (0,ACore._)({ extendEvent: ['checkedchange', 'click', 'statuschange'], class: ['am-check-tree-leaf-item', 'am-check-tree-item', 'am-dropdown-box-item'], child: [ { class: 'am-check-tree-item-toggle-ctn', child: 'toggler-ico' }, { class: 'am-check-tree-item-icon-ctn' }, { class: 'am-check-tree-item-checkbox-ctn', child: 'checkboxinput' }, { class: 'am-check-tree-item-text', child: { text: '' } }, { class: 'am-check-tree-item-desc', child: { text: '' } } ] }); }; CheckTreeLeafItem.eventHandler = Object.assign({}, MCheckTreeItem.eventHandler); CheckTreeLeafItem.property = checktreeleafbox_CTLIPropHandlers; /*** * @name data * @memberOf CheckTreeLeafItem# */ /***. * @name text * @type {string} * @memberOf CheckTreeLeafItem# */ /*** * @name desc * @type {string} * @memberOf CheckTreeLeafItem# */ /*** * @name value * @memberOf CheckTreeLeafItem# */ /* harmony default export */ const checktreeleafbox_CheckTreeLeafItem = (CheckTreeLeafItem); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreeleafbox/CTLBModes.js /*** * @extends CTBModeNormal * @param {MCheckTreeBox} elt * @param {[]} items * @constructor */ function CTLBModeNormal(elt, items) { CTBModeNormal.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(CTLBModeNormal, CTBModeNormal); CTLBModeNormal.prototype.getViewValues = function () { var values = []; this.children.forEach(function visit(node) { if (node.selected === 'all' && node.data.isLeaf) { values.push(node.data.value); } else if (node.children) { node.children.forEach(visit); } }); return values; }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/checktreeleafbox/MCheckTreeLeafBox.js /*** * @extends MCheckTreeBox * @constructor */ function MCheckTreeLeafBox() { checktreebox_MCheckTreeBox.apply(this, arguments); this.$box.addClass('as-check-tree-leaf-box'); } OOP/* default.mixClass */.ZP.mixClass(MCheckTreeLeafBox, checktreebox_MCheckTreeBox); MCheckTreeLeafBox.tag = 'MCheckTreeLeafBox'.toLowerCase(); MCheckTreeLeafBox.prototype.classes = Object.assign({}, checktreebox_MCheckTreeBox.prototype.classes, { ItemElement: checktreeleafbox_CheckTreeLeafItem, ModeNormal: CTLBModeNormal }); MCheckTreeLeafBox.render = function () { return checktreebox_MCheckTreeBox.render(); }; MCheckTreeLeafBox.property = checktreeleafbox_CTLBPropHandlers; MCheckTreeLeafBox.prototype.findItemByValue = function (value) { return this.itemListCtrl.getItemByValue(value); }; MCheckTreeLeafBox.eventHandler = Object.assign({}, checktreebox_MCheckTreeBox.eventHandler); ACore/* default.install */.Z.install(MCheckTreeLeafBox); /* harmony default export */ const checktreeleafbox_MCheckTreeLeafBox = (MCheckTreeLeafBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/multichecktreeleafmenu/MultiCheckTreeLeafMenu.js /** * @extends MultiCheckTreeMenu * @constructor */ function MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu() { multichecktreemenu_MultiCheckTreeMenu.apply(this, arguments) } OOP/* default.mixClass */.ZP.mixClass(MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu, multichecktreemenu_MultiCheckTreeMenu); MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu.tag = 'MultiCheckTreeLeafMenu'.toLowerCase(); MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu.prototype.classes = { Box: checktreeleafbox_MCheckTreeLeafBox } MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu.render = function () { return multichecktreemenu_MultiCheckTreeMenu.render().addClass('as-multi-check-tree-leaf-menu'); }; MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu.prototype.findItemsByValue = function (value) { return this.$box.findItemByValue(value); }; MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu.property = multichecktreeleafmenu_MCTLMPropHandler; ACore/* default.install */.Z.install(MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu); /* harmony default export */ const multichecktreeleafmenu_MultiCheckTreeLeafMenu = (MultiCheckTreeLeafMenu_MultiCheckTreeLeafMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/selecttreeleafmenu/SelectTreeLeafMenu.js /* harmony default export */ const selecttreeleafmenu_SelectTreeLeafMenu = ((/* unused pure expression or super */ null && (SelectTreeLeafMenu))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectbox/DSBPropHandlers.js var DSBPropHandlers = {}; DSBPropHandlers.items = { set: function (items) { this.itemListCtrl.setItems(items); if ('savedValue' in this) { this.modes.normal.setValue(this.savedValue, this.strictValue); } }, get: function () { return this.itemListCtrl.getItems(); } }; DSBPropHandlers.value = { set: function (value) { this.savedValue = value; this.modes.normal.setValue(value, this.strictValue); }, get: function () { return this.modes.normal.getValue(this.strictValue); } }; DSBPropHandlers.selectedItem = { get: function (){ return this.modes.normal.getSelectedItem(); } }; DSBPropHandlers.strictValue = { set: function (value) { if (value) { this.$box.addClass('as-strict-value'); } else { this.$box.removeClass('as-strict-value'); } }, get: function () { return this.$box.hasClass('as-strict-value'); } }; DSBPropHandlers.enableSearch = { set: function (value) { if (value) { this.$box.addClass('as-enable-search'); } else { this.$box.removeClass('as-enable-search'); } }, get: function () { return this.$box.hasClass('as-enable-search'); } }; /* harmony default export */ const dualselectbox_DSBPropHandlers = (DSBPropHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectbox/DSBModes.js function DSBModeNormal(elt, items) { this.items = items; this.value = [undefined, undefined]; this.elt = elt; this.$lists = this.elt.$lists; this.$leftItems = items.map((item) => this._makeLeftItem(item)); this.$leftItemDict = this.$leftItems.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr.itemData.value)] = cr; return ac; }, {}); this.$rightItemDict = {}; this.$rightItems = []; this.rightListDict = {}; if (items.length > 0) { this.viewRight(items[0].value) } this.$selectedLeft = null; this.$selectedRight = null; } DSBModeNormal.prototype._makeLeftItem = function (item) { var self = this; var itemElt = (0,ACore._)({ class: 'absol-selectlist-item', attr: { 'data-key': (0,utils.keyStringOf)(item.value) }, child: { tag: 'span', class:'absol-selectlist-item-text', child: { text: item.text } }, on: { click: function () { self.selectLeft(item.value); self.viewToSelected(); self.elt.notifyChange(); } } }); itemElt.itemData = item; return itemElt; }; DSBModeNormal.prototype._makeRightItem = function (leftItem, item) { var self = this; var itemElt = (0,ACore._)({ class: 'absol-selectlist-item', attr: { 'data-key': (0,utils.keyStringOf)(item.value) }, child: { tag: 'span', class:'absol-selectlist-item-text', child: { text: item.text } }, on: { click: function () { self.selectLeft(leftItem.value); self.selectRight(item.value); self.elt.notifyChange(); } } }); itemElt.itemData = item; return itemElt; } DSBModeNormal.prototype.selectLeft = function (leftValue) { var itemElt = this.$leftItemDict[(0,utils.keyStringOf)(leftValue)]; if (!itemElt) return false; if (this.$selectedLeft === itemElt) return true; if (this.$selectedLeft) { this.$selectedLeft.removeClass('as-selected'); this.$selectedLeft = null; } itemElt.addClass('as-selected'); this.$selectedLeft = itemElt; this.value[0] = leftValue; this.viewRight(leftValue); var ok = this.selectRight(this.value[1]); var sItems; if (!ok) { sItems = itemElt.itemData.items; if (sItems && sItems.length > 0) this.selectRight(sItems[0].value); } return true; }; DSBModeNormal.prototype.viewRight = function (leftValue) { var key = (0,utils.keyStringOf)(leftValue); var holder = this.rightListDict[key]; var items; var leftItem; if (!holder) { leftItem = this.$leftItemDict[key] && this.$leftItemDict[key].itemData; items = leftItem && leftItem.items; if (items) { holder = {}; holder.list = items.map(sItem => this._makeRightItem(leftItem, sItem)); holder.dict = holder.list.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr.itemData.value)] = cr; return ac; }, {}); this.rightListDict[key] = holder; } } if (holder) { if (this.$rightItems !== holder.list) { this.$rightItems = holder.list; this.$rightItemDict = holder.dict; this.$lists[1].clearChild().addChild(this.$rightItems); } } else { this.$lists[1].clearChild(); this.$rightItems = null; this.$rightItemDict = {}; } } DSBModeNormal.prototype.selectRight = function (value) { var itemElt = this.$rightItemDict[(0,utils.keyStringOf)(value)]; if (!itemElt) return false; if (this.$selectedRight === itemElt) return true; if (this.$selectedRight) { this.$selectedRight.removeClass('as-selected'); this.$selectedRight = null; } itemElt.addClass('as-selected'); this.$selectedRight = itemElt; this.value[1] = value; return true; }; DSBModeNormal.prototype.onStart = function () { this.$lists[0].clearChild().addChild(this.$leftItems); this.$lists[1].clearChild().addChild(this.$rightItems); this.viewToSelected(); }; DSBModeNormal.prototype.onStop = noop/* default */.Z; DSBModeNormal.prototype.setValue = function (value, strictValue) { if (!(value instanceof Array)) { value = [undefined, undefined]; } while (value.length < 2) { value.push(undefined); } while (value.length > 2) value.pop(); var leftOK = this.selectLeft(value[0]); if (!leftOK && strictValue) { if (this.items.length > 0) { leftOK = this.selectLeft(this.items[0].value); } } if (leftOK) this.viewRight(this.value[0]); var rightOK = this.selectRight(value[1]); if (!rightOK && strictValue) { if (this.$selectedLeft && this.$selectedLeft.itemData.items && this.$selectedLeft.itemData.items.length > 0) { rightOK = this.selectRight(this.$selectedLeft.itemData.items[0].value); } } this.viewToSelected(); }; DSBModeNormal.prototype.getValue = function (strictValue) { var value = this.value.slice(); if (!strictValue) return value; if (!this.$leftItemDict[(0,utils.keyStringOf)(value[0])]) { value[0] = this.items[0] && this.items[0].value; } var rightHolder = this.rightListDict[(0,utils.keyStringOf)(value[0])]; if (rightHolder) { if (!rightHolder.dict[(0,utils.keyStringOf)(value[1])]) { if (rightHolder.list.length > 0) { value[1] = rightHolder.list[0].itemData.value; } } } return value; }; DSBModeNormal.prototype.getSelectedItem = function () { var value = this.value.slice(); var item = [null, null]; if (this.$leftItemDict[(0,utils.keyStringOf)(value[0])]) { item[0] = this.$leftItemDict[(0,utils.keyStringOf)(value[0])].itemData; } var rightHolder = this.rightListDict[(0,utils.keyStringOf)(value[0])]; if (rightHolder) { if (rightHolder.dict[(0,utils.keyStringOf)(value[1])]) { item[1] = rightHolder.dict[(0,utils.keyStringOf)(value[1])].itemData; } } return item; } DSBModeNormal.prototype.viewToSelected = function () { setTimeout(() => { if (this.$selectedLeft) { (0,utils.vScrollIntoView)(this.$selectedLeft); } if (this.$selectedRight) { (0,utils.vScrollIntoView)(this.$selectedRight); } }, 50); }; /*** * @extends DSBModeNormal * @param elt * @param items * @constructor */ function DSBModeSearch(elt, items) { DSBModeNormal.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(DSBModeSearch, DSBModeNormal); delete DSBModeSearch.prototype.getValue; delete DSBModeSearch.prototype.setValue; DSBModeSearch.prototype.onStart = function () { DSBModeNormal.prototype.onStart.call(this); this.$lists[0].scrollTop = 0; this.$lists[1].scrollTop = 0; if (this.$selectedLeft) { this.$selectedLeft.removeClass('as-selected'); this.$selectedLeft = null; } if (this.$selectedRight) { this.$selectedRight.removeClass('as-selected'); this.$selectedRight = null; } } DSBModeSearch.prototype.updateSelectedFromRef = function () { var normalMode = this.elt.modes.normal; if (normalMode.$selectedLeft) { this.selectLeft(normalMode.$selectedLeft.itemData.value, true); } if (normalMode.$selectedRight) { this.selectRight(normalMode.$selectedRight.itemData.value, true); } }; DSBModeSearch.prototype.selectLeft = function (leftValue, viewOnly) { if (!viewOnly) this.elt.modes.normal.selectLeft(leftValue); var itemElt = this.$leftItemDict[(0,utils.keyStringOf)(leftValue)]; if (this.$selectedLeft === itemElt) return true; if (this.$selectedLeft) { this.$selectedLeft.removeClass('as-selected'); this.$selectedLeft = null; } if (!itemElt) return false; itemElt.addClass('as-selected'); this.$selectedLeft = itemElt; this.viewRight(leftValue); var sItems = itemElt.itemData.items; if (sItems && sItems.length > 0 && !viewOnly) this.selectRight(sItems[0].value); return true; }; DSBModeSearch.prototype.selectRight = function (value, viewOnly) { if (!viewOnly) this.elt.modes.normal.selectRight(value); var itemElt = this.$rightItemDict[(0,utils.keyStringOf)(value)]; if (this.$selectedRight === itemElt) return true; if (this.$selectedRight) { this.$selectedRight.removeClass('as-selected'); this.$selectedRight = null; } if (!itemElt) return false; itemElt.addClass('as-selected'); this.$selectedRight = itemElt; return true; }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectbox/MDSBItemListController.js function MDSBItemListController(elt) { this.elt = elt; this.items = []; this._searchItems = []; this._searchCache = {}; } MDSBItemListController.prototype.setItems = function (items) { this.items = (0,utils.copySelectionItemArray)(items); this._searchItems = (0,search/* prepareSearchForList */.Lb)((0,utils.copySelectionItemArray)(this.items)); this._searchCache = {}; var mode = new DSBModeNormal(this.elt, this.items); this.elt.modes.normal = mode; this.elt.mode = mode; mode.onStart(); }; MDSBItemListController.prototype.getItems = function () { return (0,utils.copySelectionItemArray)(this.items); }; MDSBItemListController.prototype.makeSearch = function (query) { if (this._searchCache[query]) return this._searchCache[query].resetAndGet(); var items = this._searchItems; var queryItem = (0,search/* default */.ZP)({ text: query }); var maxScore = 0; var holders = items.map(function (item) { var h = { item: item, itemScore: (0,search/* calcItemMatchScore */.lk)(queryItem, item), }; maxScore = Math.max(maxScore, h.itemScore); var childMaxScore = 0; if (item.items && item.items.length > 0) { h.child = item.items.map(function (cItem) { var cItemScore = (0,search/* calcItemMatchScore */.lk)(queryItem, cItem); maxScore = Math.max(maxScore, cItemScore); childMaxScore = Math.max(childMaxScore, cItemScore); return { item: cItem, itemScore: cItemScore }; }); h.childScore = childMaxScore; } return h; }); holders.sort(function (a, b) { return -Math.max(a.itemScore, a.childScore) + Math.max(b.itemScore, b.childScore) }); var midScore = maxScore / 2; holders = holders.filter(function (holder) { return Math.max(holder.itemScore, holder.childScore) >= midScore; }); var searchingResultItems = holders.map(function (holder) { var oldItem = holder.item; var item = { text: oldItem.text, value: oldItem.value }; var childHolders; if (holder.child) { childHolders = holder.child.slice(); childHolders.sort(function (a, b) { return -a.itemScore + b.itemScore; }); item.items = childHolders.map(function (cHolder) { return cHolder.item; }); item.isSearchItem = true; } return item; }); var mode = new DSBModeSearch(this.elt, searchingResultItems); this._searchCache[query] = { mode: mode, resetAndGet: function (){ return this.mode } }; return mode; }; /* harmony default export */ const dualselectbox_MDSBItemListController = (MDSBItemListController); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/dualselectbox.css var dualselectbox = __webpack_require__(560); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectbox/MDualSelectBox.js /*** * @extends {AElement} * @constructor */ function MDualSelectBox() { this.$box = (0,ACore.$)('.am-dropdown-box', this); this.$lists = (0,ACore.$$)('.as-dual-select-box-list', this); this.itemListCtrl = new dualselectbox_MDSBItemListController(this); this.$searchInput = (0,ACore.$)(Searcher/* default.tag */.Z.tag, this) .on('stoptyping', this.eventHandler.searchModify); this.$closeBtn = (0,ACore.$)('.am-dropdown-box-close-btn', this); this.modes = { normal: new DSBModeNormal(this, []) } this.mode = this.modes.normal; this.strictValue = true; this.on('click', this.eventHandler.click); } MDualSelectBox.tag = 'MDualSelectBox'.toLowerCase(); MDualSelectBox.render = function () { return (0,ACore._)({ extendEvent: ['change', 'close'], class: ['am-modal', 'am-dropdown-box-modal'], child: { class: ['am-dual-select-box', 'am-dropdown-box', 'as-dropdown-box-common-style'], child: [ { class: 'am-dropdown-box-header', child: [ { tag: Searcher/* default.tag */.Z.tag }, { tag: 'button', class: 'am-dropdown-box-close-btn', child: 'span.mdi.mdi-close' } ] }, { class: ['am-dropdown-box-body', 'am-check-tree-box-body', 'as-dual-select-box-list-ctn'], child: [ { class: ['as-dual-select-box-list', 'absol-selectlist'], }, { class: 'as-dual-select-box-arrow-ctn', child: 'span.mdi.mdi-menu-right' }, { class: ['as-dual-select-box-list', 'absol-selectlist'] } ] } ] } }); }; MDualSelectBox.prototype.viewToSelected = function () { this.modes.normal.viewToSelected(); }; MDualSelectBox.prototype.notifyChange = function () { var newValue = this.value; if ((0,utils.keyStringOf)(newValue) !== (0,utils.keyStringOf)(this['savedValue'])) { this.savedValue = newValue; this.emit('change', { type: 'change', target: this }, this); } }; MDualSelectBox.prototype.resetSearchState = function () { this.$searchInput.value = ''; this.eventHandler.searchModify(); } MDualSelectBox.property = dualselectbox_DSBPropHandlers; MDualSelectBox.eventHandler = {}; MDualSelectBox.eventHandler.searchModify = function () { var query = this.$searchInput.value.trim().replace(/\s+/g, ' '); if (query.length > 0) { if (this.mode === this.modes.normal) { this.mode.onStop(); this.$box.addClass('as-searching'); } this.mode.search = this.itemListCtrl.makeSearch(query); this.mode = this.mode.search; this.mode.onStart(); } else { if (this.mode !== this.modes.normal) { this.mode.onStop(); this.mode = this.modes.normal; this.mode.onStart(); this.$box.removeClass('as-searching'); } } }; MDualSelectBox.eventHandler.click = function (event) { if (event.target === this || (0,EventEmitter/* hitElement */.EY)(this.$closeBtn, event)) { this.emit('close', { type: 'close', target: this, originalEvent: event }, this); } }; /* harmony default export */ const dualselectbox_MDualSelectBox = (MDualSelectBox); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectmenu/MDSMBoxController.js function MDSMBoxController(elt) { this.elt = elt; this.$box = elt.$box; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.elt.on('click', this.ev_click); this.$box.on('close', this.ev_close); } MDSMBoxController.prototype.ev_click = function () { this.elt.isFocus = true; }; MDSMBoxController.prototype.ev_close = function () { this.elt.isFocus = false; }; MDSMBoxController.prototype.onFocus = function (){ this.$box.addTo(document.body); this.$box.viewToSelected(); this.elt.off('click', this.ev_click); }; MDSMBoxController.prototype.onBlur = function (){ this.$box.remove(); setTimeout(()=>{ this.elt.on('click', this.ev_click); }, 50); }; /* harmony default export */ const dualselectmenu_MDSMBoxController = (MDSMBoxController); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/VarScope.js var VarScope = __webpack_require__(1312); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectmenu/DSMPropsHandlers.js var DSMPropsHandlers = {}; DSMPropsHandlers.isFocus = { set: function (value) { if (this.disabled || this.readOnly) value = false; value = !!value; if (value === this.hasClass('as-focus')) return; if (value) { this.savedValue = this.$box.value; this.addClass('as-focus'); this.boxCtrl.onFocus(); } else { this.removeClass('as-focus'); this.boxCtrl.onBlur(); this.updateText(); if ((0,utils.keyStringOf)(this.savedValue) !== (0,utils.keyStringOf)(this.$box.value)) { delete this.savedValue; this.notifyChange(); } } }, get: function () { return this.hasClass('as-focus'); } }; DSMPropsHandlers.items = { set: function (items) { this.$box.items = items; if ('pendingValue' in this) { this.$box.value = this.pendingValue; } this.updateText(); }, get: function () { return this.$box.items; } }; DSMPropsHandlers.value = { set: function (value) { this.pendingValue = value; this.$box.value = value; this.updateText(); }, get: function () { if (!this.strictValue && ('pendingValue' in this)) { return this.pendingValue; } var value = this.$box.value; var selectedItem = this.$box.selectedItem; if (!selectedItem || !selectedItem[0] || !selectedItem[1]) return null; return value; } }; DSMPropsHandlers.format = { set: function (value) { this.attr('data-format', value); this.updateText(); }, get: function () { return this.attr('data-format') || '$0, $1'; } }; DSMPropsHandlers.strictValue = { set: function (value) { this.$box.strictValue = value; if (value) { this.addClass('as-strict-value'); } else { this.removeClass('as-strict-value'); } }, get: function () { return this.$box.strictValue; } }; DSMPropsHandlers.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.hasClass('as-disabled'); } }; DSMPropsHandlers.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.hasClass('as-read-only'); } }; /* harmony default export */ const dualselectmenu_DSMPropsHandlers = (DSMPropsHandlers); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dualselectmenu/DualSelectMenu.js function DualSelectMenu_DualSelectMenu() { this.$box = (0,ACore._)({ tag: dualselectbox_MDualSelectBox, }); this.$item = (0,ACore.$)('.absol-selectlist-item', this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$box, 'enableSearch'); this.boxCtrl = new dualselectmenu_MDSMBoxController(this); this.strictValue = true; } DualSelectMenu_DualSelectMenu.tag = 'DualSelectMenu'.toLowerCase(); DualSelectMenu_DualSelectMenu.render = function () { return (0,ACore._)({ class: ['am-dual-select-menu', 'absol-selectmenu', 'as-dual-select-menu'], extendEvent: ['change'], attr: { tabindex: '1' }, child: [ { class: 'absol-selectmenu-holder-item', child: '.absol-selectlist-item' }, { tag: 'button', class: 'absol-selectmenu-btn', child: ['dropdown-ico'] }, 'attachhook', ] }); }; DualSelectMenu_DualSelectMenu.prototype.notifyChange = function () { // console.log('change') delete this['pendingValue']; this.emit('change', { type: 'change', target: this }, this); }; DualSelectMenu_DualSelectMenu.prototype.updateText = function () { var selectedItem = this.$box.selectedItem; var format = this.format; var firstToken = '__'; var secToken = '__'; if (selectedItem[0]) { firstToken = selectedItem[0].text + '' } if (selectedItem[1]) { secToken = selectedItem[1].text + '' } var text = format.replace('$0', firstToken) .replace('$1', secToken); this.$item.clearChild().addChild((0,ACore._)({ tag: 'span', class:'absol-selectlist-item-text', child: { text: text } })); }; DualSelectMenu_DualSelectMenu.property = dualselectmenu_DSMPropsHandlers; DualSelectMenu_DualSelectMenu.eventHandler = {}; /* harmony default export */ const dualselectmenu_DualSelectMenu = (DualSelectMenu_DualSelectMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTHeadCell.js /*** * * @param {TTHeadRow} row * @param {TTDHeadCell} data * @constructor */ function TTHeadCell(row, data){ this.row = row; this.data = data; this.elt = (0,ACore._)({ tag:'th', class: 'as-tree-table-head-cell' }); if (data.attr) this.elt.attr(data.attr); if (data.style) this.elt.addStyle(data.style); this.row.head.table.elt.mAdapter.renderHeadCell(this.elt, this.data, this); } TTHeadCell.prototype.render = function (){ }; /* harmony default export */ const treetable_TTHeadCell = (TTHeadCell); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTHeadRow.js /** * * @param {TTHead} head * @param {TTDHeadRow} data * @constructor */ function TTHeadRow(head, data) { this.head = head; this.data = data; this.cells = this.data.cells.map(cellData => new treetable_TTHeadCell(this, cellData)); this.elt = (0,ACore._)({ tag:'tr', class:'as-tree-table-head-row' }); this.elt.addChild(this.cells.map((cell, i)=> cell.elt.attr('data-col-idx', ''+i))); } /* harmony default export */ const treetable_TTHeadRow = (TTHeadRow); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTHead.js /*** * * @param {TTTable} table * @param {TTDHead} data * @constructor */ function TTHead(table, data) { this.data = data; this.table = table; this.elt = this.table.elt.$head; this.rows = (this.data.rows || []).map(rowData => new treetable_TTHeadRow(this, rowData)); this.elt.clearChild().addChild(this.rows.map(r=> r.elt)); } /* harmony default export */ const treetable_TTHead = (TTHead); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTCell.js /*** * * @param {TTRow} row * @param {TTDCell} data * @constructor */ function TTCell(row, data) { this.row = row; this.data = data; } Object.defineProperty(TTCell.prototype, 'elt', { get: function () { if (!this._elt) { this._elt = (0,ACore._)({ tag: 'td', class: 'as-tree-table-cell', props: { ttCell: this }, on: { click: (event) => { if (this.data && this.data.on && this.data.on.click) { this.data.on.click.call(this._elt, event, this); } } } }); if (typeof this.data.class === "string") { (0,utils.addElementClassName)(this._elt, this.data.class); } if (this.data.attr) this._elt.attr(this.data.attr); if (this.data.class) this._elt.addClass(this.data.class); if (this.data.style) this._elt.addStyle(this.data.style); this.row.body.table.elt.mAdapter.renderBodyCell(this.elt, this.data, this); } return this._elt; } }); Object.defineProperty(TTCell.prototype, 'innerText', Object.getOwnPropertyDescriptor(dynamictable_DTBodyCell.prototype, 'innerText')); /* harmony default export */ const treetable_TTCell = (TTCell); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTRow.js /*** * * @param {TTBody} body * @param {TTDRow}data * @param parentRow * @constructor */ function TTRow(body, data, parentRow) { this.id = (0,stringGenerate.randomIdent)(8); this.level = parentRow ? parentRow.level + 1 : 0; this.body = body; this.data = data; this.parentRow = parentRow; this.clonedRow = null; this.cells = (this.data.cells || []).map(cellData => new treetable_TTCell(this, cellData)); this.subRows = (this.data.subRows || []).map(rowData => new TTRow(body, rowData, this)); if (!(0,utils.isNone)(data.id) && data.subRows && data.subRows.length > 0 && (data.id in this.body.table.elt.savedState)) { this.isOpened = !!this.body.table.elt.savedState[data.id]; } else if (typeof data.initOpened === 'boolean') { this.isOpened = data.initOpened; } else if (typeof body.table.data.initOpened === "boolean") { this.isOpened = body.table.data.initOpened; } else if (typeof body.table.elt.initOpened === 'boolean') { this.isOpened = body.table.elt.initOpened; } else if ((typeof body.table.data.initOpened === 'number')) { this.isOpened = this.level < body.table.data.initOpened ; } } TTRow.prototype.isOpened = false; /*** * * @param {Array<AElement>=} ac */ TTRow.prototype.getRowElements = function (ac) { ac = ac || []; ac.push(this.elt); if (this.isOpened) { this.subRows.forEach(row => row.getRowElements(ac)); } return ac; }; TTRow.prototype.toggle = function () { if (this.isOpened) this.close(); else this.open(); }; TTRow.prototype.open = function () { if (this.isOpened) return; if (this.subRows.length === 0) return; this.isOpened = true; if (!(0,utils.isNone)(this.data.id) && this.cells)//real node this.body.table.elt.savedState[this.data.id] = this.isOpened; this.elt.addClass('as-is-opened'); var rowElements = this.getRowElements(); rowElements.shift(); var bodyElt = this.body.elt; var bf = this.body.elt.findChildAfter(this.elt); if (bf) { rowElements.forEach(elt => bodyElt.addChildBefore(elt, bf)); } else { bodyElt.addChild(rowElements); } this.updateSizeUp(); this.requestParentUpdateContent(); }; TTRow.prototype.close = function () { if (!this.isOpened) return; var rowElements = this.getRowElements(); rowElements.shift(); rowElements.forEach(elt => elt.remove()); this.isOpened = false; if (!(0,utils.isNone)(this.data.id) && this.cells) this.body.table.elt.savedState[this.data.id] = this.isOpened; this._elt.removeClass('as-is-opened'); this.updateSizeUp(); this.requestParentUpdateContent(); }; TTRow.prototype.updateSizeUp = function () { this.body.table.elt.notifySizeChange(); }; TTRow.prototype.requestParentUpdateContent = function () { var c = this.body.table.elt.parentElement; while (c) { if (c.updateContent) { console.log('update content'); c.updateContent(); break; } else c = c.parentElement; } }; TTRow.prototype.remove = function () { var idx = -1; var rowElements; var removeRow = (idx, rows, dataRows) => { rows.splice(idx, 1); dataRows.splice(idx, 1); if (this.clonedRow) this.clonedRow.remove(); if (this.elt.parentElement) { rowElements = this.clonedRow ? this.clonedRow.getRowElements() : this.getRowElements(); rowElements.forEach(elt => elt.selfRemove()); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } this.body.table.elt.queryCtrl.requestTransferSearchItems(); } if (this.parentRow) { idx = this.parentRow.subRows.indexOf(this); if (idx >= 0) { removeRow(idx, this.parentRow.subRows, this.parentRow.data.subRows); if (this.parentRow.subRows.length === 0) this.parentRow.elt.removeClass('as-has-sub-row'); } } else { idx = this.body.rows.indexOf(this); if (idx >= 0) { removeRow(idx, this.body.rows, this.body.data.rows); } } }; /*** * @param {TTDRow} rowData */ TTRow.prototype.addSubRow = function (rowData) { var row = new TTRow(this.body, rowData, this); var clonedRow; if (this.clonedRow) clonedRow = new TTClonedRow(row, null, this.subRows.length);//idx is not important var rowElements; var bf; if (this.elt.parentElement && this.isOpened) { rowElements = this.clonedRow ? this.clonedRow.getRowElements() : this.getRowElements(); bf = this.body.elt.findChildAfter(rowElements[rowElements.length - 1]); rowElements = clonedRow ? clonedRow.getRowElements() : row.getRowElements(); if (bf) { rowElements.forEach(elt => this.body.elt.addChildBefore(elt, bf)); } else { rowElements.forEach(elt => this.body.elt.addChild(elt)); } ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } this.subRows.push(row); if (this.data.subRows) { this.data.subRows.push(rowData); } else { this.data.subRows = [rowData]; } if (this.clonedRow) this.clonedRow.addSubRow(clonedRow); if (this._elt) this.elt.addClass('as-has-sub-row'); this.body.table.elt.queryCtrl.requestTransferSearchItems(); }; /*** * @param {TTDRow} newRowData */ TTRow.prototype.replace = function (newRowData) { var idx = -1; var rowElements; var bf; var newRow; var newClonedRow; var needView; var makeReplaceRow = (idx, rows, dataRows) => { newRow = new TTRow(this.body, newRowData, this.parentRow); rows.splice(idx, 1, newRow); dataRows.splice(idx, 1, newRowData); if (this.clonedRow) { newClonedRow = new TTClonedRow(newRow, null, idx); this.clonedRow.replace(newClonedRow) } if (this.elt.parentElement) { rowElements = this.clonedRow ? this.clonedRow.getRowElements() : this.getRowElements(); bf = this.body.elt.findChildAfter(rowElements[rowElements.length - 1]); rowElements.forEach(elt => elt.selfRemove()); rowElements = newClonedRow ? newClonedRow.getRowElements() : newRow.getRowElements(); if (bf) { rowElements.forEach(elt => this.body.elt.addChildBefore(elt, bf)); } else { rowElements.forEach(elt => this.body.elt.addChild(elt)); } ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } this.body.table.elt.queryCtrl.requestTransferSearchItems(); } if (this.parentRow) { idx = this.parentRow.subRows.indexOf(this); if (idx >= 0) { makeReplaceRow(idx, this.parentRow.subRows, this.parentRow.data.subRows); } } else { idx = this.body.rows.indexOf(this); if (idx >= 0) { makeReplaceRow(idx, this.body.rows, this.body.data.rows); } } }; /*** * @param {TTDRow} newRowData */ TTRow.prototype.addRowBefore = function (newRowData) { var idx = -1; var makeNewRowBefore = (idx, rows, dataRows) => { var row, clonedRow; var rowElements; row = new TTRow(this.body, newRowData, this.parentRow); if (this.clonedRow) { clonedRow = new TTClonedRow(row, null, idx); } if (this.elt.parentElement) { rowElements = clonedRow ? clonedRow.getRowElements() : row.getRowElements(); rowElements.forEach(elt => this.body.elt.addChildBefore(elt, this.elt)); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } rows.splice(idx, 0, row); dataRows.splice(idx, 0, newRowData); if (this.clonedRow) { this.clonedRow.addRowBefore(clonedRow); } this.body.table.elt.queryCtrl.requestTransferSearchItems(); } if (this.parentRow) { idx = this.parentRow.subRows.indexOf(this); if (idx >= 0) { makeNewRowBefore(idx, this.parentRow.subRows, this.parentRow.data.subRows) } } else { idx = this.body.rows.indexOf(this); if (idx >= 0) { makeNewRowBefore(idx, this.body.rows, this.body.data.rows); } } }; /*** * @param {TTDRow} newRowData */ TTRow.prototype.addRowAfter = function (newRowData) { var idx = -1; var rowElements; var bf; var makeNewRowAfter = (idx, rows, dataRows) => { var row = new TTRow(this.body, newRowData, this.parentRow); var clonedRow; if (this.clonedRow) clonedRow = new TTClonedRow(row, null, idx); if (this.elt.parentElement) { rowElements = this.clonedRow ? this.clonedRow.getRowElements() : this.getRowElements(); bf = this.body.elt.findChildAfter(rowElements[rowElements.length - 1]); rowElements = clonedRow ? clonedRow.getRowElements() : row.getRowElements(); if (bf) { rowElements.forEach(elt => this.body.elt.addChildBefore(elt, bf)); } else { rowElements.forEach(elt => this.body.elt.addChild(elt)); } ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); } rows.splice(idx + 1, 0, row); dataRows.splice(idx + 1, 0, newRowData); if (this.clonedRow) this.clonedRow.addRowBefore(clonedRow); this.body.table.elt.queryCtrl.requestTransferSearchItems(); } if (this.parentRow) { idx = this.parentRow.subRows.indexOf(this); if (idx >= 0) { makeNewRowAfter(idx, this.parentRow.subRows, this.parentRow.data.subRows); } } else { idx = this.body.rows.indexOf(this); if (idx >= 0) { makeNewRowAfter(idx, this.body.rows, this.body.data.rows); } } }; Object.defineProperty(TTRow.prototype, 'elt', { get: function () { if (!this._elt) { this._elt = (0,ACore._)({ tag: 'tr', class: 'as-tree-table-row', attr: { 'data-level': this.level + '' }, props: { ttRow: this } }); if (this.data.id) this._elt.attr('data-id', this.data.id); if (this.isOpened) this._elt.addClass('as-is-opened'); if (this.subRows.length > 0) this._elt.addClass('as-has-sub-row'); this._elt.addChild(this.cells.map((cell, i) => (cell.elt).attr('data-col-idx', i + ''))); if (this.data.on && (typeof this.data.on.click === "function")) { this._elt.on('click', (event)=>{ this.data.on.click.call(this._elt, event, this); }); } this.$toggle = (0,ACore.$)('.as-tree-table-toggle', this._elt); if (this.$toggle) { this.$toggleCell = this.$toggle.parentElement; this.$toggleCell.addClass('as-has-toggle'); this.$toggle = (0,ACore._)({ elt: this.$toggle, child: 'toggler-ico', on: { click: () => { if (this.clonedRow) { this.clonedRow.toggle(); } else { this.toggle(); } } } }); } } return this._elt; } }); Object.defineProperty(TTRow.prototype, 'innerText', Object.getOwnPropertyDescriptor(dynamictable_DTBodyRow.prototype, 'innerText')); /* harmony default export */ const treetable_TTRow = (TTRow); /*** * * @param {TTRow} origin * @param queryResult * @param idx * @constructor */ function TTClonedRow(origin, queryResult, idx) { this.body = origin.body; this.idx = idx; this.id = origin.id; this._elt = origin.elt; this.elt = origin.elt; this.data = origin.data; this.origin = origin; this.score = queryResult && queryResult[this.id]; if (!queryResult) this.score = 1e6; this.isOpened = this.score && this.score[0] <= this.score[1]; this.attach(); if (this.isOpened) { this.subRows = this.origin.subRows.filter(row => queryResult[row.id]) .map((row, i) => new TTClonedRow(row, queryResult, i)); this.subRows.sort((a, b) => { var sa = a.score[1]; var sb = b.score[1]; if (sa !== sb) return sb - sa; return a.idx - b.idx; }); } else { this.subRows = this.origin.subRows.map((row, i) => new TTClonedRow(row, queryResult, i)); } } ['toggle', 'open', 'close', 'getRowElements', 'updateSizeUp'].forEach(key => { TTClonedRow.prototype[key] = TTRow.prototype[key]; }); TTClonedRow.prototype.remove = function () { var parentRow = this.origin.parentRow && this.origin.parentRow.clonedRow; var idx; if (parentRow) { idx = parentRow.subRows.indexOf(this); if (idx >= 0) { parentRow.subRows.splice(idx, 1); } } else { idx = this.origin.body.clonedRows.indexOf(this); if (idx >= 0) { this.origin.body.clonedRows.splice(idx, 1); } } }; TTClonedRow.prototype.replace = function (newClonedRow) { var parentRow = this.origin.parentRow && this.origin.parentRow.clonedRow; var idx; if (parentRow) { idx = parentRow.subRows.indexOf(this); if (idx >= 0) { parentRow.subRows.splice(idx, 1, newClonedRow); } } else { idx = this.origin.body.clonedRows.indexOf(this); if (idx >= 0) { this.origin.body.clonedRows.splice(idx, 1, newClonedRow); } } }; TTClonedRow.prototype.addRowBefore = function (newClonedRow) { var parentRow = this.origin.parentRow && this.origin.parentRow.clonedRow; var idx; if (parentRow) { idx = parentRow.subRows.indexOf(this); if (idx >= 0) { parentRow.subRows.splice(idx, 0, newClonedRow); } } else { idx = this.origin.body.clonedRows.indexOf(this); if (idx >= 0) { this.origin.body.clonedRows.splice(idx, 0, newClonedRow); } } }; TTClonedRow.prototype.addRowAfter = function (newClonedRow) { var parentRow = this.origin.parentRow && this.origin.parentRow.clonedRow; var idx; if (parentRow) { idx = parentRow.subRows.indexOf(this); if (idx >= 0) { parentRow.subRows.splice(idx + 1, 0, newClonedRow); } } else { idx = this.origin.body.clonedRows.indexOf(this); if (idx >= 0) { this.origin.body.clonedRows.splice(idx + 1, 0, newClonedRow); } } }; TTClonedRow.prototype.addSubRow = function (newClonedRow) { this.subRows.push(newClonedRow); }; TTClonedRow.prototype.attach = function () { if (this.isOpened) { this.origin.elt.addClass('as-is-opened'); } else { this.origin.elt.removeClass('as-is-opened'); } this.origin.clonedRow = this; }; TTClonedRow.prototype.detach = function () { if (this.origin.isOpened) { this.origin.elt.addClass('as-is-opened'); } else { this.origin.elt.removeClass('as-is-opened'); } this.origin.clonedRow = null; this.subRows.forEach(row => row.detach()); }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTBody.js /*** * * @param {TTTable}table * @param {TTDBody} data * @constructor */ function TTBody(table, data) { this.table = table; this.data = data; this.elt = this.table.elt.$body; /*** * * @type {TTRow[]} */ this.rows = (this.data.rows || []).map(rowData => new treetable_TTRow(this, rowData, null)); this.clonedRows = null; this.renderRows(); } TTBody.prototype.applyQueryResult = function (queryResult) { this.clearClonedRows(); if (queryResult) { this.table.elt.addClass('as-searching'); this.clonedRows = this.rows.filter(row => queryResult[row.id]) .map((row, i) => new TTClonedRow(row, queryResult, i)); this.clonedRows.sort((a, b) => { var sa = a.score[1]; var sb = b.score[1]; if (sa !== sb) return sb - sa; return a.idx - b.idx; }); this.renderRows(this.clonedRows); this.table.elt.notifySizeChange(); } else { this.table.elt.removeClass('as-searching'); this.renderRows(); } }; TTBody.prototype.clearClonedRows = function () { if (this.clonedRows) this.clonedRows.forEach(row => row.detach()); this.clonedRows = null; }; /*** * */ TTBody.prototype.renderRows = function (rows) { rows = rows || this.rows; this.elt.clearChild().addChild(rows.reduce((ac, row) => { row.getRowElements(ac); return ac; }, [])); }; /*** * * @param data */ TTBody.prototype.rowOf = function (data) { if (data instanceof treetable_TTRow) { data = data.data; } var result = null; var queue = this.rows.slice(); var cr; while (queue.length > 0 && !result) { cr = queue.shift(); if (cr.data === data || cr.data.id === data || (data.id && cr.data.id === data.id)) { result = cr; } else { queue.push.apply(queue, cr.subRows); } } return result; }; /*** * * @param {TTDRow} rowData */ TTBody.prototype.addRow = function (rowData) { var row = new treetable_TTRow(this, rowData, null); this.data.rows.push(rowData); this.rows.push(row); var elements = row.getRowElements(); elements.forEach(elt => this.elt.addChild(elt)); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }; /* harmony default export */ const treetable_TTBody = (TTBody); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTTable.js /*** * * @param {TreeTable} elt * @param data * @constructor */ function TTTable(elt, data) { this.data = data; this.elt = elt; this.head = new treetable_TTHead(this, this.data.head); this.body = new treetable_TTBody(this, this.data.body); } /* harmony default export */ const treetable_TTTable = (TTTable); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTDataAdapter.js /*** * * @param {TreeTable} tableElt * @param opt * @constructor */ function TTDataAdapter(tableElt, opt) { this.tableElt = tableElt; this.data = null; Object.assign(this, opt || {}); } TTDataAdapter.prototype.render = function () { if (this.tableElt.table) { } this.tableElt.table = new treetable_TTTable(this.tableElt, this.data); }; /*** * * @param {AElement} elt * @param {TTDHeadCell} data * @param {TTHeadCell} controller */ TTDataAdapter.prototype.renderHeadCell = function (elt, data, controller) { if (data.child) { if (data.child.map) { elt.addChild(data.child.map(function (it) { return (0,ACore._)(it); })); } else { elt.addChild((0,ACore._)(data.child)); } } if (data.render) { data.render.call(null, elt, data, controller); } if (data.style) { elt.addStyle(data.style); } }; /*** * * @param {AElement} elt * @param {TTDCell} data * @param {TTCell} controller */ TTDataAdapter.prototype.renderBodyCell = function (elt, data, controller) { if (data.child) { if (data.child.map) { elt.addChild(data.child.map(function (it) { return (0,ACore._)(it); })) } else { elt.addChild((0,ACore._)(data.child)); } } if (data.render) { data.render.call(null, elt, data, controller); } if (data.style) { elt.addStyle(data.style); } if (data.class) { elt.addClass(data.class); } if (data.attr) { elt.attr(data.attr); } }; /* harmony default export */ const treetable_TTDataAdapter = (TTDataAdapter); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/treetable.css var treetable = __webpack_require__(7961); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TTQueryController.js /*** * * @param {TreeTable} elt * @constructor */ function TTQueryController(elt) { this.searchMaster = new ListSearchMaster/* default */.Z(); this.elt = elt; this.$filterInputs = []; this.$searchInput = null; this['request'] = this['request'].bind(this); this._waitDestroy(); this._rtsiIdx = -1; } TTQueryController.prototype._waitDestroy = function (){ setTimeout(()=>{ if (this.elt.isDescendantOf(document.body)) { this._waitDestroy(); } else { this.searchMaster.destroy(); } }, 10000); }; TTQueryController.prototype.attachFilterInput = function (input) { if (this.$filterInputs.indexOf(input) >= 0) return; if (input.detachTreeTable) input.detachTreeTable(); input.$treeTable = this; if ((0,ACore.$)(input).isSupportedEvent('stoptyping')) { input.on('stoptyping', this.request); } else { input.on('change', this.request); } input.detachTreeTable = this.detachFilterInput.bind(this, input); this.$filterInputs.push(input); }; TTQueryController.prototype.detachFilterInput = function (input) { var idx = this.$filterInputs.indexOf(input); if (idx < 0) return; this.$filterInputs.splice(idx, 1); input.off(this.$searchInput.isSupportedEvent('stoptyping') ? 'stoptyping' : 'change', this.request); input.detachTreeTable = null; }; TTQueryController.prototype.attachSearchInput = function (input) { if (this.$searchInput === input) return; if (input.detachTreeTable) input.detachTreeTable(); this.$searchInput = input; if ((0,ACore.$)(input).isSupportedEvent('stoptyping')) { input.on('stoptyping', this.request); } else { input.on('change', this.request); } input.detachTreeTable = this.detachSearchInput.bind(this, input) }; TTQueryController.prototype.detachSearchInput = function (input) { input = input || this.$searchInput; if (input !== this.$searchInput) return; input.off(this.$searchInput.isSupportedEvent('stoptyping') ? 'stoptyping' : 'change', this.request); input.detachTreeTable = null; this.$searchInput = null; }; TTQueryController.prototype.makeQuery = function () { var res = {}; if (this.$searchInput && this.$searchInput.value.trim().length > 0) { res.text = this.$searchInput.value.trim(); } for (var key in res) { return res; } return null; } TTQueryController.prototype.request = function () { var query = this.makeQuery(); if (query) this.searchMaster.query(query).then(searchResult => { this.elt.table.body.applyQueryResult(searchResult); }); else this.elt.table.body.applyQueryResult(null); }; TTQueryController.prototype.getSearchItems = function () { var getSearchItemOf = row => { var res = {}; res.text = row.innerText; res.value = row.id; if (row.subRows && row.subRows.length > 0) { res.items = row.subRows.map(getSearchItemOf) } return res; } return this.elt.table.body.rows.map(getSearchItemOf); }; TTQueryController.prototype.transferSearchItems = function () { this.searchMaster.transfer(this.getSearchItems()); }; TTQueryController.prototype.requestTransferSearchItems = function (){ if (this._rtsiIdx > 0) return; this._rtsiIdx = setTimeout(()=>{ this._rtsiIdx = -1; this.transferSearchItems(); }, 0); }; /* harmony default export */ const treetable_TTQueryController = (TTQueryController); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/LinearColorTinyBar.js /*** * @extends {AElement} * @constructor */ function LinearColorTinyBar() { this._value = 0; this._colorMapping = 0; this._colorMapping = this.BUILDIN_COLORS_RANGE.rainbow; this.$textCtn = (0,ACore.$)('.as-linear-color-tiny-text', this); /*** * * @type {Text} */ this.$text = this.$textCtn.firstChild; /*** * @type {string} valueText * @memberOf LinearColorTinyBar# * @name valueText */ /*** * @type {number} from 0..1..Inf * @memberOf LinearColorTinyBar# * @name value */ /*** * @type {Array} - from 0..1..Inf * @memberOf LinearColorTinyBar# * @name colorMapping# */ } LinearColorTinyBar.tag = 'LinearColorTinyBar'.toLowerCase(); LinearColorTinyBar.render = function () { return (0,ACore._)({ class: 'as-linear-color-tiny-bar', child: [ { tag: 'span', class: 'as-linear-color-tiny-text', style: { display: 'none' }, child: { text: '' } }, '.as-linear-color-tiny-bar-rect', ] }); } LinearColorTinyBar.prototype.BUILDIN_COLORS_RANGE = js_LinearColorBar.prototype.BUILDIN_COLORS_RANGE; LinearColorTinyBar.prototype._updateColor = function () { var value = this._value; var colorMapping = this.colorMapping; var i = 0; while (i < colorMapping.length) { if (i + 1 == colorMapping.length || colorMapping[i + 1].value > value) break; ++i; } this.addStyle('--color', colorMapping[i].color + ''); }; LinearColorTinyBar.property = {}; LinearColorTinyBar.property.value = { set: function (value) { if (typeof value === "string") value = parseFloat(value); if (typeof value !== "number") value = 0; if (isNaN(value)) value = 0; this._value = Math.max(value, 0); this.addStyle('--value', this._value + ''); this._updateColor(); }, get: function () { return this._value; } }; LinearColorTinyBar.property.valueText = { set: function (value) { if (typeof value === "string" || typeof value === 'number') { this.$text.data = value; this.$textCtn.removeStyle('display', 'none'); } else { this.$text.data = ''; this.$textCtn.addStyle('display', 'none'); } }, get: function () { return this.$text.data; } }; LinearColorTinyBar.property.colorMapping = { set: function (value) { var ok = true; if (typeof value === 'string') { if (!(value in this.BUILDIN_COLORS_RANGE)) { value = 'rainbow' } value = this.BUILDIN_COLORS_RANGE[value]; } else if (value instanceof Array) { ok = value.length > 1; if (!ok) { console.warn("colorMapping.length must > 1", value); } } else { console.warn("Invalid colorMapping", value); } if (!ok) value = this.BUILDIN_COLORS_RANGE.rainbow; this._colorMapping = value; this._updateColor(); }, get: function () { return this._colorMapping; } }; ACore/* default.install */.Z.install(LinearColorTinyBar); /* harmony default export */ const js_LinearColorTinyBar = (LinearColorTinyBar); printer.ShareSerializer.addHandlerBefore({ match: (elt, scope, stack) => { return elt.hasClass && elt.hasClass('as-linear-color-tiny-bar-rect'); }, exec: (printer, elt, scope, stack, accept) => { var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect()); bound.x -= printer.O.x; bound.y -= printer.O.y; printer.rect(bound, { fill: elt.getComputedStyleValue('background-color') }); } }, '*') ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/treetable/TreeTable.js /*** * @typedef {Object} TTDHeadCell * @property {AbsolConstructDescriptor|Array<AbsolConstructDescriptor>|AElement} [child] * @property {function(elt:AElement, data:TTDHeadCell, controller:TTCell): void} render * @property {CSSStyleDeclaration} style */ /*** * @typedef {Object} TTDHeadRow * @property {Array<TTDHeadCell>} cells * @property {Array<TTDHeadRow>} subRows */ /*** * @typedef {Object} TTDHead * @property {Array<TTDHeadRow>} rows */ /*** * @typedef {Object} TTDCell * @property {AbsolConstructDescriptor|Array<AbsolConstructDescriptor>|AElement} [child] * @property {function(elt:AElement, data:TTDCell, controller:TTCell): void} render * @property {CSSStyleDeclaration} [style] * @property {string|Array<string>} class * @property {Object} attr */ /*** * @typedef {Object} TTDRow * @property {Array<TTDCell>} cells * @property {Array<TTDRow>} subRows * @property {string} [id] * */ /*** * @typedef {Object} TTDHead * @property {Array<TTDHeadRow>} rows */ /*** * @typedef {Object} TTDBody * @property {Array<TTDRow>} rows */ /*** * @typedef {Object} TTData * @property {TTDHead} head * @property {TTDBody} body * @property {boolean} [initOpened] */ /*** * @typedef {Object} TTDAdapter * @property {TTData} data */ var loadCss = () => { var dynamicCss = new DynamicCSS/* default */.Z(); dynamicCss.setRules(Array(20).fill(null).reduce((ac, cr, i) => { ac[`.as-tree-table-row[data-level="${i}"] .as-tree-table-toggle::before`] = { width: 2 * i + 'em' } ac[['.as-tree-table.as-hide-col-' + i + ' td[data-col-idx="' + i + '"]', '.as-tree-table.as-hide-col-' + i + ' th[data-col-idx="' + i + '"]'].join(',')] = { display: 'none' } ac[`.as-tree-table-row[data-level="${i}"] .as-tree-table-cell.as-has-toggle`] = { 'padding-left': `calc(5px + ${2 * i + 1.5}em)` } ac[`.as-printer-content .as-tree-table-row[data-level="${i}"] .as-tree-table-cell.as-has-toggle`] = { 'padding-left': `calc(5px + ${2 * i}em)` } return ac; }, {})).commit(); loadCss = noop/* default */.Z; } /*** * @extends AElement * @constructor */ function TreeTable() { loadCss(); this._hiddenColumns = []; this.$head = (0,ACore.$)('thead', this); this.$body = (0,ACore.$)('tbody', this); this.savedState = {}; /** * * @type {null|TTTable} */ this.table = null; /*** * * @type {null|TTDataAdapter} */ this.mAdapter = null; this.queryCtrl = new treetable_TTQueryController(this); this.rowMoveTool = new TTRowMoveTool(this); /*** * @name adapter * @type TTDAdapter * @memberOf TreeTable# */ /*** * @name searchInput * @type SearchTextInput * @memberOf TreeTable# */ } TreeTable.tag = 'TreeTable'.toLowerCase(); TreeTable.render = function () { return (0,ACore._)({ extendEvent: ['orderchange'], tag: 'table', class: 'as-tree-table', child: [ { tag: 'thead', class: 'as-tree-table-head' }, { tag: 'tbody' } ] }); }; TreeTable.prototype.removeRow = function (rowData) { if (!this.table) return; var row = this.table.body.rowOf(rowData); if (row) row.remove(); }; TreeTable.prototype.replaceRow = function (rowData, oldRowData) { if (!this.table) return; var row = this.table.body.rowOf(oldRowData); if (row) row.replace(rowData); }; TreeTable.prototype.getRows = function () { return this.table.body.rows.slice(); }; /*** * * @param rowData * @param {any|null} parentRow */ TreeTable.prototype.addRowIn = function (rowData, parentRow) { if (!this.table) return; var row; if (parentRow) { row = this.table.body.rowOf(parentRow); if (row) row.addSubRow(rowData); else { console.error('Can not find row', parentRow) } } else { this.table.body.addRow(rowData); } }; TreeTable.prototype.addRow = function (rowData) { if (!this.table) return; this.table.body.addRow(rowData); }; TreeTable.prototype.addRows = function (rowDataArr) { if (!this.table) return; rowDataArr.forEach(rowData => { this.table.body.addRow(rowData); }); }; /*** * * @param rowData * @param {any|null} bfRow */ TreeTable.prototype.addRowBefore = function (rowData, bfRow) { if (!this.table) return; var row; if (bfRow) { row = this.table.body.rowOf(bfRow); if (row) row.addRowBefore(rowData); else { console.error('Can not find row', bfRow) } } else { this.table.body.addRow(rowData); } }; /*** * * @param rowData * @param {any|null} atRow */ TreeTable.prototype.addRowAfter = function (rowData, atRow) { if (!this.table) return; var row; if (atRow) { row = this.table.body.rowOf(atRow); if (row) row.addRowAfter(rowData); else { console.error('Can not find row', atRow) } } else { if (this.table.body.rows.length === 0) { this.table.body.addRow(rowData); } else { this.table.body.rows[0].addRowBefore(rowData); } } }; TreeTable.prototype.rowOf = function (rowData) { return this.table.body.rowOf(rowData); }; TreeTable.prototype.viewIntoRow = function (row) { var counter = 300; var wait = () => { counter--; if (this.isDescendantOf(document.body)) { row = this.rowOf(row); if (row) { (0,utils.vScrollIntoView)(row.elt); } } else if (counter > 0) { setTimeout(wait, 30); } } setTimeout(wait, 10); }; TreeTable.prototype.notifySizeChange = function () { var c = this.parentElement; while (c) { if (typeof c.updateSize === 'function') c.updateSize(); else if (typeof c.requestUpdateSize === 'function') c.requestUpdateSize(); c = c.parentElement; } }; TreeTable.prototype.attachSearchInput = function (input) { this.searchInput = input; }; TreeTable.property = {}; TreeTable.property.adapter = { set: function (adapter) { if (adapter.type === 'struct') { adapter = ttStructAdapter2TTDAdapter(adapter); } this._adapterData = adapter; if (adapter && adapter.data) { adapter.data.initOpened = adapter.data.initOpened || adapter.initOpened;//adapt param } this.mAdapter = new treetable_TTDataAdapter(this, adapter); this.mAdapter.render(); this.queryCtrl.transferSearchItems(); var c = this.parentElement; while (c) { if (c.hasClass && c.hasClass('absol-table-vscroller') && c.update) { c.update(); break; } c = c.parentElement; } ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); var td = (0,ACore.$)('td', this); if (td) { var attachhook = (0,ACore._)('attachhook').once('attached', () => { attachhook.remove(); ResizeSystem/* default.requestUpdateSignal */.Z.requestUpdateSignal(); }).addTo(td); } }, get: function () { return this._adapterData; } }; TreeTable.property.filterInputs = { set: function (inputs) { }, get: function () { } }; TreeTable.property.searchInput = { set: function (input) { if (input) this.queryCtrl.attachSearchInput(input); else this.queryCtrl.detachSearchInput(); }, get: function () { return this.queryCtrl.$searchInput; } }; TreeTable.property.hiddenColumns = { set: function (value) { value = value || []; this._hiddenColumns.forEach(function (idxV) { this.removeClass('as-hide-col-' + idxV); }.bind(this)); this._hiddenColumns = value; this._hiddenColumns.forEach(function (idxV) { this.addClass('as-hide-col-' + idxV); }.bind(this)); var c = this.parentElement; while (c) { if (c.hasClass && (c.hasClass('absol-table-vscroller') || c.hasClass('absol-table-scroller')) && (c.update || c.updateContent)) { (c.update || c.updateContent).call(c); break; } c = c.parentElement; } if (this.isDescendantOf(document.body)) ResizeSystem/* default.update */.Z.update(); }, get: function () { return this._hiddenColumns; } }; ACore/* default.install */.Z.install(TreeTable); /* harmony default export */ const treetable_TreeTable = (TreeTable); /** * * @param {TreeTable} elt * @constructor */ function TTRowMoveTool(elt) { this.elt = elt; this.dragListenners = { dragstart: this.ev_dragStart.bind(this), drag: this.ev_drag.bind(this), dragend: this.ev_dragEnd.bind(this), dragdeinit: this.ev_dragDeinit.bind(this) }; this.$body = (0,ACore._)({ tag: Hanger/* default */.Z, elt: this.elt.$body, props: { hangOn: 3 } }).on('draginit', this.ev_dragInit.bind(this)); /** * * @type {null|TTRow} */ this.inParent = null; /** * * @type {null|TTRow} */ this.row = null; this.siblingRows = []; this.siblingBounds = []; } TTRowMoveTool.prototype._getZIndex = function () { var res = 0; var c = this.elt; while (c) { res = Math.max(res, parseInt(getComputedStyle(c).getPropertyValue('z-index'), 10) || 0); c = c.parentElement; } return res; }; TTRowMoveTool.prototype.ev_dragInit = function (event) { var row = this._findRow(event.target, true); if (!row) return; if (this.elt.table.body.clonedRows) return;// searching this.inParent = row.parentRow; this.row = row; this.$body.on(this.dragListenners); event.preventDefault(); }; TTRowMoveTool.prototype.ev_dragDeinit = function () { this.$body.off(this.dragListenners); }; TTRowMoveTool.prototype.ev_dragStart = function (event) { event.preventDefault(); var row = this.row; var originTableElt = this.elt.table.elt; var originBody = originTableElt.lastChild; var tableBound = originTableElt.getBoundingClientRect(); var zIndex = this._getZIndex(); this.$clonedTable = (0,ACore.$)(originTableElt.cloneNode(false)) .addClass('as-dt-body-row-cloned-ctn')//reuse class this.$clonedTable.addStyle({ tableLayout: 'fixed', width: tableBound.width + 'px', zIndex: zIndex + 200 }).addTo(document.body); this.$modal = this.$modal || (0,ACore._)({ tag: Modal/* default */.Z, style: { zIndex: zIndex + 201, userSelect: 'none' } }); this.$modal.addTo(document.body); this.$clonedBody = (0,ACore.$)(originBody.cloneNode()); this.$clonedTable.addChild(this.$clonedBody); var originRowElt = row.elt; this.$clonedRow = (0,ACore.$)(originRowElt.cloneNode(true)).addStyle({ backgroundColor: originRowElt.getComputedStyleValue('background-color') }); this.$clonedBody.addChild(this.$clonedRow); var rowBound = originRowElt.getBoundingClientRect(); this.$clonedTable.addStyle({ top: rowBound.top + 'px', left: rowBound.left + 'px' }); this.$newPostLine = this.$newPostLine || (0,ACore._)('.as-dt-insert-line'); this.$newPostLine.addStyle({ left: rowBound.left + 'px', width: rowBound.width + 'px' }); this.$newPostLine.addTo(document.body); this.rowBond = Rectangle/* default.fromClientRect */.Z.fromClientRect(rowBound); this.mouseOffset = event.currentPoint.sub(this.rowBond.A()); Array.prototype.forEach.call(this.$clonedRow.childNodes, (td, i) => { var originTd = originRowElt.childNodes[i]; var bound = originTd.getBoundingClientRect(); (0,ACore.$)(td).addStyle({ 'width': bound.width + 'px', boxSizing: 'border-box' }); }); this.siblingRows = this.inParent ? this.inParent.subRows.slice() : this.elt.table.body.rows.slice(); this.firstSiblingRow = this.inParent ? this.inParent.subRows[0] : this.elt.table.body.rows[0]; this.siblingBounds = (this.inParent ? this.inParent.subRows : this.elt.table.body.rows).map(row => this._boundOfRow(row)); this.idx = this.siblingRows.indexOf(this.row); this.newIdx = this.idx; this.$scroller = (0,utils.findVScrollContainer)(this.elt); if (this.$scroller === document.body.parentElement) this.$scroller = null; this.overflowCheckITV = setInterval(() => { if (!this.$scroller) return; var scrollerBound = this.$scroller.getBoundingClientRect(); var cloneBound = this.$clonedTable.getBoundingClientRect(); if (cloneBound.height >= scrollerBound.height) return; var newScrollTop = this.$scroller.scrollTop; if (cloneBound.top < scrollerBound.top) { newScrollTop = newScrollTop - Math.min(100, (scrollerBound.top - cloneBound.top) / 6); } else if (cloneBound.bottom > scrollerBound.bottom) { newScrollTop = newScrollTop - Math.min(100, (scrollerBound.bottom - cloneBound.bottom) / 6); newScrollTop = Math.min(this.$scroller.scrollHeight - this.$scroller.clientHeight, newScrollTop); } newScrollTop = Math.max(0, newScrollTop); if (newScrollTop !== this.$scroller.scrollTop) { this.$scroller.scrollTop = newScrollTop; } }, 33); }; TTRowMoveTool.prototype._boundOfRow = function (row) { var rowElements = row.getRowElements(); var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(rowElements[0].getBoundingClientRect()); if (rowElements.length > 1) { bound = bound.merge( Rectangle/* default.fromClientRect */.Z.fromClientRect(rowElements[rowElements.length - 1].getBoundingClientRect()) ); } return bound; }; TTRowMoveTool.prototype.ev_drag = function (event) { event.preventDefault(); var newPos = event.currentPoint.sub(this.mouseOffset); this.$clonedTable.addStyle('top', newPos.y + 'px'); var firstSiblingRowBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.firstSiblingRow.elt.getBoundingClientRect()); var viewDelta = firstSiblingRowBound.A().sub(this.siblingBounds[0].A()).y; var y = newPos.y + this.rowBond.height / 2 - viewDelta; var beforeIdx = this.siblingBounds.length; var rBound; for (var i = 0; i < this.siblingBounds.length; ++i) { rBound = this.siblingBounds[i]; if (rBound.centerPoint().y > y) { beforeIdx = i; break; } } if ((beforeIdx === this.idx + 1 || beforeIdx === this.idx)) { this.$newPostLine.addStyle('display', 'none'); this.newIdx = this.idx; } else { this.$newPostLine.removeStyle('display'); if (beforeIdx < this.siblingBounds.length) { this.$newPostLine.addStyle('top', this.siblingBounds[beforeIdx].y + viewDelta + 'px'); if (beforeIdx < this.idx) { this.newIdx = beforeIdx; } else { this.newIdx = beforeIdx - 1; } } else { this.newIdx = this.siblingBounds.length - 1; this.$newPostLine.addStyle('top', this.siblingBounds[this.siblingBounds.length - 1].C().y + viewDelta + 'px'); } } }; TTRowMoveTool.prototype.ev_dragEnd = function (event) { clearInterval(this.overflowCheckITV); this.$modal.remove(); this.$newPostLine.remove(); this.$clonedTable.remove(); if (this.newIdx !== this.idx) { if (this.inParent) { this.inParent.subRows.splice(this.idx, 1); this.inParent.subRows.splice(this.newIdx, 0, this.row); this.inParent.data.subRows.splice(this.idx, 1); this.inParent.data.subRows.splice(this.newIdx, 0, this.row.data); } else { this.elt.table.body.rows.splice(this.idx, 1); this.elt.table.body.rows.splice(this.newIdx, 0, this.row); this.elt.table.body.data.rows.splice(this.idx, 1); this.elt.table.body.data.rows.splice(this.newIdx, 0, this.row.data); } this.elt.table.body.renderRows(); this.elt.emit('orderchange', { type: 'orderchange', target: this.row, inParent: this.inParent || this.elt.table.body, inParentData: this.inParent ? this.inParent.data : this.elt.table.body.data, from: this.idx, to: this.newIdx, originalEvent: event, row: this.row, data: this.row.data, devMessage: this.inParent ? 'order change in array event.inParent.subRows' : 'order change in array event.inParent.rows' }); } }; TTRowMoveTool.prototype._findRow = function (elt, inDraZone) { var hitDragZone = false; while (elt) { if (elt.classList.contains('as-drag-zone')) hitDragZone = true; if (elt.ttRow) { if (hitDragZone || !inDraZone) return elt.ttRow; return null; } elt = elt.parentElement; } return null; }; /*** * * @param adapterData * @returns {TTDAdapter} */ function ttStructAdapter2TTDAdapter(adapterData) { var toString = { 'Date': x => x ? (0,datetime.formatDateTime)(x, 'dd/MM/yyyy') : '', 'DateTime': x => x ? (0,datetime.formatDateTime)(x, 'dd/MM/yyyy HH:mm') : '', text: x => (x || '') + '' }; var getItemDict = desc => { var dict = desc.__dict__; if (!dict) { Object.defineProperty(desc, '__dict__', { enumerable: false, writable: true, configurable: true, value: (desc.items || []).reduce(function makeDict(ac, cr) { var key = (0,utils.keyStringOf)(cr.value); ac[key] = cr; if (cr.items && cr.items.reduce) { cr.items.reduce(makeDict, ac); } return ac; }, {}) }); dict = desc.__dict__; } return dict; } var handlers = { 'Date': x => [{ tag: 'span', child: { text: x ? (0,datetime.formatDateTime)(x, 'dd/MM/yyyy') : '' } }], 'DateTime': x => [{ tag: 'span', child: { text: x ? (0,datetime.formatDateTime)(x, 'dd/MM/yyyy HH:mm') : '' } }], text: x => [{ tag: 'span', child: { text: (x || '') + '' } }], performance: (x, desc) => { return [{ tag: js_LinearColorTinyBar.tag, props: { colorMapping: desc.colorMapping || 'performance', value: x, extend: (typeof desc.extend === "number") && (desc.extend > 0) ? desc.extend : 0.5, valueText: typeof x === 'number' ? (x * 100).toFixed(2) + '%' : x + '' } }] }, enum: (x, desc) => { var dict = getItemDict(desc); var item = dict[(0,utils.keyStringOf)(x)]; if (item) return [{ tag: 'span', child: { text: item.text } }]; else return [{ tag: 'span', child: { text: '' } }]; }, '{enum}': (x, desc) => { var dict = getItemDict(desc); if (!(x instanceof Array)) return [{ tag: 'span', child: { text: '' } }]; var items = x.map(it => dict[(0,utils.keyStringOf)(it)]).filter(it => !!it); var text = items.map(it => it.text).join(', '); return [{ tag: 'span', child: { text: text } }]; } } /** * * @type {TTDAdapter} */ var res = { data: { initOpened: true, head: { rows: [ { cells: adapterData.propertyNames.map(name => { var cellData = { child: { text: name } }; var descriptor = adapterData.propertyDescriptors[name]; if (descriptor && descriptor.text) cellData.child.text = descriptor.text; return cellData; }) } ] }, body: { rows: adapterData.records.map(function visit(it) { var row = {}; row.cells = adapterData.propertyNames.map(name => { var descriptor = adapterData.propertyDescriptors[name]; var type = (descriptor && descriptor.type) || 'text' var value = it[name]; var f = toString[type] || toString.text; var text = f(value); var handler = handlers[type] || handlers.text; var cell = { innerText: text, attr: { 'data-type': type }, child: handler(value, descriptor) }; if (name === adapterData.treeBy) { cell.child.unshift('.as-tree-table-toggle'); } return cell; }); if (it.__children__) { row.subRows = it.__children__.map(visit); } return row; }) } } }; return res; } printer.ShareSerializer.addHandlerBefore({ id: 'TreeTableCellBorder', match: (elt, scope, stack) => { if (!elt.hasClass) return false; if (!elt.hasClass('as-tree-table-head-cell') && !elt.hasClass('as-tree-table-cell')) return false; var style = getComputedStyle(elt); var borderColor = style.getPropertyValue('border-color'); var borderStyle = style.getPropertyValue('border-style'); var borderWidth = style.getPropertyValue('border-width'); var borderRadius = style.getPropertyValue('border-radius'); if (borderStyle === 'none' || borderWidth === '0px') return false; scope.declare('borderStyle', { width: parseFloat(borderWidth.replace('px', '')), radius: (0,attribute.parseMeasureValue)(borderRadius), color: borderColor, }); return true; }, exec: (printer, elt, scope, stack, accept) => { var borderStyle = scope.get('borderStyle'); var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect()); var rect = bound.clone(); var strokeWidth = borderStyle.width; rect.x -= printer.O.x; rect.y -= printer.O.y; var radius = borderStyle.radius; var rounded; if (radius) { switch (radius.unit) { case '%': rounded = [radius.value * rect.width / 100, radius.value * rect.height / 100]; break; case 'px': rounded = radius.value; break; } } printer.rect(rect, { stroke: borderStyle.color, rounded: rounded, strokeWidth: strokeWidth }); return true; } }, 'Border'); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/finder/Finder.js + 2 modules var Finder = __webpack_require__(8556); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/treechart.css var treechart = __webpack_require__(255); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TreeChart.js function autoThemeVariable(viewElt) { var cp = getComputedStyle(document.body); var color = cp.getPropertyValue('--menu-background-color') || cp.getPropertyValue('--variant-color-primary') || 'blue'; color = Color.parse(color.trim()); var hsla = color.toHSLA(); hsla[2] = (hsla[2] + 1) / 2; hsla[1] = (hsla[1] + 0.2) / 2; var nColor = Color.fromHSLA(hsla[0], hsla[1], hsla[2], hsla[3]); viewElt.addStyle('--vert-node-background-color', nColor.toString('rgba')); nColor = nColor.getContrastYIQ(); viewElt.addStyle('--vert-node-text-color', nColor.toString('rgba')); hsla[0] += 0.1; if (hsla[0] > 1) hsla[0] -= 1; nColor = Color.fromHSLA(hsla[0], hsla[1], hsla[2], hsla[3]); viewElt.addStyle('--horz-node-background-color', nColor.toString('rgba')); nColor = nColor.getContrastYIQ(); viewElt.addStyle('--horz-node-text-color', nColor.toString('rgba')); hsla[0] -= 0.2; if (hsla[0] < 0) hsla[0] += 1; nColor = Color.fromHSLA(hsla[0], hsla[1], hsla[2], hsla[3]); viewElt.addStyle('--root-background-color', nColor.toString('rgba')); nColor = nColor.getContrastYIQ(); viewElt.addStyle('--root-text-color', nColor.toString('rgba')); } /*** * @extends AElement * @constructor */ function TreeChart() { // autoThemeVariable(this); this.$domSignal = (0,ACore._)('attachhook').addTo(this); this.domSignal = new DomSignal/* default */.ZP(this.$domSignal); this.domSignal.on('formatSize', this._formatSize.bind(this)); this.domSignal.on('fixWidth', this._fixWidth.bind(this)); this.$root = null; this._maxHorizonLevel = 2; /*** * @name data * @type {any} * @memberOf TreeChart# */ /*** * @name maxHorizonLevel * @type {number} * @memberOf TreeChart# */ } TreeChart.tag = 'TreeChart'; TreeChart.render = function () { return (0,ACore._)({ class: 'as-tree-chart' }); }; TreeChart.prototype._updateContent = function () { if (this.$root) { this.$root.remove(); this.$root = null; } var data = this.data; if (!data) return; var makeTree = (nodeData, level) => { var textChildren = []; if (nodeData.icon) { textChildren.push((0,ACore._)(nodeData.icon).addClass('as-tree-chart-icon')); } textChildren.push({ tag: 'span', class: 'as-tree-chart-text', child: { text: nodeData.text || nodeData.name } }); var elt = (0,ACore._)({ class: 'as-tree-chart-node', attr: { "data-level": level + '' }, child: [ { class: 'as-tree-chart-content-ctn', child: { class: 'as-tree-chart-content', child: textChildren } }, { class: 'as-tree-chart-child-ctn' } ] }); elt.$content = (0,ACore.$)('.as-tree-chart-content', elt); elt.$childCtn = (0,ACore.$)('.as-tree-chart-child-ctn', elt); var fillColor, textColor; if (typeof nodeData.fill === "string") { fillColor = Color_Color/* default.parse */.Z.parse(nodeData.fill); } else if (nodeData.fill instanceof Color_Color/* default */.Z) { fillColor = nodeData.fill; } if (fillColor) { textColor = fillColor.getContrastYIQ(); elt.$content.addStyle({ color: textColor.toString('hex8'), backgroundColor: fillColor.toString('hex8'), }); } if (level === this.maxHorizonLevel) elt.addClass('as-horizontal'); if (nodeData.isLeaf) elt.addClass('as-is-leaf'); if (nodeData.items && nodeData.items.length > 0) { elt.addClass('as-has-children'); /*** * @type {AElement[]} */ elt.$children = nodeData.items.map((it) => makeTree(it, level + 1)); elt.$childCtn.addChild(elt.$children); } return elt; }; this.$root = makeTree(data, 0).addTo(this); this.domSignal.emit('formatSize'); }; TreeChart.prototype._formatSize = function () { if (!this.$root) return; var cBound = this.getBoundingClientRect(); var maxHorizonLevel = this.maxHorizonLevel; var visit = (elt, level) => { if (!elt.$children) return; var sArr, maxS; if (level < maxHorizonLevel) { sArr = elt.$children.map(e => e.$content.getBoundingClientRect().height); maxS = Math.max.apply(Math, sArr); elt.$children.forEach((elt, i) => { if (sArr[i] < maxS) { elt.$content.addStyle('height', maxS + 'px'); } }); } else { sArr = elt.$children.map(e => e.$content.getBoundingClientRect().width); maxS = Math.max.apply(Math, sArr); elt.$children.forEach((elt, i) => { if (sArr[i] < maxS) { elt.$content.addStyle('width', maxS + 'px'); } }); } elt.$children.forEach(c => visit(c, level + 1)); }; visit(this.$root, 0); var newBound = this.getBoundingClientRect(); if (cBound.width !== newBound.width || cBound.height !== newBound.height) { ResizeSystem/* default.update */.Z.update(); } this.domSignal.emit('fixWidth'); }; TreeChart.prototype._fixWidth = function () { if (!this.$root) return; var cBound = this.getBoundingClientRect(); var maxHorizonLevel = this.maxHorizonLevel; var visit = (elt) => { if (!elt.$children) return; elt.$children.forEach(c => visit(c)); var bound, cBound; bound = elt.$childCtn.getBoundingClientRect(); cBound = elt.$childCtn.getBoundingRecursiveRect(100); if (cBound.width > bound.width) { elt.$childCtn.addStyle('width', cBound.width + 'px'); } }; visit(this.$root); var newBound = this.getBoundingClientRect(); if (cBound.width !== newBound.width || cBound.height !== newBound.height) { ResizeSystem/* default.update */.Z.update(); } }; TreeChart.property = {}; TreeChart.property.data = { set: function (data) { data = (0,generator/* copyJSVariable */.Ew)(data || null); this._data = data; this._updateContent(); }, get: function () { return this._data; } }; TreeChart.property.maxHorizonLevel = { set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 2;//default this._maxHorizonLevel = value; this._updateContent(); }, get: function () { return this._maxHorizonLevel; } } ACore/* default.install */.Z.install(TreeChart); /* harmony default export */ const js_TreeChart = (TreeChart); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Clipboard.js var Clipboard = __webpack_require__(5164); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/MultiLanguageText.js /*** * @extends AElement * @constructor */ function MultiLanguageText() { this._v = Array(5).fill(null); this._key = null; this.$text = document.createTextNode(''); this.addChild(this.$text); } MultiLanguageText.tag = 'mlt'; MultiLanguageText.render = function () { return (0,ACore._)('span'); }; MultiLanguageText.prototype._updateText = function () { var text = ''; if (this._key && window.LanguageModule && window.LanguageModule.text2) { text = window.LanguageModule.text2(this._key, this._v); } text = text.replace(/<br>/g, '\n'); this.$text.data = text; }; MultiLanguageText.attribute = Array(5).fill(0).reduce((ac, u, i) => { ac['v' + i] = { set: function (value) { this._v[i] = value; this._updateText(); }, get: function () { return this._v[i]; }, remove: function () { this._v[i] = null; } } return ac; }, {}); MultiLanguageText.attribute.key = { set: function (value) { this._key = value; this._updateText(); }, get: function () { return this._key; }, remove: function () { this._key = null; } }; MultiLanguageText.replaceAll = function (root) { (0,ACore.$$)('mlt', root).forEach(elt=>{ if (elt.tagName !== 'MLT') return; var attr = Array.prototype.reduce.call(elt.attributes,(ac, at)=>{ ac[at.name] = at.value; return ac; },{}); elt.selfReplace((0,ACore._)({ tag: MultiLanguageText, attr: attr })); }); }; /* harmony default export */ const js_MultiLanguageText = (MultiLanguageText); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CopyableIconTooltip.js /*** * @extends {AElement} * @constructor */ function CopyableIconTooltip() { this._content = ''; this.$content = null; this._value = ''; this._icon = 'span.mdi.mdi-information-outline'; this.$icon = (0,ACore.$)('.as-cit-icon', this); this.tooltip = new TooltipController(this); } CopyableIconTooltip.tag = 'CopyableIconTooltip'.toLowerCase(); CopyableIconTooltip.render = function () { return (0,ACore._)({ tag: 'button', class: 'as-copyable-icon-tooltip', child: 'span.mdi.mdi-information-outline.as-cit-icon' }); }; CopyableIconTooltip.property = {}; CopyableIconTooltip.property.content = { set: function (value) { this._content = value || ''; if (typeof this._content === "object") { this.$content = (0,ACore._)(this._content); } else if (typeof this._content === "string") { this.$content = (0,ACore._)({ tag: 'span', style:{'white-space':'pre-wrap'}, props:{ innerHTML: this._content } }); js_MultiLanguageText.replaceAll(this.$content); } }, get: function () { return this._content; } }; CopyableIconTooltip.property.icon = { set: function (value) { value = value || ''; this._icon = value; this.clearChild(); this.$icon = null; if (value) { if ((0,Dom/* isDomNode */.mV)(value)) { if (value.parentElement) value = value.cloneNode(true); } else value = (0,ACore._)(value); this.$icon = (0,ACore.$)(value).addClass('as-cit-icon'); this.addChild(this.$icon); } }, get: function () { return this._icon; } }; CopyableIconTooltip.property.value = { set: function (value) { this._value = value; }, get: function () { return this._value; } }; /*** * * @param {CopyableIconTooltip} elt * @constructor */ function TooltipController(elt) { /*** * * @type {CopyableIconTooltip} */ this.elt = elt; this.elt.on('mouseenter', this.ev_mouseEnter.bind(this)); this.elt.on('mouseleave', this.ev_mouseLeave.bind(this)); this.elt.on('click', this.ev_click.bind(this)); this.session = -2; this.timeout = -1; } TooltipController.prototype.ev_mouseEnter = function () { clearTimeout(this.timeout); if (this.elt.$content) this.session = Tooltip/* default.show */.Z.show(this.elt, this.elt.$content, 'auto'); }; TooltipController.prototype.ev_mouseLeave = function () { this.timeout = setTimeout(() => { Tooltip/* default.close */.Z.close(this.session); }, 500) }; TooltipController.prototype.ev_click = function () { var text; if (this.elt._value !== null && this.elt._value !== undefined) { text = this.elt._value + ''; } else if (typeof this.elt._content === "string") { text = this.elt._content; } else { text = this.elt.$content.innerText; } (0,Clipboard.copyText)(text); Snackbar.show('Copied: ' + text); }; /* harmony default export */ const js_CopyableIconTooltip = (CopyableIconTooltip); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/DateNLevelInput.js /** * @extends {AElement} * @constructor */ function DateNLevelInput() { this.$level = (0,ACore.$)('.as-date-n-level-input-select-level', this); /** * * @type {DateInput} */ this.$date = (0,ACore.$)('dateinput', this); this.ctrl = new DateNLevelInputCtrl(this); this._allowLevels = this.defaultAllowLevels.slice(); (0,OOP/* drillProperty */.pj)(this, this.$date, 'min'); (0,OOP/* drillProperty */.pj)(this, this.$date, 'max'); /** * @name level * @type {"date"| "week" | "month" | "quarter" | "year"} * @memberOf DateNLevelInput# * */ /** * @name allowLevels * @type {Array<"date"| "week" | "month" | "quarter" | "year">} * @memberOf DateNLevelInput# * */ /** * @name value * @type {Date} * @memberOf DateNLevelInput# * */ /** * @readonly * @name format * @type {string} * @memberOf DateNLevelInput# * */ } DateNLevelInput.tag = 'DateNLevelInput'.toLowerCase(); DateNLevelInput.prototype.leve2format = { date: 'dd/MM/yyyy', week: 'Tuần ww, yyyy', month: 'MM/yyyy', quarter: 'Quý QQ, yyyy', year: 'yyyy' }; DateNLevelInput.prototype.leve2Name = { date: 'Ngày', week: 'Tuần', month: 'Tháng', quarter: 'Quý', year: 'Năm' } DateNLevelInput.prototype.defaultAllowLevels = ['date', 'month', 'year']; DateNLevelInput.render = function () { return (0,ACore._)({ class: 'as-date-n-level-input', extendEvent: ['change'], child: [ { tag: 'dateinput', props: { format: 'dd/MM/yyyy' } }, { tag: 'button', class: ['as-transparent-button', 'as-date-n-level-input-select-level'], child: 'span.mdi.mdi-cog' } ] }); }; DateNLevelInput.property = {}; DateNLevelInput.property.allowLevels = { set: function (value) { if (typeof value === "string") { value = value.split(/\s*,\s*/); } if (!(value instanceof Array)) { value = this.defaultAllowLevels.slice(); } value = value.filter(x => !!this.leve2format[x]); if (!value || value.length === 0) value = this.defaultAllowLevels.slice(); var prevLevel = this.level; this._allowLevels = value; var newLevel = this.level; if (prevLevel !== newLevel) { this.level = newLevel;//update } }, get: function () { return this._allowLevels.slice(); } }; DateNLevelInput.property.level = { set: function (value) { if (!this.leve2format[value]) value = 'date'; this.attr('data-level', value); this.$date.format = this.leve2format[value]; this.ctrl.prevVal = this.$date.value; this.ctrl.level = value; }, get: function () { var level = this.ctrl.level; if (this._allowLevels.indexOf(level) < 0) level = this._allowLevels[0]; return level; } }; DateNLevelInput.property.format = { get: function () { return this.$date.format; } }; DateNLevelInput.property.value = { set: function (value) { this.$date.value = value; this.ctrl.prevVal = this.$date.value; }, get: function () { return this.$date.value; } }; DateNLevelInput.property.readOnly = { set: function (value) { this.$date.readOnly = value; if (value) { this.addClass('as-read-only'); } else { this.removeClass('as-read-only'); } }, get: function () { return this.$date.readOnly; } }; DateNLevelInput.property.disabled = { set: function (value) { this.$date.disabled = value; this.$level.disabled = value; if (value) { this.addClass('as-disabled'); } else { this.removeClass('as-disabled'); } }, get: function () { return this.$date.disabled; } }; function DateNLevelInputCtrl(elt) { this.elt = elt; this.prevVal = this.elt.value; this.elt.$date.on('change', this.ev_dateChange.bind(this)); this.level = 'date'; QuickMenu/* default.toggleWhenClick */.Z.toggleWhenClick(this.elt.$level, { getMenuProps: () => { var props = {}; props.items = this.elt._allowLevels.map(name => { return { text: `${this.elt.leve2Name[name]} (${this.elt.leve2format[name]})`, level: name, icon: name === this.level ? 'span.mdi.mdi-check' : null } }); return props; }, onSelect: item => { if (this.level !== item.level) { this.level = item.level; this.ev_levelChange(); } } }) } DateNLevelInputCtrl.prototype.ev_dateChange = function (event) { this.notifyCanBeChanged(); }; DateNLevelInputCtrl.prototype.ev_levelChange = function (event) { var value = this.level; this.elt.attr('data-level', value); this.elt.$date.format = this.elt.leve2format[value]; this.elt.$date.value = null; this.notifyCanBeChanged(); }; DateNLevelInputCtrl.prototype.notifyCanBeChanged = function (force) { var value = this.elt.$date.value; if (force || !value !== !this.prevVal || (value && (0,datetime.compareDate)(value, this.prevVal) !== 0)) { this.elt.emit('change', Object.assign({}, { value: value, prevValue: this.prevVal, target: this.elt }), this.elt); this.prevVal = value; } }; /* harmony default export */ const js_DateNLevelInput = (DateNLevelInput); ACore/* default.install */.Z.install(DateNLevelInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/tableoftextinput.css var tableoftextinput = __webpack_require__(978); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/swatchestable.css var swatchestable = __webpack_require__(4132); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/red_cross.tpl /* harmony default export */ const red_cross = ("<svg width=\"$width\" height=\"$height\" version=\"1.1\" viewBox=\"0 0 $width $height\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <g fill=\"none\" stroke=\"#f00\">\r\n <path d=\"m0 0 $width $height\"/>\r\n <path d=\"m$width 0-$width $heightz\" stroke-width=\"1px\"/>\r\n </g>\r\n</svg>\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/SwatchesTable.js /** * @extends AElement * @constructor */ function ColorCell() { this.$value = this.firstChild; if (!ColorCell.css) { ColorCell.css = new DynamicCSS/* default */.Z() .setProperty('.as-color-cell.as-null .as-color-cell-value', 'background-image', `url("data:image/svg+xml;base64,${(0,base64.base64EncodeUnicode)(red_cross.replace(/\$width/g, '24').replace(/\$height/g, '24'))}")`) .commit(); } } ColorCell.tag = 'ColorCell'.toString(); ColorCell.render = function () { return (0,ACore._)({ class: 'as-color-cell', child: [ '.as-color-cell-value' ] }); }; ColorCell.property = {}; ColorCell.property.value = { set: function (value) { if (value === null || value === undefined) { this.addClass('as-null'); } else if (value) { this.removeClass('as-null'); this.$value.addStyle('background-color', value + ''); } this._value = value; }, get: function () { return this._value; } }; function SwatchesTable() { this._data = []; this._poolCells = []; this._poolRows = []; this._dict = {}; } SwatchesTable.tag = 'SwatchesTable'.toLowerCase(); SwatchesTable.render = function () { return (0,ACore._)({ extendEvent: 'presscell', class: 'as-swatches-table' }); }; SwatchesTable.prototype.getCell = function () { if (arguments.length === 1) { var key = arguments[0]; if (key.toHex8) { key = key.toHex8(); } else if (typeof key == 'string') { key = Color_Color/* default.parse */.Z.parse(key); if (key) key = key.toHex8(); } key = key + ''; return this._dict[key]; } else if (arguments.length === 2) { return this.childNodes[arguments[0]] && this.childNodes[arguments[0]].childNodes[arguments[1]]; } }; SwatchesTable.eventHandler = {}; SwatchesTable.eventHandler.clickCell = function (cell, event) { this.emit('presscell', { target: this, cellElt: cell, value: cell.__swatchescell_value, rowIdx: cell.__swatchescell_row_idx, colIdx: cell.__swatchescell_col_idx }); } SwatchesTable.property = {}; SwatchesTable.property.data = { set: function (value) { this._dict = {}; value = value || [[null]]; if (typeof value == 'string') { value = { classic: MoqupsClassicSwathes, material: MaterialSwatches, bootstrap: BootstrapSwatches, ios: iOsSwatches, moqupsclassic: MoqupsClassicSwathes }[value] || [[null]]; } this._data = value; var child; while (this.childNodes.length > value.length) { child = this.firstChild; this._poolRows.push(child); this.removeChild(child); } while (this.childNodes.length < value.length) { if (this._poolRows.length > 0) child = this._poolRows.pop(); else child = (0,ACore._)('.as-swatches-table-row'); this.addChild(child); } var rowElt; var row; for (var i = 0; i < value.length; ++i) { rowElt = this.childNodes[i]; row = value[i]; while (rowElt.childNodes.length > row.length) { child = rowElt.firstChild; this._poolCells.push(child); rowElt.removeChild(child); } while (rowElt.childNodes.length < row.length) { if (this._poolCells.length > 0) child = this._poolCells.pop(); else { child = (0,ACore._)({ tag: ColorCell, class:'as-swatches-table-cell' }); child.on('click', this.eventHandler.clickCell.bind(this, child)); } rowElt.addChild(child); } for (var j = 0; j < row.length; ++j) { rowElt.childNodes[j].__swatchescell_row_idx = i; rowElt.childNodes[j].__swatchescell_col_idx = j; if (!row[j]) { rowElt.childNodes[j] .attr('title', null) // rowElt.childNodes[j].firstChild.removeStyle('background-color'); rowElt.childNodes[j].__swatchescell_value = row[j]; this._dict['null'] = rowElt.childNodes[j]; } else if (row[j].toHex8) { rowElt.childNodes[j].value = row[j]; rowElt.childNodes[j].attr('title', null); rowElt.childNodes[j].__swatchescell_value = row[j]; this._dict[row[j].toHex8()] = rowElt.childNodes[j]; } else if (typeof row[j] == 'object') { if (row[j].value) { rowElt.childNodes[j].value = row[j].value; // rowElt.childNodes[j].firstChild.addStyle('background-color', row[j].value); rowElt.childNodes[j].__swatchescell_value = row[j].value; this._dict[Color_Color/* default.parse */.Z.parse(row[j].value + '').toHex8()] = rowElt.childNodes[j]; } else { rowElt.childNodes[j].firstChild.removeStyle('background-color'); this._dict[Color_Color/* default.parse */.Z.parse('transparent').toHex8()] = rowElt.childNodes[j]; } rowElt.childNodes[j].attr('title', row[j].name || null) } else if (typeof row[j] == 'string') { rowElt.childNodes[j].value = row[j]; rowElt.childNodes[j].attr('title', null); rowElt.childNodes[j].__swatchescell_value = row[j]; this._dict[Color_Color/* default.parse */.Z.parse(row[j]).toHex8()] = rowElt.childNodes[j]; } } } }, get: function () { return this._data; } }; var MoqupsClassicSwathes = [ [ { "name": "White", "value": "#ffffff" }, { "name": "± Wild Sand", "value": "#f7f6f6" }, { "name": "± Gallery", "value": "#ebebeb" }, { "name": "± Alto", "value": "#d6d6d6" }, { "name": "Silver", "value": "#c0c0c0" }, { "name": "± Silver Chalice", "value": "#aaaaaa" }, { "name": "± Gray", "value": "#929292" }, { "name": "Boulder", "value": "#7a7a7a" }, { "name": "± Scorpion", "value": "#606060" }, { "name": "± Tundora", "value": "#444444" }, { "name": "± Mine Shaft", "value": "#232323" }, { "name": "Black", "value": "#000000" } ], [ { "name": "± Prussian Blue", "value": "#003748" }, { "name": "± Green Vogue", "value": "#021f54" }, { "name": "± Black Rock", "value": "#120639" }, { "name": "± Violet", "value": "#2f073b" }, { "name": "± Bulgarian Rose", "value": "#3d051b" }, { "name": "± Lonestar", "value": "#5e0202" }, { "name": "± Brown Bramble", "value": "#5b1a04" }, { "name": "± Cioccolato", "value": "#58330a" }, { "name": "± Bronze Olive", "value": "#553d0d" }, { "name": "± Himalaya", "value": "#656119" }, { "name": "± West Coast", "value": "#4e5516" }, { "name": "± Seaweed", "value": "#243e16" } ], [ { "name": "± Astronaut Blue", "value": "#004e63" }, { "name": "± Catalina Blue", "value": "#033076" }, { "name": "± Violet", "value": "#1c0c4f" }, { "name": "± Jagger", "value": "#460e56" }, { "name": "± Maroon Oak", "value": "#570e28" }, { "name": "± Dark Burgundy", "value": "#840705" }, { "name": "± Kenyan Copper", "value": "#7d2709" }, { "name": "± Raw Umber", "value": "#7b4812" }, { "name": "± Raw Umber", "value": "#785616" }, { "name": "± Wasabi", "value": "#8c8525" }, { "name": "± Fern Frond", "value": "#6e7623" }, { "name": "± Woodland", "value": "#355723" } ], [ { "name": "± Blue Lagoon", "value": "#006e8c" }, { "name": "± Cobalt", "value": "#0844a4" }, { "name": "± Persian Indigo", "value": "#2e1572" }, { "name": "± Honey Flower", "value": "#631878" }, { "name": "± Claret", "value": "#7a163c" }, { "name": "± Milano Red", "value": "#b70f0a" }, { "name": "± Rust", "value": "#af3a11" }, { "name": "± Desert", "value": "#aa671d" }, { "name": "± Reef Gold", "value": "#a77a23" }, { "name": "± Earls Green", "value": "#c3bb38" }, { "name": "± Sushi", "value": "#99a534" }, { "name": "± Fern Green", "value": "#4c7a34" } ], [ { "name": "± Bondi Blue", "value": "#008db1" }, { "name": "± Denim", "value": "#0c59cf" }, { "name": "± Daisy Bush", "value": "#3b1d8f" }, { "name": "± Seance", "value": "#7e2199" }, { "name": "± Disco", "value": "#9c1f4d" }, { "name": "± Crimson", "value": "#e61610" }, { "name": "± Orange Roughy", "value": "#dc4c18" }, { "name": "± Brandy Punch", "value": "#d68227" }, { "name": "± Hokey Pokey", "value": "#d39c2f" }, { "name": "± Starship", "value": "#f4eb49" }, { "name": "± Turmeric", "value": "#c1d045" }, { "name": "± Apple", "value": "#629c44" } ], [ { "name": "± Cerulean", "value": "#00a4d3" }, { "name": "± Blue Ribbon", "value": "#1464f6" }, { "name": "± Daisy Bush", "value": "#5125ad" }, { "name": "± Purple Heart", "value": "#9c29b7" }, { "name": "± Maroon Flush", "value": "#bb285c" }, { "name": "± Red Orange", "value": "#ff3823" }, { "name": "± Orange", "value": "#ff6624" }, { "name": "± Sunshade", "value": "#ffa834" }, { "name": "± Bright Sun", "value": "#fec63d" }, { "name": "± Laser Lemon", "value": "#fefb64" }, { "name": "± Confetti", "value": "#d7eb5a" }, { "name": "± Mantis", "value": "#72bb53" } ], [ { "name": "± Bright Turquoise", "value": "#00c8f8" }, { "name": "± Dodger Blue", "value": "#3d8af7" }, { "name": "± Purple Heart", "value": "#6334e3" }, { "name": "± Electric Violet", "value": "#c238eb" }, { "name": "± Cerise Red", "value": "#e93578" }, { "name": "± Persimmon", "value": "#ff5d55" }, { "name": "± Coral", "value": "#ff8351" }, { "name": "± Texas Rose", "value": "#ffb253" }, { "name": "± Golden Tainoi", "value": "#ffc957" }, { "name": "± Dolly", "value": "#fef67f" }, { "name": "± Manz", "value": "#e2ee79" }, { "name": "± Feijoa", "value": "#92d36e" } ], [ { "name": "± Malibu", "value": "#4dd7fa" }, { "name": "± Malibu", "value": "#75a9f9" }, { "name": "± Cornflower Blue", "value": "#8b51f5" }, { "name": "± Heliotrope", "value": "#d757f6" }, { "name": "± Froly", "value": "#f06e9c" }, { "name": "± Vivid Tangerine", "value": "#ff8a84" }, { "name": "± Hit Pink", "value": "#ffa382" }, { "name": "± Macaroni and Cheese", "value": "#ffc581" }, { "name": "± Grandis", "value": "#ffd783" }, { "name": "± Picasso", "value": "#fef8a0" }, { "name": "± Khaki", "value": "#e9f29b" }, { "name": "± Feijoa", "value": "#aedd94" } ], [ { "name": "± Anakiwa", "value": "#91e4fb" }, { "name": "± Sail", "value": "#a8c6fa" }, { "name": "± Perfume", "value": "#b38df7" }, { "name": "± Heliotrope", "value": "#e692f8" }, { "name": "± Illusion", "value": "#f6a2bf" }, { "name": "± Sundown", "value": "#ffb4b0" }, { "name": "± Wax Flower", "value": "#ffc3ae" }, { "name": "± Caramel", "value": "#ffd8ad" }, { "name": "± Navajo White", "value": "#ffe3ae" }, { "name": "± Pale Prim", "value": "#fefac0" }, { "name": "± Corn Field", "value": "#f1f6be" }, { "name": "± Tea Green", "value": "#cbe8ba" } ], [ { "name": "± French Pass", "value": "#c9f1fd" }, { "name": "± Hawkes Blue", "value": "#d4e3fc" }, { "name": "± Perfume", "value": "#dacafb" }, { "name": "± Perfume", "value": "#f2c9fb" }, { "name": "± Chantilly", "value": "#fad2e0" }, { "name": "± Cosmos", "value": "#ffdad8" }, { "name": "± Peach Schnapps", "value": "#ffe2d8" }, { "name": "± Derby", "value": "#ffecd7" }, { "name": "± Pink Lady", "value": "#fff1d7" }, { "name": "± Off Yellow", "value": "#fefce0" }, { "name": "± Citrine White", "value": "#f7fade" }, { "name": "± Zanah", "value": "#dfedd6" } ] ]; var MaterialSwatches = [ [ { "name": "Red 50", "value": "#ffebee" }, { "name": "Red 100", "value": "#ffcdd2" }, { "name": "Red 200", "value": "#ef9a9a" }, { "name": "Red 300", "value": "#e57373" }, { "name": "Red 400", "value": "#ef5350" }, { "name": "Red 500", "value": "#f44336" }, { "name": "Red 600", "value": "#e53935" }, { "name": "Red 700", "value": "#d32f2f" }, { "name": "Red 800", "value": "#c62828" }, { "name": "Red 900", "value": "#b71c1c" } ], [ { "name": "Pink 50", "value": "#fce4ec" }, { "name": "Pink 100", "value": "#f8bbd0" }, { "name": "Pink 200", "value": "#f48fb1" }, { "name": "Pink 300", "value": "#f06292" }, { "name": "Pink 400", "value": "#ec407a" }, { "name": "Pink 500", "value": "#e91e63" }, { "name": "Pink 600", "value": "#d81b60" }, { "name": "Pink 700", "value": "#c2185b" }, { "name": "Pink 800", "value": "#ad1457" }, { "name": "Pink 900", "value": "#880e4f" } ], [ { "name": "Purple 50", "value": "#f3e5f5" }, { "name": "Purple 100", "value": "#e1bee7" }, { "name": "Purple 200", "value": "#ce93d8" }, { "name": "Purple 300", "value": "#ba68c8" }, { "name": "Purple 400", "value": "#ab47bc" }, { "name": "Purple 500", "value": "#9c27b0" }, { "name": "Purple 600", "value": "#8e24aa" }, { "name": "Purple 700", "value": "#7b1fa2" }, { "name": "Purple 800", "value": "#6a1b9a" }, { "name": "Purple 900", "value": "#4a148c" } ], [ { "name": "Deep Purple 50", "value": "#ede7f6" }, { "name": "Deep Purple 100", "value": "#d1c4e9" }, { "name": "Deep Purple 200", "value": "#b39ddb" }, { "name": "Deep Purple 300", "value": "#9575cd" }, { "name": "Deep Purple 400", "value": "#7e57c2" }, { "name": "Deep Purple 500", "value": "#673ab7" }, { "name": "Deep Purple 600", "value": "#5e35b1" }, { "name": "Deep Purple 700", "value": "#512da8" }, { "name": "Deep Purple 800", "value": "#4527a0" }, { "name": "Deep Purple 900", "value": "#311b92" } ], [ { "name": "Indigo 50", "value": "#e8eaf6" }, { "name": "Indigo 100", "value": "#c5cae9" }, { "name": "Indigo 200", "value": "#9fa8da" }, { "name": "Indigo 300", "value": "#7986cb" }, { "name": "Indigo 400", "value": "#5c6bc0" }, { "name": "Indigo 500", "value": "#3f51b5" }, { "name": "Indigo 600", "value": "#3949ab" }, { "name": "Indigo 700", "value": "#303f9f" }, { "name": "Indigo 800", "value": "#283593" }, { "name": "Indigo 900", "value": "#1a237e" } ], [ { "name": "Blue 50", "value": "#e3f2fd" }, { "name": "Blue 100", "value": "#bbdefb" }, { "name": "Blue 200", "value": "#90caf9" }, { "name": "Blue 300", "value": "#64b5f6" }, { "name": "Blue 400", "value": "#42a5f5" }, { "name": "Blue 500", "value": "#2196f3" }, { "name": "Blue 600", "value": "#1e88e5" }, { "name": "Blue 700", "value": "#1976d2" }, { "name": "Blue 800", "value": "#1565c0" }, { "name": "Blue 900", "value": "#0d47a1" } ], [ { "name": "Light Blue 50", "value": "#e1f5fe" }, { "name": "Light Blue 100", "value": "#b3e5fc" }, { "name": "Light Blue 200", "value": "#81d4fa" }, { "name": "Light Blue 300", "value": "#4fc3f7" }, { "name": "Light Blue 400", "value": "#29b6f6" }, { "name": "Light Blue 500", "value": "#03a9f4" }, { "name": "Light Blue 600", "value": "#039be5" }, { "name": "Light Blue 700", "value": "#0288d1" }, { "name": "Light Blue 800", "value": "#0277bd" }, { "name": "Light Blue 900", "value": "#01579b" } ], [ { "name": "Cyan 50", "value": "#e0f7fa" }, { "name": "Cyan 100", "value": "#b2ebf2" }, { "name": "Cyan 200", "value": "#80deea" }, { "name": "Cyan 300", "value": "#4dd0e1" }, { "name": "Cyan 400", "value": "#26c6da" }, { "name": "Cyan 500", "value": "#00bcd4" }, { "name": "Cyan 600", "value": "#00acc1" }, { "name": "Cyan 700", "value": "#0097a7" }, { "name": "Cyan 800", "value": "#00838f" }, { "name": "Cyan 900", "value": "#006064" } ], [ { "name": "Teal 50", "value": "#e0f2f1" }, { "name": "Teal 100", "value": "#b2dfdb" }, { "name": "Teal 200", "value": "#80cbc4" }, { "name": "Teal 300", "value": "#4db6ac" }, { "name": "Teal 400", "value": "#26a69a" }, { "name": "Teal 500", "value": "#009688" }, { "name": "Teal 600", "value": "#00897b" }, { "name": "Teal 700", "value": "#00796b" }, { "name": "Teal 800", "value": "#00695c" }, { "name": "Teal 900", "value": "#004d40" } ], [ { "name": "Green 50", "value": "#e8f5e9" }, { "name": "Green 100", "value": "#c8e6c9" }, { "name": "Green 200", "value": "#a5d6a7" }, { "name": "Green 300", "value": "#81c784" }, { "name": "Green 400", "value": "#66bb6a" }, { "name": "Green 500", "value": "#4caf50" }, { "name": "Green 600", "value": "#43a047" }, { "name": "Green 700", "value": "#388e3c" }, { "name": "Green 800", "value": "#2e7d32" }, { "name": "Green 900", "value": "#1b5e20" } ], [ { "name": "Light Green 50", "value": "#f1f8e9" }, { "name": "Light Green 100", "value": "#dcedc8" }, { "name": "Light Green 200", "value": "#c5e1a5" }, { "name": "Light Green 300", "value": "#aed581" }, { "name": "Light Green 400", "value": "#9ccc65" }, { "name": "Light Green 500", "value": "#8bc34a" }, { "name": "Light Green 600", "value": "#7cb342" }, { "name": "Light Green 700", "value": "#689f38" }, { "name": "Light Green 800", "value": "#558b2f" }, { "name": "Light Green 900", "value": "#33691e" } ], [ { "name": "Lime 50", "value": "#f9fbe7" }, { "name": "Lime 100", "value": "#f0f4c3" }, { "name": "Lime 200", "value": "#e6ee9c" }, { "name": "Lime 300", "value": "#dce775" }, { "name": "Lime 400", "value": "#d4e157" }, { "name": "Lime 500", "value": "#cddc39" }, { "name": "Lime 600", "value": "#c0ca33" }, { "name": "Lime 700", "value": "#afb42b" }, { "name": "Lime 800", "value": "#9e9d24" }, { "name": "Lime 900", "value": "#827717" } ], [ { "name": "Yellow 50", "value": "#fffde7" }, { "name": "Yellow 100", "value": "#fff9c4" }, { "name": "Yellow 200", "value": "#fff59d" }, { "name": "Yellow 300", "value": "#fff176" }, { "name": "Yellow 400", "value": "#ffee58" }, { "name": "Yellow 500", "value": "#ffeb3b" }, { "name": "Yellow 600", "value": "#fdd835" }, { "name": "Yellow 700", "value": "#fbc02d" }, { "name": "Yellow 800", "value": "#f9a825" }, { "name": "Yellow 900", "value": "#f57f17" } ], [ { "name": "Amber 50", "value": "#fff8e1" }, { "name": "Amber 100", "value": "#ffecb3" }, { "name": "Amber 200", "value": "#ffe082" }, { "name": "Amber 300", "value": "#ffd54f" }, { "name": "Amber 400", "value": "#ffca28" }, { "name": "Amber 500", "value": "#ffc107" }, { "name": "Amber 600", "value": "#ffb300" }, { "name": "Amber 700", "value": "#ffa000" }, { "name": "Amber 800", "value": "#ff8f00" }, { "name": "Amber 900", "value": "#ff6f00" } ], [ { "name": "Orange 50", "value": "#fff3e0" }, { "name": "Orange 100", "value": "#ffe0b2" }, { "name": "Orange 200", "value": "#ffcc80" }, { "name": "Orange 300", "value": "#ffb74d" }, { "name": "Orange 400", "value": "#ffa726" }, { "name": "Orange 500", "value": "#ff9800" }, { "name": "Orange 600", "value": "#fb8c00" }, { "name": "Orange 700", "value": "#f57c00" }, { "name": "Orange 800", "value": "#ef6c00" }, { "name": "Orange 900", "value": "#e65100" } ], [ { "name": "Deep Orange 50", "value": "#fbe9e7" }, { "name": "Deep Orange 100", "value": "#ffccbc" }, { "name": "Deep Orange 200", "value": "#ffab91" }, { "name": "Deep Orange 300", "value": "#ff8a65" }, { "name": "Deep Orange 400", "value": "#ff7043" }, { "name": "Deep Orange 500", "value": "#ff5722" }, { "name": "Deep Orange 600", "value": "#f4511e" }, { "name": "Deep Orange 700", "value": "#e64a19" }, { "name": "Deep Orange 800", "value": "#d84315" }, { "name": "Deep Orange 900", "value": "#bf360c" } ], [ { "name": "Brown 50", "value": "#efebe9" }, { "name": "Brown 100", "value": "#d7ccc8" }, { "name": "Brown 200", "value": "#bcaaa4" }, { "name": "Brown 300", "value": "#a1887f" }, { "name": "Brown 400", "value": "#8d6e63" }, { "name": "Brown 500", "value": "#795548" }, { "name": "Brown 600", "value": "#6d4c41" }, { "name": "Brown 700", "value": "#5d4037" }, { "name": "Brown 800", "value": "#4e342e" }, { "name": "Brown 900", "value": "#3e2723" } ], [ { "name": "Grey 50", "value": "#fafafa" }, { "name": "Grey 100", "value": "#f5f5f5" }, { "name": "Grey 200", "value": "#eeeeee" }, { "name": "Grey 300", "value": "#e0e0e0" }, { "name": "Grey 400", "value": "#bdbdbd" }, { "name": "Grey 500", "value": "#9e9e9e" }, { "name": "Grey 600", "value": "#757575" }, { "name": "Grey 700", "value": "#616161" }, { "name": "Grey 800", "value": "#424242" }, { "name": "Grey 900", "value": "#212121" } ], [ { "name": "Blue Grey 50", "value": "#eceff1" }, { "name": "Blue Grey 100", "value": "#cfd8dc" }, { "name": "Blue Grey 200", "value": "#b0bec5" }, { "name": "Blue Grey 300", "value": "#90a4ae" }, { "name": "Blue Grey 400", "value": "#78909c" }, { "name": "Blue Grey 500", "value": "#607d8b" }, { "name": "Blue Grey 600", "value": "#546e7a" }, { "name": "Blue Grey 700", "value": "#455a64" }, { "name": "Blue Grey 800", "value": "#37474f" }, { "name": "Blue Grey 900", "value": "#263238" } ], [ { "name": "White", "value": "#ffffff" }, { "name": "Black", "value": "#000000" } ] ]; var BootstrapSwatches = [ [ { "name": "Gray Light", "value": "#777777" }, { "name": "Base", "value": "#000000" }, { "name": "Highlight Blue", "value": "#0055cc" }, { "name": "Dark Blue", "value": "#005580" }, { "name": "Success Text Green", "value": "#468847" }, { "name": "Orange", "value": "#f89406" }, { "name": "Red", "value": "#9d261d" }, { "name": "Purple", "value": "#7a43b6" } ], [ { "name": "Border Gray", "value": "#cccccc" }, { "name": "Gray Darker", "value": "#222222" }, { "name": "Primary Blue", "value": "#337ab7" }, { "name": "Info Blue", "value": "#2f96b4" }, { "name": "Green", "value": "#46a546" }, { "name": "Light Orange", "value": "#fbb450" }, { "name": "Danger Button Red", "value": "#bd362f" }, { "name": "Pink", "value": "#c3325f" } ], [ { "name": "Gray Lighter", "value": "#eeeeee" }, { "name": "Gray Dark", "value": "#333333" }, { "name": "Link Blue", "value": "#0088cc" }, { "name": "Info Light Blue", "value": "#5bc0de" }, { "name": "Success Button Green", "value": "#62c462" }, { "name": "Yellow", "value": "#ffc40d" }, { "name": "Error Text Red", "value": "#b94a48" }, { "name": "Danger Highlight Red", "value": "#ee5f5b" } ], [ { "name": "White", "value": "#ffffff" }, { "name": "Gray", "value": "#555555" }, { "name": "Accent Blue", "value": "#049cdb" }, { "name": "Info Lighter Blue", "value": "#d9edf7" }, { "name": "Success Background Green", "value": "#dff0d8" }, { "name": "Warning Background Brown", "value": "#f3edd2" }, { "name": "Warning Text Brown", "value": "#c09853" }, { "name": "Danger Background Red", "value": "#f2dede" } ] ]; var iOsSwatches = [ [ { "name": "Red", "value": "#ff3b30" }, { "name": "Orange", "value": "#ff9500" }, { "name": "Yellow", "value": "#ffcc00" }, { "name": "Green", "value": "#4cd964" }, { "name": "Teal Blue", "value": "#5ac8fa" }, { "name": "Blue", "value": "#007aff" }, { "name": "Purple", "value": "#5856d6" }, { "name": "Pink", "value": "#ff2d55" } ], [ { "name": "White", "value": "#ffffff" }, { "name": "Custom Gray", "value": "#efeff4" }, { "name": "Light Gray", "value": "#e5e5ea" }, { "name": "Light Gray 2", "value": "#d1d1d6" }, { "name": "Mid Gray", "value": "#c7c7cc" }, { "name": "Gray", "value": "#8e8e93" }, { "name": "Black", "value": "#000000" } ] ]; ACore/* default.install */.Z.install('swatchestable', SwatchesTable); /* harmony default export */ const colorpicker_SwatchesTable = ((/* unused pure expression or super */ null && (SwatchesTable))); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/solidcolorpicker.css var solidcolorpicker = __webpack_require__(4558); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/spectrumcolor.css var spectrumcolor = __webpack_require__(7702); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/SpectrumColor.js function SpectrumColor() { } SpectrumColor.tag = 'SpectrumColor'.toLowerCase(); SpectrumColor.render = function () { return (0,ACore._)({ class:'as-spectrum-color', child: { class:'as-spectrum-color-sat', child:'.as-spectrum-color-val' } }); }; ACore/* default.install */.Z.install('spectrumcolor', SpectrumColor); /* harmony default export */ const colorpicker_SpectrumColor = (SpectrumColor); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/SolidColorPicker.js /** * @extends AElement * @constructor */ function SolidColorPicker() { if (!SolidColorPicker.css) { SolidColorPicker.css = new DynamicCSS/* default */.Z() .setProperty('.as-color-cell.as-solid-color-picker-selected.as-null .as-color-cell-value', 'background-image', `url("data:image/svg+xml;base64,${(0,base64.base64EncodeUnicode)(red_cross.replace(/\$width/g, '58').replace(/\$height/g, '22'))}")`) .commit(); } this.swatchMode = new SCPSWatchMode(this); this.pickerMode = new SCPPickerMode(this); this.modes = [this.swatchMode, this.pickerMode]; this.modeCtrl = new SCPSWatchModeController(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this.modeCtrl, 'mode'); this.footerCtrl = new SCPFooterController(this); this.$opacity = this.footerCtrl.$opacity; this.$hex = this.footerCtrl.$hex; this.$selected = this.footerCtrl.$selected; this.historyCtrl = new SCPHistoryController(this); this.$swatchesName = this.modeCtrl.$swatchesName; this.on('keydown', this.eventHandler.keydown); this._lastEmitHex8 = ''; this.rawValue = new Color_Color/* default */.Z([1, 0, 0, 1]); this._swatchesNames = ['Material Design', 'Moqups Classic', 'Bootstrap', 'iOS']; this._swatchesShortName = ['material', 'moqups', 'bootstrap', 'ios']; this._swatchesIcons = ['span.mdi.mdi-palette', 'span.mdi.mdi-material-design', 'span.mdi.mdi-bootstrap', 'span.mdi.mdi-apple-ios']; this._swatchesData = [MaterialSwatches, MoqupsClassicSwathes, BootstrapSwatches, iOsSwatches]; /** * @type {import('absol-acomp/js/BScroller').default} */ this.$swatchesTableCtn = this.swatchMode.$swatchesTableCtn; this.$selectedDot = (0,ACore._)('.as-solid-color-picker-selected-dot');//share /** * @type {import('./SwatchesTable').default} */ this.$swatchesTable = this.swatchMode.$swatchesTable; this.$recentSwatchesTable = this.historyCtrl.$recentSwatchesTable; this.$attachhook = (0,ACore._)('attachhook') .on('attached', this.eventHandler.attached).addTo(this); this.$spectrum = this.pickerMode.$spectrum; this.$spectrumDot = this.pickerMode.$spectrumDot; this.$alpha = this.pickerMode.$alpha; this.$submitBtn = (0,ACore.$)('.as-solid-color-picker-submit-btn', this) .on('click', this.notifySubmit.bind(this)); /** * @name hasOpacity * @type {boolean} * @memberof SolidColorPicker# */ /** * @name nullable * @type {boolean} * @memberof SolidColorPicker# */ /** * @name value * @type {Color|null} * @memberof SolidColorPicker# */ /** * @name hex8Value * @type {string} * @memberof SolidColorPicker# */ } SolidColorPicker.tag = 'SolidColorPicker'.toLowerCase(); SolidColorPicker.render = function () { return (0,ACore._)({ attr: { tabindex: '1' }, extendEvent: ['change', 'sizechange', 'submit'], class: ['as-solid-color-picker', 'as-has-opacity'], child: [ { class: 'as-solid-color-picker-header', child: [ { class: 'as-solid-color-picker-mode-ctn', child: { tag: 'buttonarray', class: 'as-solid-color-picker-mode', props: { items: [ { text: 'SWATCHES', value: 'swatches' }, { text: 'PICKER', value: 'picker' }, ] } } }, ] }, { class: 'as-solid-color-picker-body', child: [ { class: ['as-solid-color-picker-swatches-select-ctn'], child: [ { tag: 'span', child: { text: 'Color Scheme: ' } }, { class: 'as-solid-color-picker-swatches-name', tag: 'a', child: { text: 'Material Design' } }, 'span.mdi.mdi-menu-down' ] }, { tag: 'bscroller', class: ['as-solid-color-picker-swatches-ctn'], child: { tag: 'swatchestable', props: { data: MaterialSwatches } } }, { tag: colorpicker_SpectrumColor, class: 'as-solid-color-picker-spectrum', child: '.as-solid-color-picker-spectrum-dot' }, { class: 'as-solid-color-picker-hue', child: '.as-solid-color-picker-hue-dot' }, { class: 'as-solid-color-picker-alpha', child: [ '.as-solid-color-picker-alpha-color', '.as-solid-color-picker-alpha-dot', ] }, { tag: 'swatchestable', class: 'as-solid-color-picker-near' }, { class: 'as-solid-color-picker-none-ctn', child: [ { tag: ColorCell, class: 'as-solid-color-picker-none-cell', props: { value: null } }, { child: { text: 'None' } } ] }, { class: 'as-solid-color-picker-recent-title', child: { text: 'RECENT COLOR' } }, { class: ['as-solid-color-picker-recent-swatches-ctn'], child: { tag: 'swatchestable', props: { data: MoqupsClassicSwathes.slice(0, 2) } } } ] }, { class: 'as-solid-color-picker-footer', child: [ { tag: ColorCell, class: 'as-solid-color-picker-selected' }, { tag: 'flexiconinput', class: 'as-solid-color-picker-color-hex', props: { value: 'ffffff', icon: '<svg viewBox="0 0 64 64" id="mq-icon-hex"><path d="M60 24v-6H46V4h-6v14H24V4h-6v14H4v6h14v16H4v6h14v14h6V46h16v14h6V46h14v-6H46V24h14zM40 40H24V24h16v16z"></path></svg>' } }, { tag: 'flexiconinput', class: 'as-solid-color-picker-color-opacity', props: { icon: 'span.mdi.mdi-opacity', unit: '%', value: 100 } }, { tag: 'flexiconbutton', class: 'as-solid-color-picker-submit-btn', props: { icon: 'span.mdi.mdi-check-bold' } } ] } ] }); }; SolidColorPicker._settingKey = "absol_solid_color_setting"; //only Hex6 SolidColorPicker.setting = { recentColors: ['#ffffff', '#00ffff', '#0000ff', '#ffffff', '#000000'] }; SolidColorPicker._loadSetting = function () { var setting = localStorage.getItem(SolidColorPicker._settingKey); try { setting = JSON.parse(setting); } catch (e) { setting = {}; } if (setting) { Object.assign(SolidColorPicker.setting, setting); } }; SolidColorPicker._loadSetting(); SolidColorPicker._writeSetting = function () { localStorage.setItem(SolidColorPicker._settingKey, JSON.stringify(SolidColorPicker.setting)); SolidColorPicker.updateInstancesSetting(); }; SolidColorPicker.pushInstances = function (elt) { var instances = SolidColorPicker.$instances; var aliveInstance = []; var instance; var found = false; while (instances.length > 0) { instance = instances.pop(); if (instance.isDescendantOf(document.body)) { aliveInstance.push(instance); } if (instance === elt) found = true; } while (aliveInstance.length > 0) { instances.push(aliveInstance.pop()); } if (!found) { instances.push(elt); } }; SolidColorPicker.updateInstancesSetting = function () { var instances = SolidColorPicker.$instances; var aliveInstance = []; var instance; while (instances.length > 0) { instance = instances.pop(); if (instance.isDescendantOf(document.body)) { aliveInstance.push(instance); } } while (aliveInstance.length > 0) { instance = aliveInstance.pop(); instances.push(instance); instance.reloadSetting(); } }; SolidColorPicker.$instances = []; SolidColorPicker.css = null; /** * @param {Color} color */ SolidColorPicker.pushColorHistory = function (color) { if (!color) return; var hex6Color = color.toString('hex6'); var recentColors = SolidColorPicker.setting.recentColors; var index = recentColors.indexOf(hex6Color); if (index >= 0) { recentColors.splice(index, 1); } recentColors.unshift(hex6Color); while (recentColors.length > 24) recentColors.pop(); setTimeout(SolidColorPicker._writeSetting.bind(SolidColorPicker), 1) }; SolidColorPicker.prototype.reloadSetting = function () { var recentColors = SolidColorPicker.setting.recentColors.slice(); var swatches = []; while (recentColors.length > 0) { swatches.push(recentColors.splice(0, 12)); } this.$recentSwatchesTable.data = swatches; this.swatchMode.viewValue(); }; SolidColorPicker.prototype.notifyCanBeChanged = function () { var cHex8 = this.hex8Value; if (cHex8 !== this._lastEmitHex8) { this._lastEmitHex8 = cHex8; this.notifyChange(); } }; SolidColorPicker.prototype.notifyChange = function () { this.emit('change', { target: this, value: this.value, type: 'change' }, this); }; SolidColorPicker.prototype.notifySizeCanBeChanged = function () { var bound = this.getBoundingClientRect(); if (!this._lastSize || this._lastSize.width !== bound.width || this._lastSize.height !== bound.height) { this._lastSize = { width: bound.width, height: bound.height }; this.notifySizeChange(); } }; SolidColorPicker.prototype.notifySizeChange = function () { this.emit('sizechange', { target: this, size: this._lastSize, type: 'sizechange' }, this); }; SolidColorPicker.prototype.notifySubmit = function () { SolidColorPicker.pushColorHistory(this.rawValue); this.emit('submit', { target: this, value: this.rawValue, type: 'submit' }, this); }; SolidColorPicker.property = {}; /** * @type {SolidColorPicker} */ SolidColorPicker.property.value = { /** * * @param {Color} value */ set: function (value) { value = value || null; if (value && !value.toHex8) {//is try { value = Color_Color/* default.parse */.Z.parse(value + ''); } catch (e) { value = new Color_Color/* default */.Z([0, 0, 0, 0]); } } this.rawValue = value; this._lastEmitHex8 = this.hex8Value; this.footerCtrl.viewValue(); this.pickerMode.viewValue(); this.swatchMode.viewValue(); }, get: function () { var nullable = this.nullable; var hasOpacity = this.hasOpacity; var value = this.rawValue || null;// if (!nullable && !value) value = new Color_Color/* default */.Z([0, 0, 0, 0]); if (!hasOpacity && value) value.rgba[3] = 1; return value; } }; SolidColorPicker.property.hex8Value = { get: function () { var value = this.value; if (value) return value.toHex8(); return 'null'; } }; /** * @type {SolidColorPicker} */ SolidColorPicker.property.swatches = { set: function (value) { var index = this._swatchesShortName.indexOf(value); index = Math.max(index, 0); value = this._swatchesShortName[index]; if (this._swatches != value) { this._swatches = value; this.$swatchesTable.data = this._swatchesData[index]; this.$swatchesName.childNodes[0].data = this._swatchesNames[index]; } this.swatchMode.viewValue(); }, get: function () { return this._swatches; } }; SolidColorPicker.property.nullable = { set: function (value) { if (value) { this.addClass('as-nullable'); } else { this.removeClass('as-nullable'); } this.footerCtrl.viewValue(); this.pickerMode.viewValue(); this.swatchMode.viewValue(); }, get: function () { return this.hasClass('as-nullable'); } }; SolidColorPicker.property.hasOpacity = { /** * @this SolidColorPicker# * @param value */ set: function (value) { if (value) { this.addClass('as-has-opacity'); } else { this.removeClass('as-has-opacity'); } this.footerCtrl.viewValue(); this.swatchMode.viewValue(); this.pickerMode.viewValue(); }, get: function () { return this.hasClass('as-has-opacity'); } }; /** * @type {SolidColorPicker} */ SolidColorPicker.eventHandler = {}; SolidColorPicker.eventHandler.attached = function () { SolidColorPicker.pushInstances(this); this.reloadSetting(); }; SolidColorPicker.eventHandler.keydown = function (event) { if (event.key === 'Enter') { event.preventDefault(); event.target.blur(); this.notifySubmit(); } }; ACore/* default.install */.Z.install('solidcolorpicker', SolidColorPicker); /** * * @param {SolidColorPicker} elt * * @constructor */ function SCPHistoryController(elt) { this.elt = elt; this.$recentSwatchesTable = (0,ACore.$)('.as-solid-color-picker-recent-swatches-ctn swatchestable', this.elt) .on('presscell', this.elt.swatchMode.ev_pressCell.bind(this)); } /** * * @param {SolidColorPicker} elt * @constructor */ function SCPSWatchModeController(elt) { this.elt = elt; this.$swatchesName = (0,ACore.$)('.as-solid-color-picker-swatches-name', this.elt); QuickMenu/* default.toggleWhenClick */.Z.toggleWhenClick(this.$swatchesName, { anchor: [1, 6], getMenuProps: () => { return { extendClasses: 'as-solid-color-picker-swatches-name-menu', extendStyle: { 'font-size': this.elt.getComputedStyleValue('font-size') }, items: this.elt._swatchesNames.map((name, i) => { return { text: name, value: this.elt._swatchesShortName[i], icon: this.elt._swatchesIcons[i] }; }) } }, onSelect: (item) => { this.elt.swatches = item.value; } }); this.$mode = (0,ACore.$)('.as-solid-color-picker-mode', this.elt) .on('change', this.updateMode.bind(this)); this.viewingMode = null; this.updateMode(); } SCPSWatchModeController.prototype.updateMode = function () { var value = this.$mode.value; if (value === this.viewingMode) return; this.elt.removeClass('as-solid-color-picker-mode-' + this.viewingMode); this.viewingMode = value + ''; this.elt.addClass('as-solid-color-picker-mode-' + this.viewingMode); this.$mode.value = this.viewingMode; this.elt.notifySizeCanBeChanged(); }; Object.defineProperty(SCPSWatchModeController.prototype, 'mode', { set: function (value) { this.$mode.value = value; this.updateMode(); }, get: function () { return this.$mode.value; } }); /** * * @param {SolidColorPicker} elt * @constructor */ function SCPSWatchMode(elt) { this.elt = elt; /** * * @type {BScroller} */ this.$swatchesTableCtn = (0,ACore.$)('.as-solid-color-picker-swatches-ctn', this.elt); /** * @type {SwatchesTable} */ this.$swatchesTable = (0,ACore.$)('.as-solid-color-picker-swatches-ctn swatchestable', this.elt) .on('presscell', this.ev_pressCell.bind(this)); this.$noneCtn = (0,ACore.$)('.as-solid-color-picker-none-ctn', this.elt).on('click', this.ev_clickNone.bind(this)); } SCPPickerMode.prototype.name = "swatches"; SCPPickerMode.prototype.displayName = "SWATCHES"; SCPSWatchMode.prototype.ev_pressCell = function (event) { try { var value = Color_Color/* default.parse */.Z.parse(event.value + ''); var hC = value.getContrastYIQ(); hC.rgba[3] = 0.7; value.rgba[3] = this.elt.footerCtrl.opacity; this.elt.rawValue = value; this.elt.footerCtrl.viewValue(); this.elt.$selectedDot.addStyle('box-shadow', `inset 0px 0px 0.3em 0.125em ${hC.toString('rgba')}`); event.cellElt.addChild(this.elt.$selectedDot); this.$noneCtn.removeClass('as-selected'); this.elt.pickerMode.viewValue(); // } catch (e) { // this.$selectedDot.removeStyle('box-shadow'); // this.$hex.value = 'ffffff'; } this.elt.notifyCanBeChanged(); }; SCPSWatchMode.prototype.ev_clickNone = function (event) { this.elt.rawValue = null; this.viewValue(); this.elt.footerCtrl.viewValue(); this.elt.swatchMode.viewValue(); this.elt.pickerMode.viewValue(); this.elt.notifyCanBeChanged(); }; SCPSWatchMode.prototype.viewValue = function () { this.elt.$selectedDot.remove(); var cell, hC; /** * * @type {Color|null} */ var value = this.elt.value; if (!value) this.$noneCtn.addClass('as-selected'); else this.$noneCtn.removeClass('as-selected'); if (this.elt.modeCtrl.mode === 'swatches' && value) { cell = this.$swatchesTable.getCell(value.toString('hex6')); if (cell) this.$swatchesTableCtn.scrollInto(cell); } if (!cell && value) { cell = this.elt.$recentSwatchesTable.getCell(value.toString('hex6')); } if (cell) { hC = value.getContrastYIQ(); hC.rgba[3] = 0.7; this.elt.$selectedDot.addStyle('box-shadow', `inset 0px 0px 0.3em 0.125em ${hC.toString('rgba')}`); cell.addChild(this.elt.$selectedDot); } }; /** * * @param {SolidColorPicker} elt * @constructor */ function SCPPickerMode(elt) { this.elt = elt; this.$spectrum = (0,ACore._)({ tag: 'hanger', elt: (0,ACore.$)('.as-solid-color-picker-spectrum', this.elt) }) .on('predrag', this.ev_spectrumDrag.bind(this)) .on('drag', this.ev_spectrumDrag.bind(this)); this.$hueDot = (0,ACore.$)('.as-solid-color-picker-hue-dot', this.elt); this.$spectrumDot = (0,ACore.$)('.as-solid-color-picker-spectrum-dot', this.elt); this.$alpha = (0,ACore._)({ tag: 'hanger', elt: (0,ACore.$)('.as-solid-color-picker-alpha', this.elt) }) .on('predrag', this.ev_alphaDrag.bind(this)) .on('drag', this.ev_alphaDrag.bind(this)); this.$alphaDot = (0,ACore.$)('.as-solid-color-picker-alpha-dot', this.elt); this.$hue = (0,ACore._)({ tag: 'hanger', elt: (0,ACore.$)('.as-solid-color-picker-hue', this.elt) }) .on('predrag', this.ev_hueDrag.bind(this)) .on('drag', this.ev_hueDrag.bind(this)); this.$near = (0,ACore.$)('.as-solid-color-picker-near', this.elt) .on('presscell', this.ev_nearPressCell.bind(this)); this._hue = 0; this._sat = 1; this._brightness = 1; } SCPPickerMode.prototype.name = 'picker'; SCPPickerMode.prototype.displayName = 'PICKER'; SCPPickerMode.prototype.viewValue = function () { var value = this.elt.value || new Color_Color/* default */.Z([0, 0, 0, 1]); var hsba = Color_Color/* default.rgbaToHSBA */.Z.rgbaToHSBA(value.rgba); this._setHue(hsba[0] * 360); this._setSatBrightness(hsba[1] * 100, hsba[2] * 100); this._updateOpacity(); this._updateNear(); }; SCPPickerMode.prototype._updateSpectrumDot = function () { var value = this.elt.value || new Color_Color/* default */.Z([0, 0, 0, 1]); var dotColor = value.getContrastYIQ(); dotColor.rgba[3] = 0.7; this.$spectrumDot.addStyle({ bottom: 'calc(' + this._brightness + '% - 0.5em)', left: 'calc(' + this._sat + '% - 0.5em)', 'box-shadow': 'inset 0px 0px 0.3em 0.125em ' + dotColor.toString() }); }; SCPPickerMode.prototype._updateNear = function () { var value = this.elt.value || new Color_Color/* default */.Z([0, 0, 0, 1]); var hsba = Color_Color/* default.rgbaToHSBA */.Z.rgbaToHSBA(value.rgba); var sat = hsba[1]; var hue = hsba[0]; var brightness = hsba[2]; var whiterColors = Array(7).fill(null).map(function (u, i) { return Color_Color/* default.fromHSB */.Z.fromHSB(hue, sat * (7 - i) / 8, brightness); }); var darkerColors = Array(7).fill(null).map(function (u, i) { return Color_Color/* default.fromHSB */.Z.fromHSB(hue, sat, brightness * (7 - i) / 8); }); var hueNearColors = [-5, -3, -2, 1, 2, 3, 5].map(function (u) { var nHue = hue + u / 40; if (nHue > 1) nHue -= 1; else if (nHue < 0) nHue += 1; return Color_Color/* default.fromHSB */.Z.fromHSB(nHue, sat, brightness); }); this.$near.data = [whiterColors, darkerColors, hueNearColors]; }; SCPPickerMode.prototype._setHue = function (hue) { this._hue = hue; var spectrumColor = Color_Color/* default.fromHSB */.Z.fromHSB(hue / 360, 1, 1); var hueDotColor = spectrumColor.getContrastYIQ(); hueDotColor.rgba[3] = 0.7; this.$hueDot.addStyle({ 'box-shadow': 'inset 0px 0px 0.3em 0.125em ' + hueDotColor.toString(), left: 'calc(' + (hue / 3.6) + '% - 0.5em)' }) this.$spectrum.addStyle('background-color', spectrumColor.toString()); this._updateSpectrumDot(); }; SCPPickerMode.prototype._setSatBrightness = function (sat, brightness) { this._sat = sat; this._brightness = brightness; this._updateSpectrumDot(); }; SCPPickerMode.prototype._updateOpacity = function () { this.$alphaDot.addStyle('left', 'calc(' + (this.elt.footerCtrl.opacity * 100) + '% - 0.5em)'); }; SCPPickerMode.prototype.ev_spectrumDrag = function (event) { event.preventDefault(); var sBound = this.$spectrum.getBoundingClientRect(); var brightness = (sBound.bottom - event.clientY) * 100 / sBound.height; brightness = Math.max(0, Math.min(100, Math.round(brightness))); var sat = (event.clientX - sBound.left) * 100 / sBound.width; sat = Math.max(0, Math.min(100, Math.round(sat))); this.elt.rawValue = Color_Color/* default.fromHSBA */.Z.fromHSBA(this._hue / 360, sat / 100, brightness / 100, this.elt.footerCtrl.opacity); this._setSatBrightness(sat, brightness); this._updateNear(); this.elt.footerCtrl.viewValue(); this.elt.swatchMode.viewValue(); this.elt.notifyCanBeChanged(); }; SCPPickerMode.prototype.ev_alphaDrag = function (event) { event.preventDefault(); var aBound = this.$alpha.getBoundingClientRect(); var opacity = (event.clientX - aBound.left) * 100 / aBound.width; opacity = Math.max(0, Math.min(100, Math.round(opacity))); var color = this.elt.value || new Color_Color/* default */.Z([0, 0, 0, 0]); color.rgba[3] = opacity / 100; this.elt.rawValue = color; this.elt.footerCtrl.viewValue(); this._updateOpacity(); // this._setOpacityPercent(opacity); this.elt.notifyCanBeChanged(); }; SCPPickerMode.prototype.ev_hueDrag = function (event) { event.preventDefault(); var hBound = this.$hue.getBoundingClientRect(); var hue = (event.clientX - hBound.left) * 360 / hBound.width; hue = Math.max(0, Math.min(360, Math.round(hue))); this.elt.rawValue = Color_Color/* default.fromHSBA */.Z.fromHSBA(hue / 360, this._sat / 100, this._brightness / 100, this.elt.footerCtrl.opacity); this._setHue(hue); this.elt.footerCtrl.viewValue(); this.elt.swatchMode.viewValue(); this._updateNear(); this.elt.notifyCanBeChanged(); }; SCPPickerMode.prototype.ev_nearPressCell = function (event) { var value = event.value.clone(); value.rgba[3] = this.elt.footerCtrl.opacity; this.elt.rawValue = value; this.viewValue(); this.elt.footerCtrl.viewValue(); this.elt.pickerMode.viewValue(); }; /** * * @param {SolidColorPicker} elt * @constructor */ function SCPFooterController(elt) { this.elt = elt; this.$selected = (0,ACore.$)('.as-solid-color-picker-selected', this.elt); this.$opacity = (0,ACore.$)('.as-solid-color-picker-color-opacity', this.elt) .on('change', this.ev_opacityChange.bind(this)) .on('keyup', this.ev_opacityKeyUp.bind(this)); this.$hex = (0,ACore.$)('.as-solid-color-picker-color-hex', this.elt) .on('keyup', this.ev_hexKeyUp.bind(this)) .on('change', this.ev_hexChange.bind(this)); } SCPFooterController.prototype.ev_opacityChange = function (event) { var color = this.elt.value; var opacityTxt = color ? Math.round(color.rgba[3] * 100) : '100'; if (color && this.$opacity.value !== opacityTxt) { this.$opacity.value = opacityTxt; } }; SCPFooterController.prototype.ev_opacityKeyUp = function (event) { var opacity = parseFloat(this.$opacity.value); if (!isNaN(opacity)) { opacity = Math.round(Math.max(0, Math.min(opacity, 100))); var color = this.elt.value || new Color_Color/* default */.Z(0, 0, 0, 1); color.rgba[3] = opacity / 100; this.elt.rawValue = color; this.elt.pickerMode.viewValue(); this.$selected.value = color; this.elt.notifyCanBeChanged(); } }; SCPFooterController.prototype.ev_hexKeyUp = function (event) { // var prevValue = this.elt.value; var value; var nullable = this.elt.nullable; var hex = this.$hex.value.trim(); try { if (nullable && hex.length === 0) { value = null; } else { value = Color_Color/* default.parse */.Z.parse('#' + hex); } } catch (e) { // console.error(e); } if (!value && !nullable) return; if (value) value.rgba[3] = this.opacity; this.elt.rawValue = value; this.$selected.value = value; this.elt.pickerMode.viewValue(); this.elt.swatchMode.viewValue(); this.elt.notifyCanBeChanged(); }; SCPFooterController.prototype.ev_hexChange = function (event) { var value = this.elt.value; if (value) this.$hex.value = value.toHex6(); }; SCPFooterController.prototype.viewValue = function () { var value = this.elt.value; var hasOpacity = this.elt.hasOpacity; this.$selected.value = value; this.$hex.value = value ? (value.toHex6()) : ''; if (hasOpacity && value) { this.$opacity.value = Math.round(value.rgba[3] * 100) + ''; } else this.$opacity.value = '100'; }; Object.defineProperty(SCPFooterController.prototype, 'opacity', { get: function () { if (!this.elt.hasOpacity) return 1; var opFromText = parseFloat(this.$opacity.value) / 100; if ((0,utils.isRealNumber)(opFromText)) { opFromText = Math.max(0, Math.min(opFromText, 1)); return opFromText; } var value = this.elt.value; if (!value) return 1; return value.rgba[3]; } }); /* harmony default export */ const colorpicker_SolidColorPicker = (SolidColorPicker); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/FontColorButton.js /** * @extends AElement * @constructor */ function FontColorButton() { this.$value = (0,ACore.$)('.as-font-color-button-value', this); this.$primary = (0,ACore.$)('.as-ribbon-split-button-primary', this).on('click', () => { this.emit('submit', { type: 'submit', target: this }, this); }); this.$extend = (0,ACore.$)('.as-ribbon-split-button-extend', this); new FCBPickerController(this); /** * @type {string} * @name value * @memberof FontColorButton# */ } FontColorButton.tag = 'FontColorButton'.toLowerCase(); FontColorButton.render = function () { return (0,ACore._)({ extendEvent: ['submit', 'change'], attr: { 'tabindex': '0' }, class: ['as-ribbon-split-button'], child: { class: 'as-ribbon-split-button-content', child: [ { tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-primary', child: { tag: Icons/* FontColorIcon */.Tj, class: 'as-font-color-button-value', style: { width: '18px', height: '18px' } } }, { tag: 'button', attr: { 'tabindex': '-1' }, class: 'as-ribbon-split-button-extend', child: ['span.as-ribbon-split-button-text', 'span.mdi.mdi-chevron-down'] } ] } }); }; FontColorButton.property = {}; FontColorButton.property.value = { set: function (value) { this.$value.value = value; }, get: function () { return this.$value.value; } }; /* harmony default export */ const colorpicker_FontColorButton = (FontColorButton); /** * * @param {FontColorButton} elt * @constructor */ function FCBPickerController(elt) { this.elt = elt; this['ev_clickExtend'] = this['ev_clickExtend'].bind(this); this['ev_clickOut'] = this['ev_clickOut'].bind(this); this['ev_submit'] = this['ev_submit'].bind(this); this['ev_change'] = this['ev_change'].bind(this); this.elt.$extend.on('click', this.ev_clickExtend); } FCBPickerController.prototype.ev_clickExtend = function () { this.openPicker(); }; FCBPickerController.prototype.ev_clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.share.$picker, event)) return; this.closePicker(); }; FCBPickerController.prototype.ev_submit = function () { var prevValue = this.elt.value; this.elt.value = this.share.$picker.value; this.closePicker(); if (prevValue !== this.elt.value) { this.elt.emit('change', { type: 'change', target: this.elt }, this.elt); } this.elt.emit('submit', { type: 'submit', target: this.elt }, this.elt); }; FCBPickerController.prototype.ev_change = function () { var prevValue = this.elt.value; this.elt.value = this.share.$picker.value; if (prevValue !== this.elt.value) { this.elt.emit('change', { type: 'change', target: this.elt }, this.elt); } }; FCBPickerController.prototype.share = { $picker: null, $follower: null, holder: null }; FCBPickerController.prototype.prepare = function () { if (this.share.$follower) return; this.share.$picker = (0,ACore._)({ tag: colorpicker_SolidColorPicker, props: { hasOpacity: false } }); this.share.$follower = (0,ACore._)({ tag: Follower/* default */.Z, child: this.share.$picker, props: { anchor: [2, 1, 6, 5, 9, 11] } }); }; FCBPickerController.prototype.openPicker = function () { this.prepare(); if (this.share.holder) this.share.holder.closePicker(); this.share.holder = this; this.share.$follower.addStyle('visibility', 'hidden'); this.share.$follower.addTo(document.body); this.share.$follower.followTarget = this.elt.$extend; this.share.$follower.sponsorElement = this.elt.$extend; this.share.$follower.addStyle('z-index', (0,utils.findMaxZIndex)(this.elt.$extend) + 70); this.share.$follower.removeStyle('visibility'); this.elt.$extend.off('click', this.ev_clickExtend); this.share.$picker.on('submit', this.ev_submit); this.share.$picker.on('change', this.ev_change); this.share.$picker.value = this.elt.value; setTimeout(() => { document.addEventListener('click', this.ev_clickOut); }, 5); }; FCBPickerController.prototype.closePicker = function () { if (this.share.holder !== this) return; this.share.holder = null; document.removeEventListener('click', this.ev_clickOut); this.share.$picker.off('submit', this.ev_submit); this.share.$picker.off('change', this.ev_change); setTimeout(() => { this.elt.$extend.on('click', this.ev_clickExtend); }, 5) this.share.$follower.followTarget = null; this.share.$follower.remove(); }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/TableOfTextInput.js /** * @typedef TEIDataRow * @property {TEIDataCell[]} cells */ /** * @typedef TEIData * @property {TEIDataRow[]} rows */ /** * @typedef TEIDataCell * @property {{color?:string, fontSize?: number, fontWeight?: ("bool"|"normal")}} [style] * @property {string} value */ /** * @extends AElement * @constructor */ function TableOfTextInput() { /** * * @type {TEITable} */ this.teiTable = new TEITable(this); /** * @name data * @type {TEICell[]} */ OOP/* default.drillProperty */.ZP.drillProperty(this, this.teiTable, ['minCol', 'maxCol', 'data', 'excelRichTextRows']); } /** * * @param name * @param value * @returns {this} */ TableOfTextInput.prototype.addStyle = function (name, value) { if (name === 'display') { if ((typeof value === "string") && value.indexOf('inline')) { this.addClass('as-inline'); } else { this.removeClass('as-inline'); } return this; } else return AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); }; TableOfTextInput.tag = 'TableOfTextInput'.toLowerCase(); TableOfTextInput.render = function () { return (0,ACore._)({ class: 'as-table-of-text-input-wrapper', child: [ { class: 'as-table-of-text-input-content-ctn', child: { tag: 'table', extendEvent: ['change'], class: 'as-table-of-text-input', child: [ { tag: 'tbody', child: [] } ] } } ] }); }; /* harmony default export */ const js_TableOfTextInput = (TableOfTextInput); ACore/* default.install */.Z.install(TableOfTextInput); /** * * @param {TableOfTextInput} wrapper * @constructor */ function TEITable(wrapper) { this._minCol = 3; this._maxCol = 3; this._minRow = 1; this._maxRow = 9; this.wrapper = wrapper; this.elt = (0,ACore.$)('table', wrapper); this.$body = (0,ACore.$)('tbody', this.elt); /** * * @type {TEIRow[]} */ this.rows = []; this.formatTool = new TEIFormatTool(this); } TEITable.prototype.defaultData = { rows: [ { cells: [ { value: '' }, { value: '' }, { value: '' } ] } ] } TEITable.prototype.notifyChange = function (data) { this.elt.emit('change', Object.assign({ type: 'change', target: this }, data), this.elt); }; TEITable.prototype.calcCellPos = function () { var n = this.rows[0].cells.reduce((ac, cell) => ac + cell.colspan, 0); var m = this.rows.length; var heights = Array(n).fill(0); var row, i, j, k; var cell, colspan, rowspan, colIdx; for (i = 0; i < m; ++i) { row = this.rows[i]; colIdx = 0; for (j = 0; j < row.cells.length; ++j) { cell = row.cells[j]; while (heights[colIdx] > i) colIdx++; colspan = cell.colspan; rowspan = cell.rowspan; cell.td.attr('data-col-idx', colIdx); for (k = 0; k < colspan; ++k) { heights[colIdx] = i + rowspan; } } } }; Object.defineProperties(TEITable.prototype, { minCol: { /** * @this TableOfTextInput * @param value */ set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 1; value = Math.max(1, Math.floor(value)); this._minCol = value; }, get: function () { return this._minCol; } }, maxCol: { /** * @this TableOfTextInput * @param value */ set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 20; value = Math.min(20, Math.max(1, Math.floor(value))); this._maxCol = value; }, get: function () { return Math.max(this._minCol, this._maxCol); } }, minRow: { /** * @this TableOfTextInput * @param value */ set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 1; value = Math.max(1, Math.floor(value)); this._minRow = value; }, get: function () { return this._minRow; } }, maxRow: { /** * @this TableOfTextInput * @param value */ set: function (value) { if (!(0,utils.isNaturalNumber)(value)) value = 20; value = Math.min(20, Math.max(1, Math.floor(value))); this._maxRow = value; }, get: function () { return Math.max(this._minRow, this._maxRow); } }, data: { set: function (value) { if (typeof value === "string") { value = { rows: [ { cells: [{ value: value }] } ] }; } value = (0,generator/* copyJSVariable */.Ew)(value || this.defaultData); if (!(value.rows instanceof Array)) value.rows = (0,generator/* copyJSVariable */.Ew)(this.defaultData.rows); value.rows.forEach(row => { if (!(row.cells instanceof Array)) { row.cells = [] } if (row.cells.length === 0) { row.cells.push({ value: '' }); } }); this.rows.forEach(row => row.tr.remove()); this.rows = value.rows.map(rowData => new TEIRow(this, rowData)); this.$body.addChild(this.rows.map(row => row.tr)); this.calcCellPos(); }, get: function () { return { rows: this.rows.map(row => row.data) } } }, excelRichTextRows: { get: function () { var cBound = this.elt.getBoundingClientRect(); var placeHolderElt; var renderSpace; if (!cBound.width || !cBound.height) { if (this.parentElement) { placeHolderElt = (0,ACore._)({ style: { display: 'none' } }); this.selfReplace(placeHolderElt); } renderSpace = (0,ACore._)({ style: { position: 'fixed', zIndex: -1000, visibility: 'hidden', opacity: 0 } }).addTo(document.body); } var textNodes = (0,Text.getTextNodesIn)(this.elt).filter(t => !!t.data); var lineHeight = 25.662879943847656; cBound = this.elt.getBoundingClientRect(); var y0 = cBound.top + 4 + 3.2348480224609375; var textInfos = textNodes.reduce((ac, txt) => { var cell = cellOf(txt); var style = cell.style.export(); var bounds = (0,utils.getTextNodeBounds)(txt); bounds.forEach(bound => { var excelData = { text: bound.text.replace(/\n+$/, ''), }; if (excelData.text.trim().length === 0) return; excelData.font = { 'name': 'Calibri' }; if (style.color) { excelData.font.color = { argb: 'ff' + Color_Color/* default.parse */.Z.parse(style.color).toString('hex6').substring(1).toLowerCase() }; } if (style.fontWeight === 'bold') { excelData.font.bold = true; } if (style.fontStyle === 'italic') { excelData.font.italic = true; } if (style.fontSize) { excelData.font.size = style.fontSize; } ac.push({ rowIdx: Math.round((bound.rect.y - y0) / lineHeight), bound: bound.rect, text: excelData.text, excelData: excelData }); }); return ac; }, []); textInfos.sort((a, b) => { if (a.rowIdx === b.rowIdx) { return a.bound.x - b.bound.x; } else { return a.bound.y - b.bound.y; } }); var richTextRows = textInfos.reduce((ac, cr, i) => { var rowIdx = cr.rowIdx; while (ac.richTextRows.length <= rowIdx) { ac.x = ac.x0; ac.richTextRows.push([]); } var marginTextL = Math.floor((cr.bound.x - ac.x) / 3.314239501953125); if (marginTextL > 0) { ac.richTextRows[ac.richTextRows.length - 1].push({ text: ' '.repeat(marginTextL), font: { 'name': 'Calibri' } }); } ac.richTextRows[ac.richTextRows.length - 1].push(cr.excelData); ac.x = cr.bound.x + cr.bound.width; ac.y = cr.bound.y; return ac; }, { richTextRows: [], x: cBound.left + 5, x0: cBound.left + 5, }).richTextRows; if (placeHolderElt) { placeHolderElt.selfReplace(this); } if (renderSpace) renderSpace.remove(); return richTextRows; } } }); /** * * @param {TEITable} table * @param data * @constructor */ function TEIRow(table, data) { data = data || {}; if (!(data.cells instanceof Array)) data.cells = []; this.table = table; this.tr = (0,ACore._)('tr'); /** * * @type {TEICell[]} */ this.cells = []; this.data = data; } Object.defineProperty(TEIRow.prototype, 'data', { set: function (data) { this.cells = data.cells.map(cellData => new TEICell(this, cellData)); this.tr.clearChild().addChild(this.cells.map(cell => cell.td)); }, get: function () { return { cells: this.cells.map(cell => cell.data) } } }); var cellOf = node => { while (node) { if (node.teiCell) return node.teiCell; node = node.parentElement; } return null; } /** * * @param {TEIRow} row * @param {TEIDataCell} data * @constructor */ function TEICell(row, data) { this.row = row; this.table = row.table; this.td = (0,ACore._)({ tag: 'td', class: 'as-table-of-text-input-cell', on: { click: (event) => { if (event.target === this.td) this.focus(); }, }, child: { tag: js_PreInput, attr: { spellcheck: 'false' }, props: { teiCell: this }, on: { focus: () => { this.table.formatTool.onFocus(this); }, blur: () => { this.table.formatTool.onBlur(this); }, change: (event) => { if (event.originalEvent) this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this.table.elt); } } } }); this.$input = (0,ACore.$)('preinput', this.td); this.data = data; this.style = new AppPattern_Attributes(this); Object.assign(this.style, data.style); this.style.loadAttributeHandlers(this.styleHandlers); } TEICell.prototype.focus = function () { this.$input.focus(); var textNode = (0,Text.getTextNodesIn)(this.$input).pop(); if (!textNode) return; var range = document.createRange(); range.setStart(textNode, textNode.data.length); range.setEnd(textNode, textNode.data.length); var sel = getSelection(); sel.removeAllRanges(); sel.addRange(range); }; TEICell.prototype.remove = function () { this.td.remove(); var idx = this.table.cells.indexOf(this); if (idx >= 0) this.table.cells.splice(idx, 1); }; TEICell.prototype.styleHandlers = { fontWeight: { set: function (value) { if (value === 'bold') { this.td.addClass('as-bold'); } else { this.td.removeClass('as-bold'); } }, get: function () { if (this.td.hasClass('as-bold')) return 'bold'; return 'normal'; }, export: function () { if (this.td.hasClass('as-bold')) return 'bold'; return undefined; } }, fontStyle: { set: function (value) { if (value === 'italic') { this.td.addClass('as-italic'); } else { this.td.removeClass('as-italic'); } }, get: function () { if (this.td.hasClass('as-italic')) return 'italic'; return 'normal'; }, export: function () { if (this.td.hasClass('as-italic')) return 'italic'; return undefined; } }, fontSize: { set: function (value) { if (typeof value === "string") value = parseInt(value.replace(/[^0-9.]/g, ''), 10); if (!(0,utils.isRealNumber)(value)) value = 11; value = Math.abs(value); value = value || 11; this.td.addStyle('font-size', value + 'pt'); return value; }, get: function (ref) { var value = ref.get(); return value || 11; }, export: function (ref) { var value = ref.get(); if (value === 11) value = undefined; return value || undefined; } }, color: { set: function (value) { try { var cValue = Color_Color/* default.parse */.Z.parse(value); value = cValue.toString('hex6'); } catch (err) { value = '#000000'; } this.td.addStyle('color', value); return value; }, get: function (ref) { return ref.get() || '#000000'; }, export: function (ref) { var value = ref.get(); if (value === '#000000') value = undefined; return value || undefined; } }, textAlign: { set: function (value) { if (!['left', 'right', 'center'].includes(value)) value = 'left'; this.td.addStyle('text-align', value); return value; }, get: function (ref) { var value = ref.get(); return value || 'left'; }, export: function (ref) { var value = ref.get(); if (value === 'left') value = undefined; return value; } } }; Object.defineProperty(TEICell.prototype, "data", { set: function (value) { value = value || {}; if (typeof value === "string") value = { value: value }; if (typeof value.value === "string") { this.$input.value = value.value; } else { this.$input.value = ""; } }, get: function () { var res = {}; res.value = this.$input.value; res.style = this.style.export(); Object.keys(res.style).forEach(key => { if (res.style[key] === undefined) delete res.style[key]; }); return res; } }); Object.defineProperties(TEICell.prototype, { colspan: { set: function (value) { }, get: function () { var value = this.td.attr('colspan') || '1'; value = parseInt(value); if ((0,utils.isNaturalNumber)(value)) return value; return 1; } }, rowspan: { set: function (value) { }, get: function () { var value = this.td.attr('rowspan') || '1'; value = parseInt(value); if ((0,utils.isNaturalNumber)(value)) return value; return 1; } }, colpos: { get: function () { } }, rowpos: { get: function () { } } }); function TEIFormatTool(table) { Object.keys(TEIFormatTool.prototype).filter(k => k.startsWith('ev_')).forEach(k => this[k] = this[k].bind(this)); this.table = table; this.table.elt.on('keydown', this.ev_keydown) this.$tool = (0,ACore._)({ class: 'as-table-of-text-input-tool', child: [ { tag: 'numberinput', class: 'as-table-of-text-input-tool-font-size', props: { value: 14 }, attr: { title: 'Ctrl+< | Ctrl+>' } }, { tag: 'button', attr: { title: 'Ctrl+B' }, class: ['as-transparent-button', 'as-table-of-text-input-tool-bold'/*, 'as-checked'*/], child: 'span.mdi.mdi-format-bold' }, { tag: 'button', attr: { title: 'Ctrl+I' }, class: ['as-transparent-button', 'as-table-of-text-input-tool-italic'], child: 'span.mdi.mdi-format-italic' }, { tag: colorpicker_FontColorButton }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-text-align'], child: 'span.mdi.mdi-format-align-left', attr: { 'data-align': 'left', title: 'Ctrl+L' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-text-align'], child: 'span.mdi.mdi-format-align-center', attr: { 'data-align': 'center', title: 'Ctrl+E' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-text-align'], child: 'span.mdi.mdi-format-align-right', attr: { 'data-align': 'right', title: 'Ctrl+R' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-column-plus-before', attr: { 'data-command': 'left' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-column-plus-after', attr: { 'data-command': 'right' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-row-plus-before', attr: { 'data-command': 'above' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-row-plus-after', attr: { 'data-command': 'bellow' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command', 'as-variant-danger'], attr: { 'data-command': 'removeCol' }, child: { tag: 'span', class: ['mdi', 'mdi-table-column-remove'], }, }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command', 'as-variant-danger'], attr: { 'data-command': 'removeRow' }, child: { tag: 'span', class: ['mdi', 'mdi-table-row-remove'], }, }, ] }); this.table.wrapper.addChildBefore(this.$tool, this.table.wrapper.firstChild); this.$fontSize = (0,ACore.$)('.as-table-of-text-input-tool-font-size', this.$tool).on('change', this.ev_fontSizeChange); this.$bold = (0,ACore.$)('.as-table-of-text-input-tool-bold', this.$tool).on('click', this.ev_clickBold); this.$italic = (0,ACore.$)('.as-table-of-text-input-tool-italic', this.$tool).on('click', this.ev_clickItalic); this.$fontColor = (0,ACore.$)(colorpicker_FontColorButton.tag, this.$tool).on('submit', this.ev_fontColorSubmit); this.$alignBtns = (0,ACore.$$)('.as-table-of-text-input-tool-text-align', this.$tool) .reduce((ac, btn) => { var value = btn.attr('data-align'); btn.on('click', ev => { this.ev_clickAlign(value, ev); }); ac[value] = btn; return ac; }, {}); this.$commandBtns = (0,ACore.$$)('.as-table-of-text-input-tool-command', this.$tool) .reduce((ac, btn) => { var value = btn.attr('data-command'); btn.on('click', ev => { this.commands[value].exec.call(this); // this.ev_clickInsert(value, ev); }); ac[value] = btn; return ac; }, {}); // this.$removeBtn = $('.as-table-of-text-input-tool-remove-col', this.$tool) // .on('click', this.ev_clickRemove); this.focusCell = null; this.table.elt.on('change', () => this.updateAvailableCommands()); } TEIFormatTool.prototype.commands = { left: { /** * @this TEIFormatTool */ available: function () { return this.focusCell.row.cells.length < this.table.maxCol; }, /** * @this TEIFormatTool */ exec: function () { var idx = this.focusCell.row.cells.indexOf(this.focusCell); this.table.rows.forEach(row => { var newCell = new TEICell(row, { value: '' }); row.tr.addChildBefore(newCell.td, row.cells[idx].td); row.cells.splice(idx, 0, newCell); }); this.table.elt.emit('change', { type: 'change', target: this.table }, this.table.elt); } }, right: { /** * @this TEIFormatTool */ exec: function () { var idx = this.focusCell.row.cells.indexOf(this.focusCell); this.table.rows.forEach(row => { var newCell = new TEICell(row, { value: '' }); row.tr.addChildAfter(newCell.td, row.cells[idx].td); row.cells.splice(idx + 1, 0, newCell); }); this.table.elt.emit('change', { type: 'change', target: this.table }, this.table.elt); } }, above: { /** * @this TEIFormatTool */ available: function () { return this.table.rows.length < this.table.maxRow; }, /** * @this TEIFormatTool */ exec: function () { if (!this.focusCell) return; var colN = this.table.rows[0].cells.length; var focusRow = this.focusCell.row; var idx = this.table.rows.indexOf(focusRow); var newRow = new TEIRow(this.table, { cells: Array(colN).fill().map(() => ({ value: '' })) }); this.table.rows.splice(idx, 0, newRow); this.table.$body.addChildBefore(newRow.tr, focusRow.tr); this.table.notifyChange({ newRow: newRow }); } }, bellow: { /** * @this TEIFormatTool */ exec: function () { if (!this.focusCell) return; var colN = this.table.rows[0].cells.length; var focusRow = this.focusCell.row; var idx = this.table.rows.indexOf(focusRow); var newRow = new TEIRow(this.table, { cells: Array(colN).fill().map(() => ({ value: '' })) }); this.table.rows.splice(idx + 1, 0, newRow); this.table.$body.addChildAfter(newRow.tr, focusRow.tr); this.table.notifyChange({ newRow: newRow }); } }, removeCol: { /** * @this TEIFormatTool */ available: function () { return this.table.minCol < this.focusCell.row.cells.length; }, /** * @this TEIFormatTool */ exec: function () { if (!this.focusCell) return; var focusRow = this.focusCell.row; var idx = focusRow.cells.indexOf(this.focusCell); this.table.rows.forEach(row => { var cell = row.cells[idx]; cell.td.remove(); row.cells.splice(idx, 1); }); this.table.elt.emit('change', { type: 'change', target: this.table }, this.table.elt); var cellNext = focusRow.cells[idx - 1] || focusRow.cells[idx]; if (cellNext) cellNext.focus(); } }, removeRow: { /** * @this TEIFormatTool */ available: function () { return this.table.minRow < this.table.rows.length; }, /** * @this TEIFormatTool */ exec: function () { if (!this.focusCell) return; var focusRow = this.focusCell.row; var idx = this.table.rows.indexOf(focusRow); var colIdx = focusRow.cells.indexOf(this.focusCell); focusRow.tr.remove(); this.table.rows.splice(idx, 1); this.table.elt.emit('change', { type: 'change', target: this.table }, this.table.elt); var nextRow = this.table.rows[idx] || this.table.rows[idx - 1]; var nexCell; if (nextRow) { nexCell = nextRow.cells[colIdx]; if (nexCell) nexCell.focus(); } } } }; TEIFormatTool.prototype.commands.right.available = TEIFormatTool.prototype.commands.left.available; TEIFormatTool.prototype.commands.bellow.available = TEIFormatTool.prototype.commands.above.available; TEIFormatTool.prototype.onFocus = function (cell) { if (this.focusCell !== cell && this.focusCell) { this.focusCell.td.removeClass('as-focus'); } if (!this.focusCell) { setTimeout(() => { document.addEventListener('click', this.ev_clickOut); }, 30); } this.focusCell = cell; this.focusCell.td.addClass('as-focus'); this.$fontSize.value = this.focusCell.style.fontSize; if (this.focusCell.style.fontWeight === 'bold') this.$bold.addClass('as-checked'); else this.$bold.removeClass('as-checked'); if (this.focusCell.style.fontStyle === 'italic') this.$italic.addClass('as-checked'); else this.$italic.removeClass('as-checked'); this.$fontColor.value = this.focusCell.style.color; var textAlign = this.focusCell.style.textAlign; for (var align in this.$alignBtns) { if (align === textAlign) { this.$alignBtns[align].addClass('as-checked'); } else { this.$alignBtns[align].removeClass('as-checked'); } } this.updateAvailableCommands(); }; TEIFormatTool.prototype.updateAvailableCommands = function () { Object.keys(this.$commandBtns).forEach(key => { var available = this.focusCell && this.commands[key].available.call(this); this.$commandBtns[key].disabled = !available; }); }; TEIFormatTool.prototype.onBlur = function (cell) { }; TEIFormatTool.prototype.ev_clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.table.wrapper, event)) return; if (this.focusCell) { this.focusCell.td.removeClass('as-focus'); this.focusCell = null; } document.removeEventListener('click', this.ev_clickOut); }; TEIFormatTool.prototype.ev_fontSizeChange = function () { if (!this.focusCell) return; var prevValue = this.focusCell.style.fontSize; var newValue = this.$fontSize.value; if (newValue !== prevValue) { this.focusCell.style.fontSize = newValue; this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); } }; TEIFormatTool.prototype.ev_clickBold = function () { if (this.$bold.hasClass('as-checked')) { this.$bold.removeClass('as-checked'); this.focusCell.style.fontWeight = 'normal'; } else { this.$bold.addClass('as-checked'); this.focusCell.style.fontWeight = 'bold'; } this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); }; TEIFormatTool.prototype.ev_clickItalic = function () { if (!this.focusCell) return; if (this.$italic.hasClass('as-checked')) { this.$italic.removeClass('as-checked'); this.focusCell.style.fontStyle = 'normal'; } else { this.$italic.addClass('as-checked'); this.focusCell.style.fontStyle = 'italic'; } this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); }; TEIFormatTool.prototype.ev_fontColorSubmit = function () { if (!this.focusCell) return; var prevColor = this.focusCell.style.color; var newColor = this.$fontColor.value; if (prevColor !== newColor) { this.focusCell.style.color = newColor; this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); } }; TEIFormatTool.prototype.ev_clickAlign = function (newValue, event) { if (!this.focusCell) return; var prevValue = this.focusCell.style.textAlign; if (prevValue !== newValue) { this.$alignBtns[prevValue].removeClass('as-checked'); this.$alignBtns[newValue].addClass('as-checked'); this.focusCell.style.textAlign = newValue; this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); } }; TEIFormatTool.prototype.ev_clickInsert = function (at, event) { if (!this.focusCell) return; var idx = this.table.cells.indexOf(this.focusCell); var bfIdx = at === 'left' ? idx : idx + 1; var newCell = new TEICell(this.table, { value: '' }); if (bfIdx >= this.table.cells.length) { this.table.$row.addChild(newCell.td); this.table.cells.push(newCell); } else { this.table.$row.addChildBefore(newCell.td, this.table.cells[bfIdx].td); this.table.cells.splice(bfIdx, 0, newCell); } this.table.elt.emit('change', { type: 'change', target: this.table, cell: this }, this); }; TEIFormatTool.prototype.ev_clickRemove = function () { if (!this.focusCell) return; this.focusCell.remove(); this.table.elt.emit('change', { type: 'change', target: this.table, cell: this.focusCell }, this.table); this.focusCell = null; }; TEIFormatTool.prototype.ev_keydown = function (event) { var key = (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event); switch (key) { case 'ctrl-b': this.ev_clickBold(event); event.preventDefault(); break; case 'ctrl-i': this.ev_clickItalic(); event.preventDefault(); break; case 'ctrl-l': this.ev_clickAlign('left', event); event.preventDefault(); break; case 'ctrl-e': this.ev_clickAlign('center', event); event.preventDefault(); break; case 'ctrl-r': this.ev_clickAlign('right', event); event.preventDefault(); break; } }; // EXTERNAL MODULE: ./node_modules/absol-acomp/js/mobile/MHeaderBar.js var MHeaderBar = __webpack_require__(9277); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/mobileapp.css var mobileapp = __webpack_require__(8789); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Context.js var Context = __webpack_require__(5721); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/mobile/MExplore.js var makeTextToNode = (data, pElt) => { var node; if (typeof data === "string") { node = (0,ACore._)({ text: data }); } else if (data instanceof Array) { data.forEach(it => makeTextToNode(it, pElt)); } if (node) pElt.addChild(node); } var makeIconToNode = (data, pElt) => { var node; if (data) node = (0,ACore._)(data); pElt.clearChild(); if (node) pElt.addChild(node); } function MExploreSectionBreak() { this._name = ''; this.$name = (0,ACore.$)('.am-explore-section-break-name', this); } MExploreSectionBreak.tag = 'MExploreSectionBreak'.toLowerCase(); MExploreSectionBreak.render = function () { return (0,ACore._)({ class: 'am-explore-section-break', child: [ { class: 'am-explore-section-break-name', }, '.am-explore-section-break-line' ] }); }; MExploreSectionBreak.property = {}; MExploreSectionBreak.property.name = { set: function (value) { if (value === null || value === undefined) value = ''; this._name = value; this.$name.clearChild(); makeTextToNode(value, this.$name); }, get: function () { return this._name; } }; function MExploreItemBlock() { this.$name = (0,ACore.$)('.am-explore-item-block-name', this); this._name = ''; this._icon = null; this.$icon = (0,ACore.$)('.am-explore-item-block-icon', this); this.$name = (0,ACore.$)('.am-explore-item-block-name', this); /** * @name name * @type {string} * @memberof MExploreItemBlock# */ /** * @name icon * @memberof MExploreItemBlock# */ } MExploreItemBlock.tag = 'MExploreItemBlock'.toLowerCase(); MExploreItemBlock.render = function () { return (0,ACore._)({ attr: { tabindex: '1' }, class: 'am-explore-item-block', child: [ { class: 'am-explore-item-block-icon' }, { class: 'am-explore-item-block-name' } ] }); }; MExploreItemBlock.property = {}; MExploreItemBlock.property.icon = { set: function (value) { value = value || null; this._icon = value; makeIconToNode(value, this.$icon) }, get: function () { return this._icon; } }; MExploreItemBlock.property.name = { set: function (value) { if (value === null || value === undefined) value = ''; makeTextToNode(value, this.$name); this._name = value; }, get: function () { return this._name; } }; MExploreItemBlock.property.hidden = { set: function (value) { if (value) { this.addClass('as-hidden'); } else { this.removeClass('as-hidden'); } }, get: function () { return this.hasClass('as-hidden'); } } function MExploreItemList() { } MExploreItemList.tag = 'MExploreItemList'.toLowerCase(); MExploreItemList.render = function () { } /** * @extends AElement * @constructor */ function MExploreGroup() { this.$br = (0,ACore.$)(MExploreSectionBreak.tag, this); this._items = []; this.$items = []; this.$itemCtn = (0,ACore.$)('.am-explore-group-item-ctn', this); /** * @name name * @type {string} * @memberof MExploreGroup# /** * @name items * @type {[]} * @memberof MExploreGroup# */ } MExploreGroup.tag = 'MExploreGroup'.toLowerCase(); MExploreGroup.render = function () { return (0,ACore._)({ class: 'am-explore-group', extendEvent: ['press'], child: [ { tag: MExploreSectionBreak }, { class: 'am-explore-group-item-ctn' } ] }); }; MExploreGroup.property = {}; MExploreGroup.property.name = { set: function (value) { value = value || ''; this.$br.name = value; if (value) { this.$br.removeStyle('display'); } else { this.$br.addStyle('display', 'none'); } }, get: function () { return this.$br.name; } }; MExploreGroup.property.items = { /** * @this MExploreGroup * @param items */ set: function (items) { if (!items || !items.slice || !items.map) items = []; items = items.slice(); this._items = items; while (this.$items.length) { this.$items.pop().selfRemove(); } this.$items = items.map(it => { var elt = (0,ACore._)({ tag: MExploreItemBlock, props: { data: it, name: it.name, icon: it.icon, hidden: !!it.hidden }, on: { click: event => { this.emit('press', { type: 'press', target: elt, itemData: it, originalEvent: event, itemElt: elt }, this); } } }); if (window.ABSOL_DEBUG) { elt.attr('title', 'score: ' + it.score); } return elt; }); this.$itemCtn.addChild(this.$items); }, get: function () { return this._items; } } MExploreGroup.property.hidden = { set: function (value) { if (value) { this.addClass('as-hidden'); } else { this.removeClass('as-hidden'); } }, get: function () { return this.hasClass('as-hidden'); } }; /** * @extends AElement * @constructor */ function MSpringboardMenu() { if (BrowserDetector/* default.isMobile */.Z.isMobile) { this.addClass('as-mobile'); } this.keyboardCtrl = new MSMKeyboardController(this); this.$groups = []; this.$attachHook = (0,ACore._)('attachhook').addTo(this); this.$attachHook.on('attached', () => { ResizeSystem/* default.add */.Z.add(this); this.updateSize(); this.keyboardCtrl.lowPriorityFocus(); }); this.$attachHook.requestUpdateSize = this.updateSize.bind(this); this.searchingPlugin = new MSMSearchingPlugin(this); /** * @name searching * @type {{input: SearchTextInput, items: []}} * @memberof MSpringboardMenu# */ } MSpringboardMenu.tag = 'MSpringboardMenu'.toLowerCase(); MSpringboardMenu.render = function () { return (0,ACore._)({ attr: { tabindex: '1' }, class: 'am-springboard-menu', extendEvent: ['press'] }); }; MSpringboardMenu.prototype.updateSize = function () { if (!this.isDescendantOf(document.body)) return; if (this.$groups.length === 0) return; var maxChildLength = 0; var longestGroupElt = this.$groups[0]; var groupElt; for (var i = 0; i < this.$groups.length; ++i) { groupElt = this.$groups[i]; if (groupElt.$items.length > maxChildLength) { longestGroupElt = groupElt; maxChildLength = groupElt.$items.length; } } var style = getComputedStyle(groupElt.$itemCtn); var width = parseFloat(style.width.replace('px', '')); if (width < 10) return; var paddingLeft = parseFloat(style.paddingLeft.replace('px', '')); var paddingRight = parseFloat(style.paddingRight.replace('px', '')); var rowLength = Math.max(1, Math.floor((width - paddingLeft - paddingRight) / 150)); var itemWidth = Math.floor((width - paddingLeft - paddingRight) / rowLength) - 1; this.addStyle('--item-width', itemWidth + 'px'); }; MSpringboardMenu.property = {}; MSpringboardMenu.property.groups = { /** * @this MSpringboardMenu * @param groups */ set: function (groups) { if (!(groups instanceof Array)) groups = []; this.$groups.forEach(elt => elt.selfRemove()); this.$groups = groups.map(group => { var hidden = group.hidden || !group.items || group.items.length === 0 || group.items.every(it => it.hidden); var elt = (0,ACore._)({ tag: MExploreGroup, props: { data: group, name: group.name, items: group.items || [], hidden: hidden }, on: { press: (event) => { this.emit('press', Object.assign({ groupElt: elt, groupData: group }, event), this); } } }); return elt; }); this.addChild(this.$groups); this.updateSize(); }, get: function () { return this.$groups.map(gr => gr.data); } }; ACore/* default.install */.Z.install(MSpringboardMenu); /** * * @param {MSpringboardMenu} elt * @constructor */ function MSMKeyboardController(elt) { this.elt = elt; if (!BrowserDetector/* default.isMobile */.Z.isMobile) this.elt.on('keydown', this.ev_keydown.bind(this)); this.itemsMatrix = []; } MSMKeyboardController.prototype.canLowPriorityFocus = function () { var elt = document.activeElement; if (!elt || elt === document.body || elt === this.elt) { return true; } if (elt.hasClass && elt.hasClass('am-explore-item-block') && elt.isDescendantOf(this.elt)) return false; var style; while (elt && elt !== document.body && elt !== this.elt) { style = getComputedStyle(elt); if (style.display === 'none' || style.visibility === 'hidden' || style.opacity === '0') { return true; } elt = elt.parentElement; } return false; }; MSMKeyboardController.prototype.lowPriorityFocus = function () { if (!this.canLowPriorityFocus()) return; this.elt.focus(); // var firstItem = null; // for (var i = 0; i < this.elt.$groups.length; ++i) { // var group = this.elt.$groups[i]; // if (group.$items.length > 0) { // firstItem = group.$items[0]; // break; // } // } // if (firstItem) { // firstItem.focus(); // } }; MSMKeyboardController.prototype.calcItemsMatrix = function () { var arr = []; var group; var item; for (var i = 0; i < this.elt.$groups.length; ++i) { group = this.elt.$groups[i]; for (var j = 0; j < group.$items.length; ++j) { item = group.$items[j]; if (item.hidden) continue; arr.push(item); } } arr = arr.map(item => { var rect = item.getBoundingClientRect(); return { item: item, ii: Math.round(rect.top / 30), jj: Math.round(rect.left / 30) } }); var rows = arr.reduce((ac, it) => { ac[it.ii] = ac[it.ii] || []; ac[it.ii].push(it); return ac; }, {}); rows = Object.values(rows); rows.sort((a, b) => { return a[0].ii - b[0].ii; }); rows.forEach(row => { row.sort((a, b) => { return a.jj - b.jj; }); }); this.itemsMatrix = rows.map(row => row.map(it => it.item)); return rows; }; MSMKeyboardController.prototype.findItemsStartsWith = function (prefix) { prefix = prefix.toLowerCase(); var res = []; var group; var item; for (var i = 0; i < this.elt.$groups.length; ++i) { group = this.elt.$groups[i]; for (var j = 0; j < group.$items.length; ++j) { item = group.$items[j]; if (item.hidden) continue; if ((0,stringFormat.nonAccentVietnamese)(item.name.toLowerCase()).startsWith(prefix)) { res.push(item); } } } return res; }; /** * * @param elt */ MSMKeyboardController.prototype.positionOf = function (elt) { if (!elt) return null; if (elt.hidden) return null; var row; var item; for (var i = 0; i < this.itemsMatrix.length; ++i) { row = this.itemsMatrix[i]; for (var j = 0; j < row.length; ++j) { item = row[j]; if (item === elt) { return [i, j]; } } } return null; }; MSMKeyboardController.prototype.ev_keydown = function (event) { if (event.target.tagName === 'INPUT' || event.target.tagName === 'TEXTAREA') return; var key = (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event); var focusElt = document.activeElement; if (!focusElt || !focusElt.hasClass) focusElt = null; if (focusElt && !focusElt.hasClass('am-explore-item-block')) focusElt = null; if (focusElt && focusElt.hidden) focusElt = null; if (focusElt && !focusElt.isDescendantOf(this.elt)) focusElt = null; var focusIdx; var itemEltArr; var itemPos; if (key.length === 1) { itemEltArr = this.findItemsStartsWith(key); focusIdx = itemEltArr.indexOf(focusElt); if (itemEltArr.length > 0) { itemEltArr[(focusIdx + 1) % itemEltArr.length].focus(); } } else if (['arrowdown', 'arrowup', 'arrowleft', 'arrowright'].indexOf(key) >= 0) { event.preventDefault(); this.calcItemsMatrix(); itemPos = this.positionOf(focusElt); switch (key) { case 'arrowdown': itemPos = itemPos || [-1, 0]; if (itemPos[0] < this.itemsMatrix.length - 1) { itemPos[0]++; itemPos[1] = Math.min(itemPos[1], this.itemsMatrix[itemPos[0]].length - 1); } break; case 'arrowup': itemPos = itemPos || [1, 0]; if (itemPos[0] > 0) { itemPos[0]--; itemPos[1] = Math.min(itemPos[1], this.itemsMatrix[itemPos[0]].length - 1); } break; case 'arrowleft': itemPos = itemPos || [0, 1]; if (itemPos[1] > 0) { itemPos[1]--; } else if (itemPos[0] > 0) { itemPos[0]--; itemPos[1] = this.itemsMatrix[itemPos[0]].length - 1; } break; case 'arrowright': itemPos = itemPos || [0, -1]; if (itemPos[1] < this.itemsMatrix[itemPos[0]].length - 1) { itemPos[1]++; } else if (itemPos[0] < this.itemsMatrix.length - 1) { itemPos[0]++; itemPos[1] = 0; } break; } focusElt = this.itemsMatrix[itemPos[0]] && this.itemsMatrix[itemPos[0]][itemPos[1]]; if (focusElt) focusElt.focus(); } else if (key === 'enter') { event.preventDefault(); if (focusElt) focusElt.click(); } }; /** * @extends Context * @param {MSpringboardMenu} elt * @constructor */ function MSMSearchingPlugin(elt) { Context/* default.call */.Z.call(this); this.elt = elt; this._data = null; OOP/* default.drillProperty */.ZP.drillProperty(this.elt, this, 'searching', 'data'); this.ev_inputStopTyping = this.ev_inputStopTyping.bind(this); /** * @type {SearchTextInput|null} */ this.$input = null; this.itemHolders = []; this.$seachGroups = []; } (0,OOP/* mixClass */.Jx)(MSMSearchingPlugin, Context/* default */.Z); MSMSearchingPlugin.prototype.onStart = function () { this.$input = this._data && this._data.input; if (!this.$input) { this.$input = (0,ACore._)({ tag: Searcher/* default */.Z }); this.elt.addChildBefore(this.$input, this.elt.firstChild); } this.$input.on('stoptyping', this.ev_inputStopTyping); this.calcItemHoldersFromItems(); }; MSMSearchingPlugin.prototype.calcItemHoldersFromItems = function () { // var holders = []; var count = 0; var virtualGroups = []; var visit = (item, parent) => { if (item.hidden) return; count++; var holder = this.makeHolder(item); holder.path = parent.path.concat([parent.item.name]); holder.count = count; if (holder.type === 'group') { virtualGroups.push(holder); } else { parent.children = parent.children || []; parent.children.push(holder); } if (item.items && item.items.length > 0) { if (holder.type !== 'group') { holder = Object.assign({}, holder, { type: 'group', children: [] }); virtualGroups.push(holder); } item.items.forEach((child) => visit(child, holder)); } } var rootHolder = Object.assign({}, this.makeHolder({ name: 'root' }), { children: [], path: [], type: 'group' }); virtualGroups.push(rootHolder); this._data.items.forEach((item) => visit(item, rootHolder)); virtualGroups = virtualGroups.filter(it => it.children && it.children.length > 0); this.itemHolders = virtualGroups; }; MSMSearchingPlugin.prototype.onResume = function () { this.elt.addClass('as-searching'); //view search }; MSMSearchingPlugin.prototype.onPause = function () { this.elt.removeClass('as-searching'); //view origin }; MSMSearchingPlugin.prototype.onStop = function () { this.$input.on('stopchange', this.ev_inputStopTyping); if (this.$input.isDescendantOf(this.elt)) { this.$input.remove(); } //turn off event }; MSMSearchingPlugin.prototype.makeHolder = function (item) { var spliter = /[\s,-\.+?\_]+/; var notEmp = function (e) { return e.length > 0; }; var res = { item: item, text: item.name || item.searchName || '', hidden: !!item.hidden, type: item.type }; if (item.hidden) return res; res.text = res.text.toLowerCase(); res.words = res.text.split(spliter).filter(notEmp); res.text = res.words.join(' '); res.nacWords = res.words.map(txt => (0,stringFormat.nonAccentVietnamese)(txt)); res.nacText = res.nacWords.join(' '); res.wordDict = res.words.reduce((ac, cr) => { ac[cr] = true; return ac; }, {}); res.nacWordDict = res.nacWords.reduce((ac, cr) => { ac[cr] = true; return ac; }, {}); return res; }; MSMSearchingPlugin.prototype.calcScore = function (queryHolder, itemHolder) { var score = 0; var mustIncluded = false; if (itemHolder.nacText.indexOf(queryHolder.nacText) >= 0) mustIncluded = true; if (itemHolder.text.indexOf(queryHolder.text) >= 0) mustIncluded = true; score += (0,stringMatching.wordsMatch)(queryHolder.words, itemHolder.words) / ((0,Math_int.harmonicMean)(queryHolder.words.length, itemHolder.words.length) || 1); score += (0,stringMatching.wordsMatch)(queryHolder.nacWords, itemHolder.nacWords) / ((0,Math_int.harmonicMean)(queryHolder.nacWords.length, itemHolder.nacWords.length) || 1); var dict = Object.keys(itemHolder.nacWordDict); Object.keys(queryHolder.nacWordDict).forEach(function (qWord) { var bestWordScore = 0; var bestWord = ''; var word; for (word in dict) { if ((0,stringMatching.wordLike)(qWord, word) > bestWordScore) { bestWordScore = (0,stringMatching.wordLike)(qWord, word); bestWord = word; } } if (bestWordScore > 0) { score += bestWordScore / ((0,Math_int.harmonicMean)(qWord.length, bestWord.length) || 1); delete dict[bestWord]; } }); return { score: score, mustIncluded: mustIncluded }; }; MSMSearchingPlugin.prototype.ev_inputStopTyping = function () { var query = this.$input.value; this.query(query); }; MSMSearchingPlugin.prototype.query = function (query) { query = query || ''; query = query.trim(); if (query && query.length > 0 && this.state !== 'RUNNING') { this.start(); } else if (!query || query.length === 0) { this.pause(); return; } var scoreList = []; var queryHolder = this.makeHolder({ name: query }, -1); var visit2calcScore = (holder) => { var res = Object.assign({ item: holder.item, type: holder.type, path: holder.path }, this.calcScore(queryHolder, holder)); scoreList.push(res.score); if (holder.children) { res.children = holder.children.map(visit2calcScore); res.childrenScore = res.children.reduce((ac, cr) => Math.max(ac, cr.score, cr.childrenScore || 0), 0); res.treeScore = Math.max(res.score, res.childrenScore || 0); } return res; }; var itemsHolders = this.itemHolders.map(visit2calcScore); scoreList.push(0); scoreList.sort((a, b) => b - a); var maxScore = scoreList[0] || 0; var midScore; if (maxScore < 1) { midScore = Math.max(maxScore - 0.2, 0.1); midScore = Math.max(midScore, scoreList[Math.floor(scoreList.length * 0.2 * maxScore)] - 0.01); } else { midScore = maxScore * 0.6; midScore = Math.max(midScore, scoreList[Math.floor(scoreList.length * 0.3)] - 0.1); } var visit2filter = function (holder) { var score = holder.score; var childrenScore = holder.childrenScore || 0; if (holder.mustIncluded) return true; if (score >= midScore && childrenScore <= score) return true; if (holder.children) { holder.children = holder.children.filter(visit2filter); return holder.children.length > 0; } return false; }; itemsHolders = itemsHolders.filter(visit2filter); itemsHolders.forEach(holder => { if (holder.children) holder.children.sort((a, b) => b.treeScore - a.treeScore); }); itemsHolders.sort((a, b) => b.treeScore - a.treeScore); this.$seachGroups.forEach(elt => elt.remove()); this.$seachGroups = itemsHolders.map(holder => { var elt = (0,ACore._)({ tag: MExploreGroup, class: 'as-search-result', props: {}, on: { press: (event) => { this.elt.emit('press', Object.assign({ groupElt: elt, groupData: holder.item }, event), this.elt); } } }); if (window.ABSOL_DEBUG) { elt.attr('title', 'score: ' + holder.score + ', childrenScore: ' + holder.childrenScore); } if (holder.item.name === 'root') { elt.name = '/'; } else { elt.name = holder.path.slice(1).concat(holder.item.name).join(' / '); } if (holder.children) { elt.items = holder.children.map(child => Object.assign({ score: child.score }, child.item)); } return elt; }); this.elt.addChild(this.$seachGroups); }; Object.defineProperty(MSMSearchingPlugin.prototype, 'data', { get: function () { return this._data; }, set: function (value) { this.stop(); value = value || null; if (value && !value.items) value = null; if (value && !value.items.length) value = null; this._data = value; if (value) this.start(true); } }); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/colorpickerbutton.css var colorpickerbutton = __webpack_require__(9693); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/ColorPicker.js function ColorPicker() { var res = (0,ACore._)(['<div class="absol-color-picker">', ' <div class="absol-color-picker-color">', ' <div class="absol-color-picker-sat">', ' <div class="absol-color-picker-val">', ' <div class="absol-color-dragger"></div>', ' </div>', ' </div>', ' </div>', ' <div class="absol-color-picker-hue-range">', ' <div class="absol-color-picker-hue">', ' <div class="absol-color-dragger"></div>', ' </div>', ' </div>', ' <div class="absol-color-picker-alpha-range">', ' <div class="absol-color-picker-alpha">', ' <div class="absol-color-dragger"></div>', ' </div>', ' </div>', ' <div class="absol-color-picker-input">', ` <div class="absol-color-picker-text-container"> <span class="f-mode">hsba(</span> <span class="absol-editabe-text num0">0</span><span class="separator0">deg, </span> <span class="absol-editabe-text num1">0</span><span class="separator1">%, </span> <span class="absol-editabe-text num2">0</span><span class="separator2">%, </span> <span class="absol-editabe-text num3">0</span><span>)</span> </div>`, ' </div>', ' <button class="absol-color-picker-mode">HSB</button>', '</div>'].join('') ); res.$fMode = (0,ACore.$)('.f-mode', res); res.$sep0 = (0,ACore.$)('.separator0', res); res.$sep1 = (0,ACore.$)('.separator1', res); res.$sep2 = (0,ACore.$)('.separator2', res); res.$num0 = (0,ACore._)('editabletext.num0'); res.$num1 = (0,ACore._)('editabletext.num1'); res.$num2 = (0,ACore._)('editabletext.num2'); res.$num3 = (0,ACore._)('editabletext.num3'); ColorPicker.defaultNumberInputHandle(res.$num0); ColorPicker.defaultNumberInputHandle(res.$num1); ColorPicker.defaultNumberInputHandle(res.$num2); ColorPicker.defaultNumberInputHandle(res.$num3); res._num0LimitOption = ColorPicker.numberInputHandleLimit(res.$num0, 0, 360); res._num1LimitOption = ColorPicker.numberInputHandleLimit(res.$num1, 0, 100, 0); res._num2LimitOption = ColorPicker.numberInputHandleLimit(res.$num2, 0, 100, 0); res._num3LimitOption = ColorPicker.numberInputHandleLimit(res.$num3, 0, 1, 3); (0,ACore.$)(".absol-editabe-text.num0", res).selfReplace(res.$num0); (0,ACore.$)(".absol-editabe-text.num1", res).selfReplace(res.$num1); (0,ACore.$)(".absol-editabe-text.num2", res).selfReplace(res.$num2); (0,ACore.$)(".absol-editabe-text.num3", res).selfReplace(res.$num3); res.$num0.text = '0'; res.$num1.text = '0'; res.$num2.text = '0'; res.$num3.text = '0'; res.switchMode = { RGBA: 'HSBA', HSBA: 'HSLA', HSLA: 'RGBA', RGB: 'HSB', HSB: 'HSL', HSL: 'RGB' }; res.toggleAlpha = { RGBA: 'RGB', HSBA: 'HSB', HSLA: 'HSL', RGB: 'RGBA', HSB: 'HSBA', HSL: 'HSLA' }; res.defineEvent(['change']); res._saturation = 0; res._brightness = 0; res._hue = 0; res._alpha = 1; res.$color = (0,ACore.$)('.absol-color-picker-color', res); res.$colorVal = (0,ACore.$)('.absol-color-picker-val', res); res.$draggerVal = (0,ACore.$)('.absol-color-dragger', res.$colorVal); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, ColorPicker.eventHandler); res.$colorVal.on('pointerdown', res.eventHandler.colorPointerDown, true); res.$hue = (0,ACore.$)('.absol-color-picker-hue', res); res.$draggerHue = (0,ACore.$)('.absol-color-dragger', res.$hue); res.$hue.on('pointerdown', res.eventHandler.huePointerDown); res.$alpha = (0,ACore.$)('.absol-color-picker-alpha', res); res.$alpha.on('pointerdown', res.eventHandler.alphaPointerDown); res.$draggerAlpha = (0,ACore.$)('.absol-color-dragger', res.$alpha); res.$textContainer = (0,ACore.$)('.absol-color-picker-text-container', res); res.$mode = (0,ACore.$)('.absol-color-picker-mode', res); res.$mode.on('click', res.eventHandler.modeClick); //todo res.$num0.on('blur', res.eventHandler.inputBlur); res.$num1.on('blur', res.eventHandler.inputBlur); res.$num2.on('blur', res.eventHandler.inputBlur); res.$num3.on('blur', res.eventHandler.inputBlur); return res; } ColorPicker.defaultNumberInputHandle = function (element) { element .on('keydown', function (event) { if (!event.key.match(/^[0-9\.]$/) && event.key.length == 1) { event.preventDefault(); } if (event.key == 'Tab') { event.preventDefault(); } if (event.key == 'Enter') { this.edit(false); } if (event.key == '.' && this.text.indexOf('.') >= 0) { event.preventDefault(); } if (this.text.length >= 6 && event.key.length == 1) event.preventDefault(); }) .on('click', function (event) { element.edit(true, true); }) .on('keydown', function (event) { if (event.key == 'Tab') { var parent = element.parentNode; var firstFriend; var found = false; var nextFriend = (0,ACore.$)('editabletext', parent, function (elt) { if (elt.getComputedStyleValue('display') == "none") return; if (!firstFriend) { firstFriend = elt; } if (elt == element) { found = true; } else if (found) { return true; } }); nextFriend = nextFriend || firstFriend; if (nextFriend) { nextFriend.edit(true, true); } } }); }; ColorPicker.numberInputHandleLimit = function (element, min, max, fixed) { var option = { min: min, max: max, fixed: fixed || 0, enable: true } element.on('blur', function (event) { if (!option.enable) return; var number = parseFloat(element.text); if (isNaN(number)) { number = min; } if (option.fixed == 0) { number = Math.round(number); } number = Math.max(min, Math.min(option.max, number)); element.text = number.toFixed(option.fixed) + ''; }); return option; }; ColorPicker.property = {}; ColorPicker.property.withAlpha = { set: function (value) { if (value) { this.addClass('with-alpha'); } else { this.removeClass('with-alpha'); } }, get: function () { return this.containClass('with-alpha'); } }; ColorPicker.property.saturation = { set: function (value) { value = value || 0; value = Math.max(0, Math.min(1, value)); this._saturation = value; this.$draggerVal.addStyle('left', value * 100 + '%'); this._update(); }, get: function () { return this._saturation; } }; ColorPicker.property.brightness = { set: function (value) { value = value || 0; value = Math.max(0, Math.min(1, value)); this._brightness = value; this.$draggerVal.addStyle('bottom', value * 100 + '%'); this._update(); }, get: function () { return this._brightness; } }; ColorPicker.property.mode = { set: function (value) { value = (value + '').toUpperCase(); if (value.indexOf('A') >= 0) { this.addClass('with-alpha'); } else { this.removeClass('with-alpha'); this.alpha = 1; } if (value.match(/^H/)) { this._num0LimitOption.max = 360; this._num1LimitOption.max = 100; this._num2LimitOption.max = 100; } else if (value.match(/^RGB/)) { this._num0LimitOption.max = 255; this._num1LimitOption.max = 255; this._num2LimitOption.max = 255; } if (value.match(/^(HSB|HSL|RGB|RGBA|HSBA|HSLA)$/)) { this.$mode.innerHTML = value; this._updateColorText(); } }, get: function () { return this.$mode.innerHTML; } }; ColorPicker.property.hue = { set: function (value) { value = value || 0; value = Math.max(0, Math.min(1, value)); this._hue = value; this.$draggerHue.addStyle('top', value * 100 + '%'); this._update(); }, get: function () { return this._hue; } }; ColorPicker.property.alpha = { set: function (value) { value = value || 0; value = Math.max(0, Math.min(1, value)); this._alpha = value; this.$draggerAlpha.addStyle('top', (1 - value) * 100 + '%'); this._update(); }, get: function () { return this._alpha; } }; ColorPicker.property.value = { set: function (value) { if (typeof value == 'string') { value = Color_Color/* default.parse */.Z.parse(value) } if (!value || !value.toHSBA) throw new Error('Invalid color type'); var hsba = value.toHSBA(); this.hue = hsba[0]; this.saturation = hsba[1]; this.brightness = hsba[2]; this.alpha = hsba[3]; }, get: function () { return Color_Color/* default.fromHSBA */.Z.fromHSBA(this.hue, this.saturation, this.brightness, this.alpha); } } ColorPicker.property.RGBA = { set: function (value) { var hsba = Color_Color/* default.rgbaToHSBA */.Z.rgbaToHSBA(value || [0, 0, 0, 0]); this.hue = hsba[0]; this.saturation = hsba[1]; this.brightness = hsba[2]; this.alpha = hsba[3]; }, get: function () { var rgba = Color_Color/* default.hsbaToRGBA */.Z.hsbaToRGBA([this.hue, this.saturation, this.brightness, this.alpha]); return rgba; }, } ColorPicker.prototype._getSVOfEvent = function (event) { var valBound = this.$colorVal.getBoundingClientRect(); var dx = event.clientX - valBound.left; var dy = event.clientY - valBound.top; var s = Math.max(0, Math.min(1, dx / valBound.width)); var b = Math.max(0, Math.min(1, 1 - dy / valBound.height)); return { s, b }; }; ColorPicker.prototype._getHOfEvent = function (event) { var hueBound = this.$hue.getBoundingClientRect(); var h = event.clientY - hueBound.top; h = h / hueBound.height; h = Math.max(0, Math.min(1, h)); return h; }; ColorPicker.prototype._getAOfEvent = function (event) { var alphaBound = this.$alpha.getBoundingClientRect(); var a = alphaBound.bottom - event.clientY; a = a / alphaBound.height; a = Math.max(0, Math.min(1, a)); return a; }; ColorPicker.prototype._getTextColorCode = function () { var h = this.hue + 0.5; if (h > 1) h -= 1; var s = this.saturation > 0.5 ? 0 : 1; var b = this.brightness > 0.5 ? 0 : 1; var rgba = Color_Color/* default.hsbaToRGBA */.Z.hsbaToRGBA([h, s, b, 1]); return 'rgba(' + rgba.map((x, i) => i < 3 ? x * 255 : x).join(',') + ')'; }; ColorPicker.prototype.init = function (props) { this.RGBA = [1, 1, 1, 1]; this.super(props); }; ColorPicker.prototype._update = function () { //update vs var rgba = Color_Color/* default.hsbaToRGBA */.Z.hsbaToRGBA([this.hue, 1, 1, 1]); this.$color.addStyle('background', 'rgba(' + rgba.map((x, i) => i < 3 ? x * 255 : x).join(',') + ')'); rgba = Color_Color/* default.hsbaToRGBA */.Z.hsbaToRGBA([this.hue, this.saturation, this.brightness, this.alpha]); this.$textContainer.addStyle('background', 'rgba(' + rgba.map((x, i) => i < 3 ? x * 255 : x).join(',') + ')'); this.$textContainer.addStyle('color', this._getTextColorCode()); this._updateColorText(); }; ColorPicker.prototype._updateColorText = function () { var hsba = [this.hue, this.saturation, this.brightness, this.alpha]; var mode = this.mode; this.$fMode.innerHTML = mode.toLocaleLowerCase() + '('; if (mode.match(/^H/)) { this.$sep0.innerHTML = 'deg, '; this.$sep1.innerHTML = '%, '; if (mode.match(/A$/)) { this.$sep2.innerHTML = "%, "; this.$num3.removeStyle('display'); } else { this.$sep2.innerHTML = "%"; this.$num3.addStyle('display', 'none'); } } else { this.$sep0.innerHTML = ', '; this.$sep1.innerHTML = ', '; if (mode.match(/A$/)) { this.$sep2.innerHTML = ", "; this.$num3.removeStyle('display'); } else { this.$num3.addStyle('display', 'none'); this.$sep2.innerHTML = ""; } } if (mode.match(/HSB/)) { this.$num0.text = '' + Math.round(hsba[0] * 360); this.$num1.text = '' + Math.round(hsba[1] * 100); this.$num2.text = '' + Math.round(hsba[2] * 100); this.$num3.text = hsba[3].toFixed(3); } else { var cBytes = Color_Color/* default */.Z['hsbaTo' + (mode.match(/A$/) ? mode : mode + 'A')](hsba); if (mode.match(/^H/)) { this.$num0.text = '' + Math.round(cBytes[0] * 360); this.$num1.text = '' + Math.round(cBytes[1] * 100); this.$num2.text = '' + Math.round(cBytes[2] * 100); this.$num3.text = hsba[3].toFixed(3); } else { this.$num0.text = '' + Math.round(cBytes[0] * 255); this.$num1.text = '' + Math.round(cBytes[1] * 255); this.$num2.text = '' + Math.round(cBytes[2] * 255); this.$num3.text = hsba[3].toFixed(3); } // var tempMode = mode.indexOf('A') < 0 ? mode + 'A' : mode; // var tempColor = Color['hsbaTo' + tempMode](hsba); // this.$textContainer.value = Color[mode.toLocaleLowerCase() + 'ToText'](tempColor); } }; ColorPicker.eventHandler = {}; ColorPicker.eventHandler.colorPointerDown = function (event) { var newSV = this._getSVOfEvent(event); this.saturation = newSV.s; this.brightness = newSV.b; absol.$(document.body) .on('pointermove', this.eventHandler.colorPointerMove) .on('pointerup', this.eventHandler.colorPointerFinish) .on('pointerleave', this.eventHandler.colorPointerFinish); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.colorPointerFinish = function (event) { absol.$(document.body) .off('pointermove', this.eventHandler.colorPointerMove) .off('pointerup', this.eventHandler.colorPointerFinish) .off('pointerleave', this.eventHandler.colorPointerFinish); }; ColorPicker.eventHandler.colorPointerMove = function (event) { var newSV = this._getSVOfEvent(event); this.saturation = newSV.s; this.brightness = newSV.b; event.preventDefault(); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.huePointerDown = function (event) { var newH = this._getHOfEvent(event); this.hue = newH; event.preventDefault(); absol.$(document.body) .on('pointermove', this.eventHandler.huePointerMove) .on('pointerup', this.eventHandler.huePointerFinish) .on('pointerleave', this.eventHandler.huePointerFinish); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.huePointerFinish = function (event) { absol.$(document.body) .off('pointermove', this.eventHandler.huePointerMove) .off('pointerup', this.eventHandler.huePointerFinish) .off('pointerleave', this.eventHandler.huePointerFinish); event.preventDefault(); }; ColorPicker.eventHandler.huePointerMove = function (event) { var newH = this._getHOfEvent(event); this.hue = newH; event.preventDefault(); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.alphaPointerDown = function (event) { var newA = this._getAOfEvent(event); this.alpha = newA; absol.$(document.body) .on('pointermove', this.eventHandler.alphaPointerMove) .on('pointerup', this.eventHandler.alphaPointerFinish) .on('pointerleave', this.eventHandler.alphaPointerFinish); event.preventDefault(); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.alphaPointerFinish = function (event) { absol.$(document.body) .off('pointermove', this.eventHandler.alphaPointerMove) .off('pointerup', this.eventHandler.alphaPointerFinish) .off('pointerleave', this.eventHandler.alphaPointerFinish); event.preventDefault(); }; ColorPicker.eventHandler.alphaPointerMove = function (event) { var newA = this._getAOfEvent(event); this.alpha = newA; event.preventDefault(); this.emit('change', { target: this, originEvent: event, value: this.value }); }; ColorPicker.eventHandler.modeClick = function (event) { this.mode = this.switchMode[this.mode]; event.preventDefault(); }; ColorPicker.eventHandler.inputBlur = function () { var mode = this.mode; var alpha = 1; if (mode.match(/A$/)) { alpha = parseFloat(this.$num3.text); } var bytes; if (mode.match(/^H/)) { bytes = [parseFloat(this.$num0.text) / 360, parseFloat(this.$num1.text) / 100, parseFloat(this.$num2.text) / 100, alpha]; } else if (mode.match(/^RGB/)) { bytes = [parseFloat(this.$num0.text) / 255, parseFloat(this.$num1.text) / 255, parseFloat(this.$num2.text) / 255, alpha]; } var hsba = mode.match(/^HSB/) ? bytes : Color_Color/* default */.Z[(mode.match(/A$/) ? mode.toLocaleLowerCase() : mode.toLocaleLowerCase() + 'a') + 'ToHSBA'](bytes); this.hue = hsba[0]; this.saturation = hsba[1]; this.brightness = hsba[2]; this.alpha = hsba[3]; }; ACore/* default.install */.Z.install('ColorPicker'.toLowerCase(),ColorPicker); /* harmony default export */ const colorpicker_ColorPicker = ((/* unused pure expression or super */ null && (ColorPicker))); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/colorpicker/ColorPickerButton.js var ColorPickerButton_isMobile = BrowserDetector/* default.isMobile */.Z.isMobile; /*** * @extends AElement * @constructor */ function ColorPickerButton() { if (!ColorPickerButton.css) { ColorPickerButton.css = new DynamicCSS/* default */.Z() .setProperty('.as-color-cell.as-color-picker-button-inner.as-null .as-color-cell-value', 'background-image', `url("data:image/svg+xml;base64,${(0,base64.base64EncodeUnicode)(red_cross.replace(/\$width/g, '33').replace(/\$height/g, '18'))}")`) .commit(); } this.mode = 'OBJECT'; this.$innerValue = (0,ACore.$)('.as-color-picker-button-inner', this); this.prepare(); this.on('click', this.eventHandler.click); /*** * @name value * @type {string|Color} * @memberOf ColorPickerButton# */ /*** * @name hasOpacity * @type {boolean} * @memberOf ColorPickerButton# */ /*** * @name nullable * @type {boolean} * @memberOf ColorPickerButton# */ /*** * @name readOnly * @type {boolean} * @memberOf ColorPickerButton# */ } ColorPickerButton.tag = 'ColorPickerButton'.toLowerCase(); ColorPickerButton.prototype.supportedModes = ['OBJECT', 'RGBA', 'RGB', 'HEX8', 'HEX6', 'HEX4', 'HEX3']; ColorPickerButton.prototype.hasOpacityModes = ['OBJECT', 'RGBA', 'HEX8', 'HEX4']; ColorPickerButton.eventHandler = {}; ColorPickerButton.eventHandler.click = function (event) { this.togglePicker(); }; ColorPickerButton.eventHandler.changeColor = function (event) { this._value = event.value; this.$innerValue.value = event.value; this.emit('change', event, this); }; ColorPickerButton.eventHandler.clickBody = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this, event) || EventEmitter/* default.hitElement */.ZP.hitElement(this.$ColorPicker, event)) return; this.closePicker(); }; ColorPickerButton.eventHandler.submit = function (event) { this.closePicker(); }; ColorPickerButton.prototype.togglePicker = function () { if (this.hasClass('as-color-picker-selecting')) { this.closePicker(); } else { this.openPicker(); } }; ColorPickerButton.prototype.openPicker = function () { if (this.readOnly) return; if (this.hasClass('as-color-picker-selecting')) return; if (ColorPickerButton.lastOpen) { ColorPickerButton.lastOpen.closePicker(); } ColorPickerButton.lastOpen = this; var thisBt = this; this.addClass('as-color-picker-selecting'); this.$ColorPicker.on('change', this.eventHandler.changeColor) .on('submit', this.eventHandler.submit); this.$ColorPicker.reloadSetting(); this.$follower.addStyle('visibility', 'hidden'); this.$follower.addTo(document.body); if (ColorPickerButton.$ColorPicker.$attachhook) {//prevent stuck setTimeOut ColorPickerButton.$ColorPicker.$attachhook.emit('attached'); } this.$follower.followTarget = this; this.$follower.sponsorElement = this; setTimeout(function () { document.addEventListener('click', this.eventHandler.clickBody); }.bind(this), 100); this._lastValue = this.value; this.$ColorPicker.nullable = this.nullable; this.$ColorPicker.hasOpacity = this.hasOpacity; ColorPickerButton.$ColorPicker.value = this.value; setTimeout(function () { thisBt.$follower.removeStyle('visibility'); }, 1); //10p }; ColorPickerButton.prototype.closePicker = function () { if (!this.hasClass('as-color-picker-selecting')) return; this.removeClass('as-color-picker-selecting'); if (ColorPickerButton.lastOpen === this) { ColorPickerButton.lastOpen = null; this.$follower.selfRemove(); } this.$ColorPicker.off('change', this.eventHandler.changeColor) .off('submit', this.eventHandler.submit); document.removeEventListener('click', this.eventHandler.clickBody); if (this.value !== this._lastValue) { this.emit('stopchange', { target: this, value: this.value }, this); } }; ColorPickerButton.prototype.prepare = function () { if (!ColorPickerButton.$ColorPicker) { if (ColorPickerButton_isMobile) { ColorPickerButton.$follower = (0,ACore._)('modal').on('click', function (event) { if (event.tagert === this) { if (ColorPickerButton.lastOpen) ColorPickerButton.lastOpen.closePicker(); } }); } else { ColorPickerButton.$follower = (0,ACore._)('follower.as-color-picker-button-follower'); ColorPickerButton.$follower.cancelWaiting(); } ColorPickerButton.$ColorPicker = (0,ACore._)({ tag: 'solidcolorpicker' }).addTo(ColorPickerButton.$follower); if (ColorPickerButton.$ColorPicker.$attachhook) {//prevent stuck setTimeOut ColorPickerButton.$ColorPicker.$attachhook.cancelWaiting(); } ColorPickerButton.lastOpen = null; } this.$follower = ColorPickerButton.$follower; this.$ColorPicker = ColorPickerButton.$ColorPicker; }; ColorPickerButton.render = function () { return (0,ACore._)({ tag: 'button', extendEvent: ['change', 'stopchange'], class: 'as-color-picker-button', child: [ { tag: ColorCell, class: "as-color-picker-button-inner", } ] }); }; ColorPickerButton.property = {}; ColorPickerButton.property.value = { set: function (value) { this._value = value; this.$innerValue.value = value || null; }, get: function () { var nullable = this.nullable; var value = this._value; if (!this._value && nullable) return value;//null, "" if (!this._value && !nullable) { value = new Color_Color/* default */.Z([0, 0, 0, 1]); } if (this.mode.match(/HEX4|HEX6|HEX8|RGB|RGBA/) && value && value.toHex3) { value = this._value.toString(this.mode); } return value; } }; ColorPickerButton.property.mode = { set: function (value) { value = value || 'OBJECT'; value = value.toUpperCase(); if (this.supportedModes.indexOf(value) < 0) value = 'OBJECT'; this.attr('data-mode', value); this._mode = value; }, get: function () { return this._mode; } }; ColorPickerButton.property.hasOpacity = { get: function () { return this.hasOpacityModes.indexOf(this._mode) >= 0; } }; ColorPickerButton.property.nullable = { set: function (value) { if (value) { this.addClass('as-nullable'); } else { this.removeClass('as-null-nullable'); } }, get: function () { return this.hasClass('as-nullable'); } }; ColorPickerButton.property.readOnly = { set: function (value) { if (value) { this.addClass('as-readonly'); } else { this.removeClass('as-readonly'); } }, get: function () { return this.hasClass('as-readonly'); } }; ACore/* default.install */.Z.install(ColorPickerButton); /* harmony default export */ const colorpicker_ColorPickerButton = (ColorPickerButton); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/colorpicker/SelectColorSchemeMenu.js var SelectColorSchemeMenu = __webpack_require__(5830); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/progressbar.css var progressbar = __webpack_require__(9862); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ProgressCircle.js var ProgressCircle_ = ACore/* default._ */.Z._; var ProgressCircle_$ = ACore/* default.$ */.Z.$; function ProgressCircle() { this._text = 'Loading\n$value'; this._value = 0; this._variant = null; this._viewValue = 0; this.$pie = ProgressCircle_$('.as-progress-circle-pie', this); this.$inner = ProgressCircle_$('.as-progress-circle-inner', this); this.$end = ProgressCircle_$('.as-progress-circle-end', this); this.$text = ProgressCircle_$('.as-progress-circle-text', this); this._animated = true; } ProgressCircle.tag = 'ProgressCircle'.toLowerCase(); ProgressCircle.render = function () { return ProgressCircle_({ class: 'as-progress-circle', child: [ '.as-progress-circle-start', '.as-progress-circle-pie', '.as-progress-circle-end', { class: 'as-progress-circle-inner', child: { class: 'as-progress-circle-text', child: { text: '' } } } ] // child: { // class: 'as-progress-bar-value' // } }); }; ProgressCircle.property = {}; ProgressCircle.prototype._updateValue = function () { if (Math.abs(this._value - this._viewValue) < 0.05 || !this._animated) this._viewValue = this._value; else { if (this._value > this._viewValue) this._viewValue += 0.05; else this._viewValue -= 0.05; } var value = this._viewValue; var angle = Math.PI * (-0.5 + value * 2); var cosAngle = Math.cos(angle); var sinAngle = Math.sin(angle); var pl = 'polygon(50% 0%, 100% 0%, '; if (value >= 0.25) pl += '100% 100%, '; if (value >= 0.5) pl += '0% 100%, '; if (value >= 0.75) pl += '0% 0%, '; pl += `${50 + 50 * cosAngle}% ${50 + 50 * sinAngle}%`; pl += ', 50% 50%)'; this.$pie.addStyle('clipPath', pl); this.$end.addStyle({ left: `calc(${50 + 50 * cosAngle}% - ${(cosAngle + 1) * 0.8/2}em)`, top: `calc(${50 + 50 * sinAngle}% - ${(sinAngle + 1) * 0.8/2}em)` }); if (this._value !== this._viewValue) { requestAnimationFrame(() => this._updateValue()); } } ProgressCircle.prototype._updateText = function () { var value = this._value; var text = this._text; text = text.replace('$value', Math.round(value * 100) + '%'); this.$text.firstChild.data = text; }; /** * @type {ProgressCircle} */ ProgressCircle.property.variant = { set: function (value) { if (this._variant) { this.removeClass('as-variant-' + this._variant); } if (value) { this.addClass('as-variant-' + value) } else { value = null; } this._variant = value; }, get: function () { return this._variant; } }; ProgressCircle.property.value = { /** * @this ProgressCircle * @param value */ set: function (value) { value = Math.max(0, Math.min(1, value || 0)); this._value = value; this._updateValue(); this._updateText(); }, get: function () { return this._value; } }; ProgressCircle.property.text = { set: function (value) { value = value || ''; if (typeof value !== "string") value = ''; this._text = value; this._updateText(); }, get: function () { return this._text; } } ProgressCircle.property.animated = { set: function (value) { value = !!value; this._animated = value; if (value) { this.addClass('as-animated'); } else { this.removeClass('as-animated'); } }, get: function () { return this._animated; } } ACore/* default.install */.Z.install(ProgressCircle); /* harmony default export */ const js_ProgressCircle = (ProgressCircle); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/expressioninput.css var expressioninput = __webpack_require__(3386); // EXTERNAL MODULE: ./node_modules/absol/src/SCLang/SCGrammar.js var SCGrammar = __webpack_require__(3224); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParser.js + 1 modules var DPParser = __webpack_require__(3281); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParseInstance.js var DPParseInstance = __webpack_require__(56); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ExpressionInput.js /*** * @extends PositionTracker * @constructor */ function ExpressionInput() { this.domSignal = new DelaySignal/* default */.Z(); this.$rangeCtn = (0,ACore.$)('.as-expression-input-range-ctn', this); this.$content = (0,ACore.$)('.as-expression-input-content', this); this.$iconCtn = (0,ACore.$)('.as-expression-input-icon-ctn', this); // this.$forground = $('.as-expression-input-foreground', this); /** * * @type {null|AElement} */ this.$icon = null; this.$alertIcon = (0,ACore.$)('.mdi.mdi-alert-circle', this.$iconCtn); this.engine = new EIEngine(this); this.userActionCtrl = new EIUserActionController(this); // this.selection = new EISelection(this); this.autoCompleteCtrl = new EIAutoCompleteController(this); this.undoMgn = new EIUndoManager(this); this.cmdTool = new EICommandTool(this); this._icon = null; /**** * @name value * @type {string} * @memberOf ExpressionInput# */ /** * @type {{variables: string[], functions: string[], sampleJS?:{getFunctions: function(): string[], getVariables: function(): string[]}}} * @memberOf ExpressionInput# * @name autocomplete */ /** * @type {*} * @memberOf ExpressionInput# * @name icon */ } ExpressionInput.tag = 'ExpressionInput'.toLowerCase(); ExpressionInput.render = function () { return (0,ACore._)({ tag: js_PositionTracker, extendEvent: ['stopchange', 'blur', 'focus'], class: ['as-expression-input'], child: [ { class: 'as-expression-input-icon-ctn', child: ['span.mdi.mdi-alert-circle'] }, { class: 'as-expression-input-content', attr: { contenteditable: 'true', spellcheck: 'false' } }//, // { class: 'as-expression-input-range-ctn' }, ] }); }; ExpressionInput.prototype.requestUpdateSize = function () { if (this.cmdTool && this.cmdTool.$ctn && this.cmdTool.$ctn.parentElement) { this.cmdTool.$ctn.updatePosition(); } }; ExpressionInput.prototype.notifySizeCanBeChanged = function () { var bound = this.getBoundingClientRect(); if (!this._prevSize || this._prevSize.width !== bound.width || this._prevSize.height !== bound.height) { ResizeSystem/* default.updateUp */.Z.updateUp(this, true); } this._prevSize = { width: bound.width, height: bound.height }; }; ExpressionInput.prototype.revokeResource = function () { (0,utils.revokeResource)(this.engine); (0,utils.revokeResource)(this.autoCompleteCtrl); (0,utils.revokeResource)(this.undoMgn); (0,utils.revokeResource)(this.cmdTool); (0,utils.revokeResource)(this.domSignal); }; ExpressionInput.prototype.focus = function () { this.$content.focus(); this.engine.setSelectedPosition(this.engine.value.length); }; ExpressionInput.property = {}; ExpressionInput.property.readOnly = { set: function (value) { if (value) { this.addClass('as-read-only'); this.$content.removeAttribute('contenteditable'); } else { this.removeClass('as-read-only'); if (!this.hasClass('as-disabled')) { this.$content.setAttribute('contenteditable', 'true'); } } }, get: function () { return this.hasClass('as-read-only'); } }; ExpressionInput.property.disabled = { set: function (value) { if (value) { this.addClass('as-disabled'); this.$content.removeAttribute('contenteditable'); } else { this.removeClass('as-disabled'); if (!this.hasClass('as-read-only')) { this.$content.setAttribute('contenteditable', 'true'); } } }, get: function () { return this.hasClass('as-disabled'); } } ExpressionInput.property.value = { get: function () { return this.engine.value; }, set: function (value) { this.engine.value = value; this.undoMgn.reset(); } }; ExpressionInput.property.icon = { /** * @this ExpressionInput * @param value */ set: function (value) { if (this.$icon) this.$icon.remove(); this.$iconCtn.clearChild(); var elt; if ((0,Dom/* isDomNode */.mV)(value)) { if (value.parentElt) value = value.cloneNode(true); elt = value; } else if (value && (typeof value === 'string' || typeof value === 'object')) { if (value === 'default') value = 'span.mdi.mdi-equal'; elt = (0,ACore._)(value); } if (elt) { this.$iconCtn.addChild(elt); this.$icon = elt; this.addClass('as-has-icon'); } else { this.$icon = null; value = null; this.removeClass('as-has-icon'); } this._icon = value; }, get: function () { return this._icon; } }; /*** * @memberOf ExpressionInput# * @type {{}} */ ExpressionInput.eventHandler = {}; ACore/* default.install */.Z.install(ExpressionInput); /* harmony default export */ const js_ExpressionInput = (ExpressionInput); /** * * @param {ExpressionInput} elt * @constructor */ function EIUserActionController(elt) { this.elt = elt; this.$content = elt.$content; this._stopChangeTO = -1; /** * * @type {EIEngine} */ this.engine = elt.engine; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.elt.on('stopchange', () => { this.elt.undoMgn.commit(); this.elt.engine.highlightError(); }); this.$content.on({ cut: this.ev_cut, blur: this.ev_blur, focus: this.ev_focus, paste: this.ev_paste, keydown: this.ev_keydown }); } EIUserActionController.prototype.delayNotifyStopChange = function () { if (this._stopChangeTO > 0) { clearTimeout(this._stopChangeTO); } this._stopChangeTO = setTimeout(function () { this._stopChangeTO = -1; this.elt.emit('stopchange', {}, this.elt); }.bind(this), 200); }; EIUserActionController.prototype.ev_keydown = function (event) { var key = (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event); if (key.match(/^[a-zA-Z0-9]$/)) { this.elt.engine.requestRedrawTokens(); setTimeout(() => { this.elt.autoCompleteCtrl.openDropdownIfNeed(); if (this.elt.autoCompleteCtrl.isOpen) { this.elt.autoCompleteCtrl.updateDropDownContent(); } }, 200); } else if (key === 'enter') { event.preventDefault(); if (this.elt.autoCompleteCtrl.isSelecting()) { this.elt.autoCompleteCtrl.applySelectingSuggestion(); } else { this.engine.breakLine(); } } else if (key === 'arrowleft' || key === 'arrowright' || key.match(/^[^a-zA-Z0-9]$/)) { this.elt.autoCompleteCtrl.closeDropdownIfNeed(); } else if (key === 'arrowup' || key === 'arrowdown') { if (this.elt.autoCompleteCtrl.isSelecting()) { event.preventDefault(); this.elt.autoCompleteCtrl.moveSelectingSuggestion(key === 'arrowup' ? 'up' : 'down'); } } else if (key === 'ctrl-space') { this.engine.redrawTokens(); this.elt.autoCompleteCtrl.openDropdown(); } else if (key === 'escape') { if (this.elt.autoCompleteCtrl.isOpen) { this.elt.autoCompleteCtrl.closeDropdown(); event.preventDefault(); } } else if (key === 'ctrl-z') { event.preventDefault(); this.elt.undoMgn.undo(); } else if (key === 'ctrl-y') { event.preventDefault(); this.elt.undoMgn.redo(); } else if ((event.ctrlKey && event.key === 'X') || (!event.ctrlKey && event.key.length === 1) || event.key === 'Delete' || event.key === 'Backspace') { this.elt.engine.requestRedrawTokens(); setTimeout(() => { this.elt.autoCompleteCtrl.openDropdownIfNeed(); if (this.elt.autoCompleteCtrl.isOpen) { this.elt.autoCompleteCtrl.updateDropDownContent(); } }, 200); } this.delayNotifyStopChange(); setTimeout(() => { this.elt.notifySizeCanBeChanged(); }, 1); }; EIUserActionController.prototype.ev_paste = function (event) { var paste = (event.clipboardData || window.clipboardData).getData('text'); paste = paste.replace(/[\r\n]+/g, ' '); event.preventDefault(); var pos = this.elt.engine.getSelectPosition(); if (!pos || !paste) return; var value = this.elt.value; this.elt.engine.value = value.substring(0, pos.start) + paste + value.substring(pos.end); this.elt.engine.setSelectedPosition(pos.start + paste.length); this.elt.engine.highlightError(); this.elt.notifySizeCanBeChanged(); }; EIUserActionController.prototype.ev_cut = function (event) { this.elt.domSignal.emit('redrawTokens'); this.delayNotifyStopChange(); this.elt.notifySizeCanBeChanged(); }; EIUserActionController.prototype.ev_focus = function (event) { this.elt.engine.clearErrorHighlight(); setTimeout(function () { //todo this.elt.engine.getSelectPosition(); }.bind(this), 100); }; EIUserActionController.prototype.ev_blur = function (event) { this.elt.engine.highlightError(); }; EIUserActionController.prototype.ev_dragInit = function (event) { }; /** * * @param {ExpressionInput} elt * @constructor */ function EIEngine(elt) { this.elt = elt; this.lastSelectedPosition = { start: 0, end: 0, direction: 'forward' }; this.$content = elt.$content; /** * * @type {null|Range} */ this.range = null; this.elt.domSignal.on('redrawTokens', this.redrawTokens.bind(this)); for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this._isListenSelectionChange = false; this.$content.on('focus', this.ev_focus); } EIEngine.prototype.ev_focus = function () { if (!this._isListenSelectionChange) { document.addEventListener('selectionchange', this.ev_range); this._isListenSelectionChange = true; } }; EIEngine.prototype.ev_range = function () { if (!this.elt.isDescendantOf(document.body)) { document.removeEventListener('selectionchange', this.ev_range); this._isListenSelectionChange = false; } this.updateRange(); }; EIEngine.prototype.revokeResource = function () { if (this._isListenSelectionChange) { document.removeEventListener('selectionchange', this.ev_range); this._isListenSelectionChange = false; } }; EIEngine.prototype.requestRedrawTokens = function () { this.elt.domSignal.emit('redrawTokens'); } EIEngine.prototype.highlightError = function () { var elt = this.elt; var contentElt = this.$content; var value = elt.value.trim(); var it = EIParser.parse(value, 'exp'); var i, notSkipCount = 0; var tokenErrorIdx = -1; if (value && it.error) { elt.addClass('as-error'); elt.attr('title', it.error.message); tokenErrorIdx = it.error.tokenIdx; } else { elt.removeClass('as-error'); } for (i = 0; i < contentElt.childNodes.length; ++i) {//todo: fix conflict (run before redraw) if (contentElt.childNodes[i].getAttribute &&contentElt.childNodes[i].classList.contains('as-token') && contentElt.childNodes[i].getAttribute('data-type') !== 'skip') { if (notSkipCount === tokenErrorIdx) { contentElt.childNodes[i].classList.add('as-unexpected-token'); } else { contentElt.childNodes[i].classList.remove('as-unexpected-token'); } notSkipCount++; } } }; EIEngine.prototype.clearErrorHighlight = function () { var contentElt = this.$content; for (var i = 0; i < contentElt.length; ++i) { if (contentElt.childNodes[i].classList.contains('as-token') && contentElt.childNodes[i].getAttribute('data-type') !== 'skip') { contentElt.childNodes[i].classList.remove('as-unexpected-token'); } } }; EIEngine.prototype.drawTokensContent = function () { var selectedPos = this.getSelectPosition(); var value = this.value; var tokens = EIParser.tokenizer.tokenize(value); var tokenEltChain = Array.prototype.slice.call(this.$content.childNodes); while (tokenEltChain[tokenEltChain.length - 1] && tokenEltChain[tokenEltChain.length - 1].tagName === 'BR') { tokenEltChain.pop(); } var leftPassed = 0; while (leftPassed < tokenEltChain.length && leftPassed < tokens.length) { if (!tokenEltChain[leftPassed].firstChild || !tokenEltChain[leftPassed].classList.contains('as-token') || tokens[leftPassed].content !== tokenEltChain[leftPassed].firstChild.data) break; if (!tokenEltChain[leftPassed].token || tokenEltChain[leftPassed].getAttribute('data-type') !== tokens[leftPassed].type) { tokenEltChain[leftPassed].setAttribute('data-type', tokens[leftPassed].type); } leftPassed++; } var rightPassed = 0; while (rightPassed < tokenEltChain.length && rightPassed < tokens.length) { if (!tokenEltChain[tokenEltChain.length - 1 - rightPassed].firstChild || !tokenEltChain[tokenEltChain.length - 1 - rightPassed].classList.contains('as-token') || tokens[tokens.length - 1 - rightPassed].content !== tokenEltChain[tokenEltChain.length - 1 - rightPassed].firstChild.data) break; if (tokenEltChain[tokenEltChain.length - 1 - rightPassed].getAttribute('data-type') !== tokens[tokens.length - 1 - rightPassed].type) { tokenEltChain[tokenEltChain.length - 1 - rightPassed].setAttribute('data-type', tokens[tokens.length - 1 - rightPassed].type); } rightPassed++; } var beforeToken; if (leftPassed + rightPassed < Math.max(tokenEltChain.length, tokens.length)) { beforeToken = tokenEltChain[tokenEltChain.length - rightPassed]; tokenEltChain.splice(leftPassed, tokenEltChain.length - leftPassed - rightPassed).forEach(function (elt) { elt.remove(); }); tokens.slice(leftPassed, tokens.length - rightPassed).forEach(function (token) { var tokenElt = this.makeTokenElt(token); if (beforeToken) { this.$content.addChildBefore(tokenElt, beforeToken); } else { this.$content.addChild(tokenElt); } }.bind(this)); } if (selectedPos) this.setSelectedPosition(selectedPos); }; EIEngine.prototype.updateTokenExType = function () { /** * @type {HTMLElement[]} */ var tokenEltChain = Array.prototype.slice.call(this.$content.childNodes); var token, nextToken; var i, j; for (i = 0; i < tokenEltChain.length; ++i) { token = tokenEltChain[i]; if (this.isTextNode(token)) continue; if (token.innerText === "true" || token.innerText === "false") { token.setAttribute('data-ex-type', 'boolean'); } else if (token.getAttribute('data-type') === 'word') { j = i + 1; nextToken = tokenEltChain[i + 1]; while (nextToken) { if (nextToken.getAttribute('data-type') === 'symbol' && nextToken.innerText === '(') { token.setAttribute('data-ex-type', 'function'); break; } else if (nextToken.getAttribute('data-type') === 'skip') { nextToken = tokenEltChain[++j]; } else { break; } } } else { token.removeAttribute('data-ex-type'); } } }; EIEngine.prototype.redrawTokens = function () { this.drawTokensContent(); this.updateTokenExType(); this.elt.notifySizeCanBeChanged(); }; /** * * @param {{type: string, content: string}} token * @returns {*} */ EIEngine.prototype.makeTokenElt = function (token) { if (token.content === '\n') return (0,ACore._)('br'); return (0,ACore._)({ tag: 'span', class: ['as-token'], attr: { 'data-type': token.type }, child: { text: token.content } }); }; EIEngine.prototype.insertText = function (text) { var lastPos = this.getSelectPosition(); var value; if (this.lastSelectedPosition) { value = this.elt.value; this.value = value.substring(0, lastPos.start) + text + value.substring(lastPos.end); this.lastSelectedPosition = Object.assign({ direction: 'forward', start: lastPos.start + text.length, end: lastPos.start + text.length }); if (document.activeElement === this.elt.$content) { this.setSelectedPosition(this.lastSelectedPosition); } } else this.appendText(text); this.elt.userActionCtrl.delayNotifyStopChange(); }; EIEngine.prototype.appendText = function (text) { var newValue = this.value + text; this.value = newValue; if (document.activeElement === this.$content) { this.setSelectedPosition(newValue.length); } this.elt.userActionCtrl.delayNotifyStopChange(); }; EIEngine.prototype.isValidRange = function (range) { return AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(range.startContainer, this.$content) && AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(range.endContainer, this.$content); }; EIEngine.prototype.updateRange = function () { var sel = window.getSelection(); var range; for (var i = 0; i < sel.rangeCount; ++i) { range = sel.getRangeAt(i); if (this.isValidRange(range)) this.range = range; } }; EIEngine.prototype.isTextNode = function (node) { return node.nodeType === Node.TEXT_NODE; }; EIEngine.prototype.isWordToken = function (node) { if (this.isTextNode(node)) return false; return node.getAttribute('data-type') === 'word'; }; EIEngine.prototype.isSymbolToken = function (node) { if (this.isTextNode(node)) return false; return node.getAttribute('data-type') === 'symbol'; }; EIEngine.prototype.isMemberSymbolToken = function (node) { return this.isSymbolToken(node) && node.innerText === '->'; }; EIEngine.prototype.isSkipToken = function (node) { if (this.isTextNode(node)) return false; return node.getAttribute('data-type') === 'skip'; } EIEngine.prototype.getRange = function () { this.updateRange(); return this.range; }; /** * * @param {Range} range */ EIEngine.prototype.setRange = function (range) { this.range = range; var sel = window.getSelection(); sel.removeAllRanges(); sel.addRange(range); }; EIEngine.prototype.childIndexOf = function (node) { if (!node.parentElement) return 0; return Array.prototype.indexOf.call(node.parentElement.childNodes, node); }; EIEngine.prototype.lcaOf = function (nd1, nd2) { var track1 = []; var track2 = []; var rootNode = this.elt; while (nd1 && (nd1 !== rootNode)) { track1.unshift(nd1); nd1 = nd1.parentElement; } while (nd2 && (nd2 !== rootNode)) { track2.unshift(nd2); nd2 = nd2.parentElement; } var res = null; for (var i = 0; i < track1.length && i < track2.length; ++i) { if (track1[i] === track2[i]) res = track1[i]; else break; } return res; }; EIEngine.prototype.trimLeft = function (nd, ofs) { if (this.isTextNode(nd)) { nd.data = nd.data.substring(ofs); } else { for (var i = 0; i < ofs; ++i) { nd.removeChild(nd.firstChild); } } }; EIEngine.prototype.trimRight = function (nd, ofs) { if (this.isTextNode(nd)) { nd.data = nd.data.substring(0, ofs); } else { while (nd.childNodes.length > ofs) { nd.removeChild(nd.lastChild); } } }; EIEngine.prototype.breakTextNode = function (textNode, offset) { var parent = (0,ACore.$)(textNode.parentElement); var text = textNode.data; var newTextNode = (0,ACore._)({ text: text.substring(offset) }); textNode.data = text.substring(0, offset); parent.addChildAfter(newTextNode, textNode); return newTextNode; }; EIEngine.prototype.breakElement = function (elt, offset) { var parent = (0,ACore.$)(elt.parentElement); var newElt = elt.cloneNode(false); var rightChildren = Array.prototype.slice.call(elt.childNodes, offset); for (var i = 0; i < rightChildren.length; ++i) { newElt.appendChild(rightChildren[i]); } parent.addChildAfter(newElt, elt); return newElt; }; EIEngine.prototype.breakNode = function (node, offset) { if (this.isTextNode(node)) { return this.breakTextNode(node, offset); } else { return this.breakElement(node, offset); } }; EIEngine.prototype.breakLine = function () { var range = this.getRange(); if (!range) return; var startCtn = range.startContainer; var endCtn = range.endContainer; var startOfs = range.startOffset; var endOfs = range.endOffset; var newNd; var lcaNd = this.lcaOf(startCtn, endCtn); while (startCtn !== lcaNd) { this.trimRight(startCtn, startOfs); startOfs = this.childIndexOf(startCtn) + 1; startCtn = startCtn.parentElement; } while (endCtn !== lcaNd) { this.trimLeft(endCtn, endOfs); endOfs = this.childIndexOf(endCtn); endCtn = endCtn.parentElement; } if (this.isTextNode(startCtn)) { newNd = startCtn.parentElement.cloneNode(false); newNd.appendChild((0,ACore._)({ text: startCtn.data.substring(0, startOfs) })); startCtn.parentElement.parentElement.insertBefore(newNd, startCtn.parentElement); startCtn.data = startCtn.data.substring(endOfs); newNd = (0,ACore._)('br'); startCtn.parentElement.parentElement.insertBefore(newNd, startCtn.parentElement); startCtn = newNd.parentElement; startOfs = this.childIndexOf(newNd) + 1; endCtn = startCtn; endOfs = startOfs; } else if (startCtn === this.$content) { Array.prototype.slice.call(startCtn.childNodes, startOfs, endOfs - 1).forEach(nd => nd.remove()); newNd = (0,ACore._)('br'); startCtn.insertBefore(newNd, startCtn.childNodes[startOfs]); endOfs = startOfs + 1; startOfs = endOfs; } else { endCtn = this.breakElement(startCtn, startOfs); endOfs -= startCtn; if (endOfs >= 0) { newNd = this.breakElement(endCtn, endOfs); endCtn.remove(); endCtn = newNd; endOfs = 0; } newNd = (0,ACore._)('br'); endCtn.parentElement.insertBefore(newNd, endCtn); startCtn = newNd.parentElement; startOfs = this.childIndexOf(newNd) + 1; endCtn = startCtn; endOfs = startOfs; } var childNodes = Array.prototype.slice.call(this.$content.childNodes); var nd; for (var i = 0; i < childNodes.length; ++i) { nd = childNodes[i]; if (nd.tagName === 'BR') continue; if (this.stringOf(nd).length === 0) { if (AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(startCtn, nd)) { startCtn = this.$content; startOfs = this.childIndexOf(nd); } if (AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(endCtn, nd)) { endCtn = this.$content; endOfs = this.childIndexOf(nd); } nd.remove(); } } range = document.createRange(); range.setStart(startCtn, startOfs); range.setEnd(endCtn, endOfs); this.setRange(range); }; EIEngine.prototype.domRange2SelectPosition = function (range) { var sel = window.getSelection(); if (!range) return null; var direction = 'forward'; if (!range) return null; var cmpPosition = sel.anchorNode.compareDocumentPosition(sel.focusNode); if (cmpPosition === 4) { direction = 'forward'; } else if (cmpPosition === 2) { direction = 'backward' } else if (!cmpPosition && sel.anchorOffset > sel.focusOffset || cmpPosition === Node.DOCUMENT_POSITION_PRECEDING) { direction = 'backward'; } var startOffset = this.getPosition(range.startContainer, range.startOffset); var endOffset = this.getPosition(range.endContainer, range.endOffset); if (isNaN(startOffset)) return null; return { start: startOffset, end: endOffset, direction: direction, startCtn: range.startContainer, startOffset: range.startOffset, endCtn: range.endContainer, endOffset: range.endOffset }; }; EIEngine.prototype.getSelectPosition = function () { var range = this.getRange(); this.lastSelectedPosition = this.domRange2SelectPosition(range) || this.lastSelectedPosition; return this.lastSelectedPosition; }; /** * * @param {null|number|{start: number, end: number}=}pos */ EIEngine.prototype.setSelectedPosition = function (pos) { var start; var end; if (typeof pos === "number") { start = pos; end = pos; } else if (pos === null) { return; } else { start = pos.start; end = pos.end; } var startCtn, startOfs, endCtn, endOfs; var text; text = ''; var visit = (nd) => { var prevText = text; var parent = nd.parentElement; if (this.isTextNode(nd)) { text += nd.data; if (text.length > start && prevText.length <= start) { startCtn = nd; startOfs = start - prevText.length; } if (text.length > end && prevText.length <= end) { endCtn = nd; endOfs = end - prevText.length; } } else if (nd.tagName === 'BR' && parent && parent.lastChild !== nd) { text += '\n'; if (text.length > start && prevText.length <= start) { startCtn = parent; startOfs = this.childIndexOf(nd); } if (text.length > end && prevText.length <= end) { endCtn = parent; endOfs = this.childIndexOf(nd); } } else { for (var i = 0; i < nd.childNodes.length; ++i) { visit(nd.childNodes[i]); } } } visit(this.$content); if (!startCtn) { startCtn = this.$content; startOfs = this.$content.childNodes.length; } if (!endCtn) { endCtn = startCtn; endOfs = startOfs; } var range = document.createRange(); range.setStart(startCtn, startOfs); range.setEnd(endCtn, endOfs); this.setRange(range); }; EIEngine.prototype.getPosition = function (node, offset) { var text = ''; var found = false; var visit = (nd) => { var i; if (found) return; if (nd === node) { if (this.isTextNode(nd)) { text += nd.data.substring(0, offset); } else { for (i = 0; i < nd.childNodes.length && i < offset; ++i) { visit(nd.childNodes[i]); } } found = true; return; } var parent = nd.parentElement; if (nd.tagName === 'BR' && parent && parent.lastChild !== nd) { text += '\n'; } if (this.isTextNode(nd)) { text += nd.data; } else { for (i = 0; i < nd.childNodes.length && !found; ++i) { visit(nd.childNodes[i]); } } } visit(this.$content); return text.length; }; EIEngine.prototype.stringOf = function (node) { if (!node) return ''; if (node.nodeType === 3) { return node.data; } var res = ''; var parent = node.parentElement; if ((node.tagName === 'BR' || node.tagName === 'br') && parent && parent.lastChild !== node) { return '\n'; } else if ((node.tagName === 'DIV' || node.tagName === 'div') && parent && parent.firstChild !== node) { res += '\n'; } return res + Array.prototype.map.call(node.childNodes, (cNode, index, arr) => { return this.stringOf(cNode, node); }).join(''); }; /** * * @param offset * @returns {AElement} */ EIEngine.prototype.tokenAt = function (offset) { var l = 0; var res = null; var nd, i; for (i = 0; i < this.$content.childNodes.length; ++i) { nd = this.$content.childNodes[i]; l += this.stringOf(nd).length; if (l > offset || (i + 1 === this.$content.childNodes.length && l === offset)) { res = nd; break; } } return res; }; /** * * @param {AElement}token * @returns {AElement} */ EIEngine.prototype.findPrefixWordTokenOf = function (token) { if (!token) return null; if (!this.isWordToken(token) && this.stringOf(token) !== '->') return null; var temp = token; var prefixStartElt = null; var state = this.isWordToken(temp) ? 0 : 1;//0: after is word, 1: symbol temp = temp.previousSibling; while (temp) { if (this.isSkipToken(temp)) { temp = temp.previousSibling; continue; } if (state === 0) { if (this.stringOf(temp) === '->') { state = 1; } else break; } else { if (this.isWordToken(temp)) { prefixStartElt = temp; state = 0; } else break; } temp = temp.previousSibling; } return prefixStartElt || null; }; // // EIEngine.prototype.selectCurrentMemberExpression = function () { // var rage = this.getRange(); // if (!rage) return; // var startCtn = rage.startContainer; // var endCtn = rage.endContainer; // var startOfs = rage.startOffset; // var endOfs = rage.endOffset; // // }; Object.defineProperty(EIEngine.prototype, 'value', { get: function () { return Array.prototype.map.call(this.$content.childNodes, nd => this.stringOf(nd)).join(''); }, set: function (value) { var tokens = EIParser.tokenizer.tokenize(value || ''); this.$content.clearChild() .addChild(tokens.map(function (token) { return this.makeTokenElt(token); }.bind(this))); this.updateTokenExType(); this.lastSelectedPosition = { start: value.length, end: value.length, direction: 'forward' }; } }); /** * * @param {ExpressionInput} elt * @constructor */ function EIUndoManager(elt) { this.elt = elt; this.reset(); } /** * * @returns {boolean} is changed value and commit success */ EIUndoManager.prototype.commit = function () { var text = this.elt.value; var range = this.elt.engine.getSelectPosition() || { start: text.length, end: text.length }; var curValue = this.stack[this.idx].value; if (curValue === text) return false; var newItem = { value: text, range: { start: range.start, end: range.end, direction: range.direction || 'forward' } }; while (this.stack.length > this.idx + 1) { this.stack.pop(); } this.idx = this.stack.length; this.stack.push(newItem); return true; }; EIUndoManager.prototype.reset = function () { var value = this.elt.value; this.stack = [{ value: value, range: { start: value.length, end: value.length, direction: "forward" } }]; this.idx = 0; }; EIUndoManager.prototype.undo = function () { if (this.idx <= 0) return; this.idx--; var item = this.stack[this.idx]; this.elt.engine.value = item.value; this.elt.engine.setSelectedPosition(item.range); }; EIUndoManager.prototype.redo = function () { if (this.idx + 1 >= this.stack.length) return; this.idx++; var item = this.stack[this.idx]; this.elt.engine.value = item.value; this.elt.engine.setSelectedPosition(item.range); }; /** * * @param {ExpressionInput} elt * @constructor */ function EIAutoCompleteController(elt) { this.elt = elt; this.$content = elt.$content; this.$tokenTarget = null; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.rawSuggestionCache = { value: null, time: 0 } /** * * @type {EISuggestionList |null} */ this.$suggestionList = null; this.query = null; this.isOpen = false; this.dropIsDown = true; } EIAutoCompleteController.prototype.revokeResource = function () { }; EIAutoCompleteController.prototype.openDropdownIfNeed = function () { if (this.isOpen) return; var query = this.getCurrentSearch(); if (query && query.value && query.value.trim()) { this.openDropdown(); } } /** * */ EIAutoCompleteController.prototype.openDropdown = function () { if (this.isOpen) { this.updateDropDownContent(); return; } if (!this.hasSuggestions()) return; this.isOpen = true; this.dropIsDown = true; if (!this.$suggestionList) { this.$suggestionList = (0,ACore._)({ tag: EISuggestionList, style: { top: '10px', left: '10px', position: 'fixed' }, on: { select: (event) => { this.applySuggestion(event.data); this.closeDropdown(); } } }); } this.$suggestionList.addTo(this.elt); var zIndex = (0,utils.findMaxZIndex)(this.elt) + 1; this.$suggestionList.addStyle('z-index', zIndex + ''); this.$suggestionList.reset(); this.elt.startTrackPosition(); // this.$dropDown.addTo(this.elt); this.$tokenTarget = null; this.updateDropDownContent(); this.updateDropDownPosition(); setTimeout(() => { document.addEventListener('click', this.ev_clickOut); }, 200); }; EIAutoCompleteController.prototype.closeDropdown = function () { if (!this.isOpen) return; this.isOpen = false; this.elt.stopTrackPosition(); this.$suggestionList.remove(); document.removeEventListener('click', this.ev_clickOut); } /** * * @returns {null|{prefix: string, value, tokenElt: HTMLElement, prefixStartElt: HTMLElement}} */ EIAutoCompleteController.prototype.getCurrentSearch = function () { var engine = this.elt.engine; var pos = this.elt.engine.getSelectPosition(); if (!pos) return null;//all var tokenElt = this.elt.engine.tokenAt(pos.start); if (!tokenElt) return null; if (!engine.isWordToken(tokenElt)) { tokenElt = tokenElt.previousSibling; } if (!tokenElt) return null; var temp = tokenElt; while (temp) { if (engine.isSymbolToken(temp)) { if ((engine.stringOf(temp) === '->')) { tokenElt = temp; } else { break; } } else if (engine.isSkipToken(temp)) { } else if (engine.isWordToken(temp)) { tokenElt = temp; } temp = temp.nextSibling; } if (!engine.isWordToken(tokenElt) && !engine.isMemberSymbolToken(tokenElt)) return null; var res = { prefix: '', value: '', tokenElt: null, prefixStartElt: null }; temp = tokenElt; var prefixStartElt = engine.findPrefixWordTokenOf(tokenElt); res.value = engine.stringOf(tokenElt); res.tokenElt = tokenElt; if (prefixStartElt) { res.prefixStartElt = prefixStartElt; temp = prefixStartElt; while (temp !== tokenElt) { if (engine.isSkipToken(temp)) { temp = temp.nextSibling; continue; } res.prefix += engine.stringOf(temp); temp = temp.nextSibling; } } return res; }; EIAutoCompleteController.prototype.getCurrentText = function () { var pos = this.elt.engine.getSelectPosition(); if (!pos) return ''; var res = { value: '', tokenElt: null }; var tokenElt = this.elt.engine.tokenAt(pos.start); if (!tokenElt || !tokenElt.getAttribute || tokenElt.getAttribute('data-type') !== 'word') { res.tokenElt = tokenElt; res.value = ''; tokenElt = null; } if (!tokenElt && pos && pos.start > 0) { tokenElt = this.elt.engine.tokenAt(pos.start - 1); } if (tokenElt && tokenElt.getAttribute && tokenElt.getAttribute('data-type') === 'word') { res.value = tokenElt.innerText; res.tokenElt = tokenElt; } console.log(res); return res; }; EIAutoCompleteController.prototype.updateDropDownContent = function () { if (!this.isOpen) return; this.query = this.getCurrentSearch(); this.$suggestionList.data = this.getSuggestionTree(this.query); this.$suggestionList.selectMaxScoreItem(); this.updateDropDownPosition(); }; EIAutoCompleteController.prototype.updateDropDownPosition = function () { if (!this.isOpen) return; var bound; var targetELt = this.query && this.query.tokenElt; var range = this.elt.engine.getRange(); var selected = this.elt.engine.getSelectPosition(); var dropBound = this.$suggestionList.getBoundingClientRect(); if (targetELt) { bound = targetELt.getBoundingClientRect(); } if (!bound) { bound = range.getBoundingClientRect(); if (!bound.width || !bound.height) bound = null; } if (!bound && selected) { targetELt = this.elt.engine.tokenAt(selected.start); if (targetELt) { bound = targetELt.getBoundingClientRect(); } } if (!bound) { bound = this.elt.$content.getBoundingClientRect(); } var screenHeight = (0,Dom/* getScreenSize */.tE)().height; var aTop = bound.top - 10; var aBottom = screenHeight - bound.bottom - 10; var contentHeight = this.$suggestionList.scrollHeight; if (this.dropIsDown) { if (aBottom < contentHeight && aBottom <= aTop) { this.dropIsDown = false; } } else { if (aTop < contentHeight && aTop <= aBottom) { this.dropIsDown = true; } } var screenSize = (0,Dom/* getScreenSize */.tE)(); this.$suggestionList.addStyle('left', Math.max(0, Math.min(bound.left, screenSize.width - dropBound.width)) + 'px'); this.$suggestionList.addStyle('max-height', this.dropIsDown ? aBottom + 'px' : aTop + 'px'); var listBound; if (this.dropIsDown) { this.$suggestionList.addStyle('top', bound.bottom + 'px'); } else { listBound = this.$suggestionList.getBoundingClientRect(); this.$suggestionList.addStyle('top', (bound.top - listBound.height) + 'px'); } }; EIAutoCompleteController.prototype.getRawSuggestion = function () { var now = Date.now(); if (now - this.rawSuggestionCache.time < 3000) { return this.rawSuggestionCache.value; } var variables = []; var functions = []; var temp; if (this.elt.autocomplete) { temp = this.elt.autocomplete.variables; if (typeof temp === "function") temp = temp(); if (Array.isArray(temp)) { temp = temp.filter(x => typeof x === 'string'); variables = variables.concat(temp); } temp = this.elt.autocomplete.functions; if (typeof temp === "function") temp = temp(); if (Array.isArray(temp)) { temp = temp.filter(x => typeof x === 'string'); functions = functions.concat(temp); } if (this.elt.sampleJS && (typeof this.elt.sampleJS.getFunctions === "function")) { temp = this.elt.sampleJS.getFunctions(); if (Array.isArray(temp)) { temp = temp.filter(x => typeof x === 'string'); functions = functions.concat(temp); } } } variables = (0,DataStructure_Array.arrayUnique)(variables); functions = (0,DataStructure_Array.arrayUnique)(functions); this.rawSuggestionCache.value = { variables: variables, functions: functions } this.rawSuggestionCache.time = now; return this.rawSuggestionCache.value; }; EIAutoCompleteController.prototype.hasSuggestions = function () { var rawSuggestions = this.getRawSuggestion(); return rawSuggestions.variables.length > 0 || rawSuggestions.functions.length > 0; }; /** * * @param {string} text * @param {string} prefix */ EIAutoCompleteController.prototype.getSuggestionList = function (text, prefix) { var res = []; prefix = prefix || ''; text = text || ''; text = text.toLowerCase(); var rawSuggestion = this.getRawSuggestion(); var variables = rawSuggestion.variables; var functions = rawSuggestion.functions; var i; var itemText, score; for (i = 0; i < variables.length; ++i) { itemText = variables[i]; score = (0,stringMatching.phraseMatch)(itemText.toLowerCase(), text); res.push({ text: itemText, score: score, type: 'variable' }); } for (i = 0; i < functions.length; ++i) { itemText = functions[i]; score = (0,stringMatching.phraseMatch)(itemText.toLowerCase(), text); res.push({ text: itemText, score: score, type: 'function' }); } res.sort(function (a, b) { if (a.score === b.score) { return a.text > b.text ? 1 : -1; } return b.score - a.score; }); if (text) res = res.filter(x => x.score > 0); return res; }; EIAutoCompleteController.prototype.computeScore = function (queryWords, itemWords) { if (queryWords.length === 0) return 1; queryWords = queryWords.map(x => x.toLowerCase()); itemWords = itemWords.map(x => x.toLowerCase()); var score = 0; var wordScore = 1 / queryWords.length; var i, j; for (i = 0; i < queryWords.length && i < itemWords.length; ++i) { if (queryWords[i] === itemWords[i]) { score += wordScore; } else { score += wordScore * (0,stringMatching.wordLike)(queryWords[i], itemWords[i]); } } var qDict = queryWords.reduce((ac, cr) => { ac[cr] = true; return ac; }, {}); var iDict = itemWords.reduce((ac, cr) => { ac[cr] = true; return ac; }, {}); var bestMatch, bestWord, curWordScore; queryWords = Object.keys(qDict); itemWords = Object.keys(iDict); for (i = 0; i < queryWords.length; ++i) { bestMatch = 0; bestWord = ''; for (j = 0; j < itemWords.length; ++j) { if (queryWords[i] === itemWords[j]) { bestMatch = wordScore; bestWord = itemWords[j]; break; } else { curWordScore = wordScore * (0,stringMatching.wordLike)(queryWords[i], itemWords[j]); if (curWordScore > bestMatch) { bestMatch = curWordScore; bestWord = itemWords[j]; } } } if (bestWord) { iDict[bestWord] = false; score += bestMatch; } } return score; }; EIAutoCompleteController.prototype.getSuggestionTree = function (query) { var splitWords = (text) => text.split(/[^a-zA-Z0-9_$]+/).filter(x => x.length > 0); var queryWords = query ? splitWords(query.prefix + ' ' + query.value) : []; var rawSuggestion = this.getRawSuggestion(); var variables = rawSuggestion.variables; var functions = rawSuggestion.functions; var items = []; var item; var i; for (i = 0; i < variables.length; ++i) { items.push({ text: variables[i], type: 'variable', words: splitWords(variables[i]) }); } for (i = 0; i < functions.length; ++i) { items.push({ text: functions[i], type: 'function', words: splitWords(functions[i]) }); } var min = Infinity, max = -Infinity; for (i = 0; i < items.length; ++i) { item = items[i]; item.score = this.computeScore(queryWords, item.words); if (item.score < min) min = item.score; if (item.score > max) max = item.score; } var idx; if (query) { for (i = 0; i < items.length; ++i) { item = items[i]; idx = item.text.toLowerCase().indexOf(query.value.toLowerCase()); if (idx >= 0) item.score = max - (idx / 1000); } } items.sort((a, b) => b.score - a.score); var mid = (max + min) / 2; items = items.filter(x => x.score >= mid); var trees = []; var nodeDict = { "*": { text: "", children: trees } }; items.forEach(item => { var words = item.words; var k; var key = ''; var nd; var parent = nodeDict['*']; for (k = 0; k < words.length; ++k) { if (k > 0) key += '->'; key += words[k]; nd = nodeDict[key]; if (!nd) { nd = { text: words[k], children: [], key: key, score: 0 }; nodeDict[key] = nd; parent.children.push(nd); } parent = nd; } parent.item = item; parent.score = item.score; }); return trees; }; EIAutoCompleteController.prototype.applySuggestion = function (suggestion) { var engine = this.elt.engine; var query = this.query; var key = suggestion.key; var words = key.split('->'); var startToken = query && query.prefixStartElt; var endToken = query && query.tokenElt; startToken = startToken || endToken; var range; var rangeStartCtn, rangeStartOffset, rangeEndCtn, rangeEndOffset; var i, tokenElt; var oldValue, newValue; var selected; if (startToken && endToken && engine.isWordToken(startToken) && (engine.isWordToken(endToken) || engine.stringOf(endToken) === '->')) { for (i = 0; i < words.length; ++i) { if (i > 0) { tokenElt = engine.makeTokenElt({ type: 'symbol', content: '->' }); this.elt.$content.insertBefore(tokenElt, startToken); } tokenElt = engine.makeTokenElt({ type: 'word', content: words[i] }); this.elt.$content.insertBefore(tokenElt, startToken); if (i + 1 === words.length) { rangeStartCtn = this.elt.$content; rangeStartOffset = engine.childIndexOf(tokenElt) + 1; rangeEndCtn = rangeStartCtn; rangeEndOffset = rangeStartOffset; } } while (startToken !== endToken) { tokenElt = startToken.nextSibling; startToken.remove(); startToken = tokenElt; } endToken.remove(); range = document.createRange(); range.setStart(rangeStartCtn, rangeStartOffset); range.setEnd(rangeEndCtn, rangeEndOffset); engine.setRange(range); } else { oldValue = this.elt.value; selected = engine.getSelectPosition(); newValue = oldValue.substring(0, selected.start) + key + oldValue.substring(selected.end); this.elt.engine.value = newValue; this.elt.engine.setSelectedPosition(selected.start + key.length); } engine.updateTokenExType(); }; EIAutoCompleteController.prototype.isSelecting = function () { return this.isOpen && this.$suggestionList && this.$suggestionList.$selectedNode && true; }; EIAutoCompleteController.prototype.applySelectingSuggestion = function () { if (this.isSelecting()) { this.applySuggestion(this.$suggestionList.$selectedNode.data); //todo // this.applySuggestion(this.$item[this.selectedIdx].getAttribute('data-suggestion')); this.closeDropdown(); } }; EIAutoCompleteController.prototype.closeDropdownIfNeed = function () { setTimeout(() => { var text = this.getCurrentText(); this.$tokenTarget = text && text.tokenElt; if (this.isOpen) { if (!this.$tokenTarget || this.$tokenTarget.getAttribute('data-type') !== 'word') { this.closeDropdown(); } } }, 5); }; /** * * @param {"down"|"up"} direction * @returns {boolean} */ EIAutoCompleteController.prototype.moveSelectingSuggestion = function (direction) { if (direction !== 'down' && direction !== 'up') return false; if (!this.hasSuggestions()) return false; if (this.isSelecting()) { if (direction === 'down') { return this.$suggestionList.moveToNextSuggestion(); } else { return this.$suggestionList.moveToPrevSuggestion(); } } }; EIAutoCompleteController.prototype.ev_positionChange = function (event) { if (!this.elt.isDescendantOf(document.body)) { this.elt.stopTrackPosition(); return; } //todo }; EIAutoCompleteController.prototype.ev_clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$suggestionList, event)) return; this.closeDropdown(); }; /** * * @param {ExpressionInput} elt * @constructor */ function EICommandTool(elt) { this.elt = elt; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.isOpen = false; this.$ctn = (0,ACore._)({ tag: Follower/* default */.Z, class: 'as-ei-command-tool', props: { anchor: [6, 1] }, child: [ // { // tag: 'button', // class: 'as-transparent-button', // child: 'span.mdi.mdi-function-variant', // attr: { // title: 'Insert [Ctrl + I]' // }, // }, { tag: 'button', class: 'as-transparent-button', child: 'span.mdi.mdi-magnify', attr: { title: 'Hint [Ctrl + Space]' }, on: { click: () => { this.elt.autoCompleteCtrl.openDropdown(); this.elt.engine.setSelectedPosition(this.elt.engine.lastSelectedPosition); } } } ] }); this.elt.$content.on('focus', this.ev_focus); } EICommandTool.prototype.open = function () { if (this.isOpen) return; this.elt.emit('focus', { type: 'focus', originalEvent: event, target: this.elt }, this.elt); if (this.elt.autoCompleteCtrl.getSuggestionList().length === 0) return; this.isOpen = true; this.$ctn.addTo(this.elt); this.$ctn.followTarget = this.elt; var zIndex = (0,utils.findMaxZIndex)(this.elt) + 1; this.$ctn.addStyle('z-index', zIndex); document.addEventListener('click', this.ev_clickOut); }; EICommandTool.prototype.close = function () { if (!this.isOpen) return; this.isOpen = false; this.elt.emit('blur', { type: 'blur', originalEvent: event, target: this.elt }, this.elt); document.removeEventListener('click', this.ev_clickOut); this.$ctn.selfRemove(); }; EICommandTool.prototype.ev_focus = function (event) { this.open(); }; EICommandTool.prototype.ev_clickOut = function (ev) { if ((0,EventEmitter/* hitElement */.EY)(this.elt, ev)) return; this.close(); }; EICommandTool.prototype.revokeResource = function () { this.elt.$content.on('focus', this.ev_focus); this.close(); }; /** * @extends {AElement} * @constructor */ function EISuggestionList() { /** * * @type {EISuggestionNode} */ this.$selectedNode = null; this._data = []; this.$children = []; } EISuggestionList.prototype.reset = function () { //todo: select first suggestion } EISuggestionList.prototype.moveToNextSuggestion = function () { if (this.$selectedNode) { return this.selectElt(this.$selectedNode.nextSibling || this.childNodes[0]); } else { return this.selectElt(this.$children[0]); } }; EISuggestionList.prototype.moveToPrevSuggestion = function () { if (this.$selectedNode) { return this.selectElt(this.$selectedNode.previousSibling || this.lastChild); } else { return this.selectElt(this.lastChild); } }; EISuggestionList.render = function () { return (0,ACore._)({ extendEvent: ['select'], class: ['am-select-tree-leaf-box-list', 'as-bscroller', 'as-dropdown-box-common-style', 'as-ei-suggestion-list'], }); }; EISuggestionList.prototype.selectElt = function (elt) { elt = elt || null; if (elt === this.$selectedNode) return false; if (this.$selectedNode) { this.$selectedNode.removeClass('as-selected'); } this.$selectedNode = elt; if (elt) { elt.addClass('as-selected'); } if (this.isDescendantOf(document.body)) { (0,utils.vScrollIntoView)(elt); } return true; } EISuggestionList.prototype.selectMaxScoreItem = function () { var maxPath = []; var maxScore = 0; var visit = (nd, path) => { if (nd.data.score > maxScore) { maxScore = nd.data.score; maxPath = path.concat([nd]); } path.push(nd); nd.$children.forEach(child => { visit(child, path); }); path.pop(); } this.$children.forEach((node) => { visit(node, []); }); maxPath.forEach((node) => { node.open() }); if (maxPath.length > 0) { this.selectElt(maxPath[maxPath.length - 1]); } }; EISuggestionList.property = {}; EISuggestionList.property.data = { set: function (data) { data = data || []; this._data = data; this.clearChild(); this.$children = data.map((it) => { return (0,ACore._)({ tag: EISuggestionNode, props: { data: it } }) }); var viewElements = []; this.$children.forEach(function (child) { child.getViewElements(viewElements); }); this.addChild(viewElements); }, get: function () { return this._data; } }; EISuggestionList.property.selectedSuggestions = { get: function () { return this.$selectedNode ? this.$selectedNode.data : null; } }; /** * @typedef {Object} EISuggestionNodeData * @property {string} text * @property {string} value * @property {string} [desc] * @property {string} type * @property {boolean} [noSelect] * @property {EISuggestionNodeData[]} [children] */ /** * @extends {AElement} * @constructor */ function EISuggestionNode() { this.$text = (0,ACore.$)('.as-eisli-text', this); this.$desc = (0,ACore.$)('.as-eisli-desc', this); this.$iconCtn = (0,ACore.$)('.as-eisli-icon-ctn', this); this._level = 0; this._data = { text: '', desc: '' }; this.on('click', (event) => { this.parentElement.emit('select', { type: 'select', originalEvent: event, target: this, data: this.data }, this); }); /** * * @type {EISuggestionNode[]} */ this.$children = []; /** * @type {"none"|"open"|"close"} * @name status * @memberOf EISuggestionNode# */ /** * @type {EISuggestionNodeData} * @name data * @memberOf EISuggestionNode# */ /** * @type {number} * @name level * @memberOf EISuggestionNode# */ } EISuggestionNode.render = function () { return (0,ACore._)({ class: ['as-ei-suggestion-list-item'], child: [ { class: 'as-eisli-toggler', child: 'toggler-ico' }, { class: 'as-eisli-icon-ctn' }, { class: 'as-eisli-text', child: { text: '' } }, { class: 'as-eisli-desc', child: { text: '' } } ] }); } EISuggestionNode.prototype.getViewElements = function (ac) { ac = ac || []; ac.push(this); if (this.status === 'open') { this.$children.forEach(function (child) { child.getViewElements(ac); }); } return ac; }; EISuggestionNode.prototype.close = function () { if (!this.hasClass(' as-status-open')) return; var viewElements = this.getViewElements(); this.addClass('as-status-close').removeClass('as-status-open'); viewElements.shift(); for (var i = 0; i < viewElements.length; ++i) { viewElements[i].remove(); } }; EISuggestionNode.prototype.open = function () { if (!this.hasClass(' as-status-close')) return; this.addClass('as-status-open').removeClass('as-status-close'); var nextSibling = this.nextSibling; var viewElements = this.getViewElements(); for (var i = 0; i < viewElements.length; ++i) { this.insertBefore(viewElements[i], nextSibling); } }; EISuggestionNode.property = {}; EISuggestionNode.property.data = { /** * @this {EISuggestionNode} * @param {EISuggestionNodeData} data */ set: function (data) { this._data = data || {}; this.$text.firstChild.data = data.text || ''; this.$desc.firstChild.data = data.desc || ''; if (data.noSelect) { this.addClass('as-no-select'); } this.$children = (data.children || []).map((childData) => { return (0,ACore._)({ tag: EISuggestionNode, props: { data: childData, level: this.level + 1 } }); }); this.$iconCtn.clearChild(); if (data.item) { switch (data.item.type) { case 'variable': this.$iconCtn.addChild((0,ACore._)('span.mdi.mdi-variable')); if (data.children && data.children.length > 0) { this.status = 'open'; } break; case 'function': this.$iconCtn.addChild((0,ACore._)('span.mdi.mdi-function')); break; } } else { this.status = 'open'; this.$iconCtn.addChild((0,ACore._)('span.mdi.mdi-code-json')); } }, get: function () { return this._data; } }; EISuggestionNode.property.level = { set: function (value) { this.addStyle('--level', value + ''); this._level = value; this.$children.forEach((child) => { child.level = value + 1; }); }, get: function () { return this._level; } } EISuggestionNode.property.status = { set: function (value) { if (value === 'open') { this.addClass('as-status-open').removeClass('as-status-close'); } else if (value === 'close') { this.addClass('as-status-close').removeClass('as-status-open'); } }, get: function () { if (this.hasClass('as-status-open')) return 'open'; if (this.hasClass('as-status-close')) return 'close'; return 'none'; } } /********************************* * EXPRESSION */ var rules = []; var operatorOrder = { 'NOT': 4, '!': 4, '*': 5, '/': 5, 'MOD': 5, '%': 5, '+': 6, '-': 6, '<': 9, '>': 9, '<=': 9, '>=': 9, '==': 9, '=': 9, '===': 9, '!=': 9, 'AND': 14, '&&': 14, 'OR': 15, '||': 15, 'XOR': 15, } rules.push({ target: 'null', elements: ['_null'], toAST: function (parsedNode) { return { type: 'NullLiteral', } } }); rules.push({ target: 'ident', elements: ['.word'], toAST: function (parsedNode) { return { type: 'Identifier', name: parsedNode.children[0].content } } }); rules.push({ target: 'args_list', elements: ['exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); }, toASTChain: function (parsedNode) { return [(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode)]; } }); rules.push({ target: 'args_list', elements: ['args_list', '_,', 'exp'], longestOnly: true, ident: 'args_list_rec', toASTChain: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[0]).concat((0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2])); } }); rules.push({ target: 'function_callee', elements: ['ident'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'function_callee', elements: ['mem_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }) rules.push({ target: 'function_call', elements: ['function_callee', '_(', 'args_list', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: parsedNode.children[2].rule.toASTChain(parsedNode.children[2]), callee: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]) } } }); rules.push({ target: 'function_call', elements: ['function_callee', '_(', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: [], callee: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]) }; } }); rules.push({ target: 'new_expression', elements: ['_new', 'function_call'], toAST: function (parsedNode) { var callAst = (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[1]) return { type: 'NewExpression', arguments: callAst.arguments, callee: callAst.callee } } }); rules.push({ target: 'exp', elements: ['new_expression'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['null'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['ident'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'number', elements: ['.number'], toAST: function (parsedNode) { return { type: 'NumericLiteral', value: parseFloat(parsedNode.children[0].content) } } }); rules.push({ target: 'string', elements: ['.string'], toAST: function (parsedNode) { var content = parsedNode.children[0].content; if (content[0] === "'") content = '"' + content.substring(1, content.length - 1).replace(/["]/g, '\\"') + '"'; return { type: 'StringLiteral', value: JSON.parse(content) } } }); rules.push({ target: 'boolean', elements: ['_true'], toAST: function (parsedNode) { return { type: 'BooleanLiteral', value: true }; } }); rules.push({ target: 'boolean', elements: ['_false'], toAST: function (parsedNode) { return { type: 'BooleanLiteral', value: false }; } }); rules.push({ target: 'exp', elements: ['number'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['string'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['boolean'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); ['+', '-', '*', '/', '%', '&&', '||', 'XOR', "=", '==', '===', '!=', '<', '>', '>=', '<='].forEach(function (op) { rules.push({ target: 'bin_op', elements: ['_' + op], toAST: function (parsedNode) { return { type: "BinaryOperator", content: op } } }); }); var x = Math.m rules.push({ target: 'exp', elements: ['exp', 'bin_op', 'exp'], // longestOnly: true,//* error when parse return (...)... ident: 'bin_op_rec', toASTChain: function (parseNode) { var res = []; if (parseNode.children[0].rule === this) { res = res.concat(this.toASTChain(parseNode.children[0])); } else { res.push((0,DPParseInstance/* parsedNodeToAST */.Hg)(parseNode.children[0])); } res.push(parseNode.children[1].children[0]); if (parseNode.children[2].rule === this) { res = res.concat(this.toASTChain(parseNode.children[2])); } else { res.push((0,DPParseInstance/* parsedNodeToAST */.Hg)(parseNode.children[2])); } return res; }, toAST: function (parsedNode) { var chain = this.toASTChain(parsedNode); var stack = []; var item; var newNode; while (chain.length > 0) { item = chain.shift(); if (item.content in operatorOrder) { while (stack.length >= 3 && operatorOrder[stack[stack.length - 2].content] <= operatorOrder[item.content]) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = stack.pop(); newNode.left = stack.pop(); stack.push(newNode); } } stack.push(item); } while (stack.length >= 3) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = stack.pop(); newNode.left = stack.pop(); stack.push(newNode); } return stack.pop(); } }); rules.push({ target: 'exp', elements: ['function_call'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'bracket_group', elements: ['_(', 'exp', '_)'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[1]); } }); rules.push({ target: 'exp', elements: ['bracket_group'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); // rules.push({ // target: 'exp', // elements: ['_(', 'exp', '_)'], // toAST: function (parsedNode) { // return parsedNodeToAST(parsedNode.children[1]); // } // }); ['+', '-', '!'].forEach(function (op) { ['number', 'bracket_group', 'ident', 'function_call', 'mem_exp', 'unary_exp'].forEach(function (arg) { rules.push({ target: 'unary_exp', elements: ['_' + op, arg], toAST: function (parsedNode) { return { type: 'UnaryExpression', argument: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[1]), operator: { type: 'UnaryOperator', content: op } } } }); }); }); rules.push({ target: 'exp', elements: ['unary_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'mem_exp', elements: ['ident', '_->', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['ident', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['new_expression', '_->', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['new_expression', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['mem_exp', '_->', 'ident'], longestOnly: true, ident: 'mem_exp_ident_rev', toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['mem_exp', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['bracket_group', '_->', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['bracket_group', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), property: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'exp', elements: ['mem_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'object_exp', elements: ['_{', '_}'], toAST: function (parsedNode) { return { type: 'ObjectExpression', properties: [] } } }); rules.push({ target: 'object_exp', elements: ['_{', 'object_property_list', '_}'], toAST: function (parsedNode) { return { type: 'ObjectExpression', properties: (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[1]) } } }); rules.push({ target: 'exp', elements: ['object_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'object_property', elements: ['ident', '_:', 'exp'], toAST: function (parsedNode) { return { type: 'ObjectProperty', key: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), value: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) }; } }); rules.push({ target: 'object_property', elements: ['string', '_:', 'exp'], toAST: function (parsedNode) { return { type: 'ObjectProperty', key: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]), value: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2]) }; } }); rules.push({ target: 'object_property_list', elements: ['object_property'], toASTChain: function (parsedNode) { return [(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'object_property_list', elements: ['object_property_list', '_,', 'object_property'], longestOnly: true, ident: 'object_property_list_rec', toASTChain: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[0]).concat([(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2])]); } }); /**********************************************************************************************************************/ rules.push({ target: 'exp', elements: ['array_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'array_exp', elements: ['_[', '_]'], toAST: function (parsedNode) { return { type: "ArrayExpression", elements: [] }; } }); rules.push({ target: 'array_exp', elements: ['_[', 'array_item_list', '_]'], toAST: function (parsedNode) { return { type: "ArrayExpression", elements: (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[1]) }; } }); rules.push({ target: 'array_item_list', elements: ['exp'], toASTChain: function (parsedNode) { return [(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'array_item_list', elements: ['array_item_list', '_,', 'exp'], longestOnly: true, ident: 'array_item_list_rec', toASTChain: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[0]).concat([(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2])]); } }); /**********************************************************************************************************************/ var elementRegexes = [ ['string', /("(?:[^"\\\n]|\\.)*?")|('(?:[^'\\\n]|\\.)*?')/], ['number', /(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)/], ['word', /[_a-zA-Z][_a-zA-Z0-9]*/], ['skip', /([\s\r\n])|(\/\/[^\n]*)|(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)/], ['dsymbol', /\+\+|--|==|!=|<=|>=|\|\||&&|->/], ['tsymbol', /\.\.\./], ['symbol', /[^\s_a-zA-Z0-9]/], ]; var EIGrammar = { elementRegexes: elementRegexes, operatorOrder: SCGrammar/* default.operatorOrder */.Z.operatorOrder, rules: rules }; var EIParser = new DPParser/* default */.Z(EIGrammar); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/IdentTextInput.js /*** * @augments HTMLInputElement * @augments AElement * @constructor */ function IdentTextInput() { this.history = new ITIHistory(this); this.textCtrl = new ITITextController(this); // this.on('keydown', this.eventHandler.identTextKeyDown) // .on('paste', this.applyData ? this.eventHandler.identTextPaste : this.eventHandler.identTextPaste1); } IdentTextInput.tag = 'IdentTextInput'.toLowerCase(); IdentTextInput.render = function () { return (0,ACore._)('input.as-text-input[type="text"]'); }; IdentTextInput.prototype._filterHistory = function () { if (!this.history) return; var temp = this.history.filter(function (t) { return !t.text.match(/(^[^a-zA-Z_$])|([^a-zA-Z$_0-9]+)/); }); this.history.splice(0, this.history.length); this.history.push.apply(this.history, temp); }; IdentTextInput.prototype._setNewText = function (text, caretPos) { this._filterHistory(); if (typeof caretPos !== "number") caretPos = text.length; caretPos = Math.max(0, Math.min(text.length, caretPos >> 0)); if (this.applyData) { this.applyData(text, { start: caretPos, end: caretPos, direction: 'forward' }); } else { this.value = text; (0,Text.setCaretPosition)(this, caretPos); } }; IdentTextInput.property = {}; IdentTextInput.property.lowerCaseOnly = { set: function (value) { if (value) { this.addClass('as-lower-case-only'); this.value = this.value.toLowerCase(); } else { this.removeClass('as-lower-case-only'); } }, get: function () { return this.addClass('as-lower-case-only'); } }; ACore/* default.install */.Z.install(IdentTextInput); /* harmony default export */ const js_IdentTextInput = (IdentTextInput); /** * * @param {IdentTextInput} elt * @constructor */ function ITIHistory(elt) { this.elt = elt; } /** * * @param {IdentTextInput} elt * @constructor */ function ITITextController(elt) { this.elt = elt; Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) this[key] = this[key].bind(this); }); this.elt.on('keydown', this.ev_keydown); } ITITextController.prototype.keyboardRegex = /[a-zA-Z$_0-9]/; ITITextController.prototype.getSelectionStart = function () { var start = 0; if (this.elt.selectionStart || this.elt.selectionStart === 0) start = this.elt.selectionStart; return start; }; ITITextController.prototype.getSelectionEnd = function () { var end = 0; if (this.elt.selectionEnd || this.elt.selectionEnd === 0) end = this.elt.selectionEnd; return end; }; ITITextController.prototype.ev_keydown = function (event) { var selectedPositionStart; var key = event.key; if (key === ' ') { event.preventDefault(); } else if (key === 'Enter') { event.preventDefault(); this.elt.blur(); } else if (key === "Escape") { // this.value = this._prevValue || ''; this.elt.blur(); } else if (!event.ctrlKey && !event.altKey && key.length === 1) { // if (nonAccentVietnamese(key).match(this.keyboardRegex)) { // selectedPositionStart = this.getSelectionStart(); // if (selectedPositionStart === 0 && key.match(/[0-9]/)) { // event.preventDefault(); // } // } // else { // event.preventDefault(); // } } }; // EXTERNAL MODULE: ./node_modules/absol/src/Code/safeThrow.js var safeThrow = __webpack_require__(5650); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/EfficientTable.js var execAsync = (commands, whileFunc) => { return commands.reduce((ac, act) => { if (whileFunc && !whileFunc()) return; if (ac && ac.then) { if (typeof act === "function") { return ac.then(act); } else { return ac.then(() => act); } } if (typeof act === 'function') return act(ac); else return act; }, null); } var getMaxRowCount = () => { var screenSize = (0,Dom/* getScreenSize */.tE)(); return Math.ceil(Math.max(2048, screenSize.height) / 40.0) * 3; } var waitAll = (variables, thenCb) => { var hasPromise = variables.findIndex(v => v && (typeof v.then === "function")); if (hasPromise >= 0) return Promise.all(variables).then(thenCb); else return thenCb(variables); } var waitValue = (value, thenCb) => { if (value && (typeof value.then === "function")) { return value.then(thenCb); } else return thenCb(value); } /** * @extends AElement * @constructor */ function EfficientTable() { this.layoutCtrl = new ETLayoutController(this); this.fixHeaderCtrl = new ETFixHeaderController(this); this._adapter = null; this.table = null; this.extendStyle = this.extendStyle || {}; this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$attachhook.requestUpdateSize = this.layoutCtrl.requestUpdateSize.bind(this); this.colWidth = new ETColWidthDeclaration(this); /** * @name adapter * @type {ETAdapter} * @memberof EfficientTable# */ } EfficientTable.tag = 'EfficientTable'.toLowerCase(); EfficientTable.render = function (data, domDesc) { var width = domDesc.style && domDesc.style.width; var classList = ['as-efficient-table-wrapper']; if (width === 'match_parent') { classList.push('as-width-match-parent'); } var id = domDesc.id || (domDesc.attr && domDesc.attr.id) || 'no-id-' + (0,stringGenerate.randomIdent)(10); return (0,ACore._)({ id: id, extendEvent: ['colresize'], class: classList, props: { extendStyle: domDesc.style }, child: [ { class: 'as-dynamic-table-fixed-y-ctn' } ] }); }; EfficientTable.prototype.addStyle = function (name, value) { if (name === 'width') { this.extendStyle[name] = value; } else { AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } return this; }; EfficientTable.prototype.getColWidth = function () { var table = this.table; if (!table) return null; if (arguments.length === 0) return this.colWidth.export(); else return this.colWidth.getProperty(...arguments); }; EfficientTable.prototype.setColWidth = function () { var table = this.table; if (!table) return null; if (arguments.length === 0) Object.assign(this.colWidth); else this.colWidth.setProperty(...arguments); }; /** * * @param {string|number|function}arg */ EfficientTable.prototype.findRow = function (arg) { if (this.table) { return this.table.body.findRow(arg); } return null; }; EfficientTable.prototype.requestUpdateSize = function () { this.layoutCtrl.requestUpdateSize(); }; EfficientTable.prototype.notifyDataSheetChange = function () { if (this.adapter) this.adapter.notifyDataSheetChange(); }; EfficientTable.prototype.notifyRowModifiedAt = function (idx) { if (this.adapter) this.adapter.notifyRowModifiedAt(idx); }; EfficientTable.prototype.notifyRowRemoveAt = function (idx) { if (this.adapter) this.adapter.notifyRowRemoveAt(idx); }; EfficientTable.prototype.notifyAddRowAt = function (idx) { if (this.adapter) this.adapter.notifyAddRowAt(idx); }; EfficientTable.prototype.revokeResource = function () { this.fixHeaderCtrl.revokeResource(); //todo: revoke all resource }; EfficientTable.property = {}; EfficientTable.property.adapter = { set: function (value) { this.colWidth.revokeResource(); this.fixHeaderCtrl.reset(); this._adapter = new ETAdapter(this, value); this.table = new ETTable(this, this._adapter.data); this.addChild(this.table.elt); this._adapter.notifyDataSheetChange(); this.colWidth = new ETColWidthDeclaration(this); }, get: function () { return this._adapter; } }; /* harmony default export */ const js_EfficientTable = (EfficientTable); ACore/* default.install */.Z.install(EfficientTable); // ETAdapter.prototype. /** * * @param {EfficientTable} elt * @constructor */ function ETFixHeaderController(elt) { this.elt = elt; this.$cloneTable = null; this.$cloneHead = null; } ETFixHeaderController.prototype.updateSize = function () { }; ETFixHeaderController.prototype.reset = function () { if (this.isWrapped) { } }; ETFixHeaderController.prototype.revokeResource = function () { this.revokeResource = noop/* default */.Z; this.elt = null; } /** * * @param {EfficientTable} elt * @constructor */ function ETLayoutController(elt) { this.elt = elt; /*** * * @type {SearchTextInput|null} */ this.$searchInput = null; /*** * * @type {AElement} */ this.$table = (0,ACore.$)('.as-dynamic-table', elt); /*** * * @type {AElement} */ this.$thead = (0,ACore.$)('.as-dynamic-table>thead', this.$table); /*** * * @type {AElement} */ this.$tbody = (0,ACore.$)('.as-dynamic-table>tbody', this.$table); this.$filterInputs = []; this.$attachhook = (0,ACore._)('attachhook').addTo(elt); this.domSignal = new DomSignal/* default */.ZP((0,ACore._)('attachhook').addTo(elt)); //controller this.$fixedYCtn = (0,ACore.$)('.as-dynamic-table-fixed-y-ctn', elt); this.extendStyle = {}; // this.$attachhook.requestUpdateSize = this.fixedContentCtrl.updateSize.bind(this.fixedContentCtrl); this.$attachhook.requestUpdateSize = this.requestUpdateSize.bind(this); this.$attachhook.on('attached', () => { ResizeSystem/* default.add */.Z.add(this.$attachhook); this.onAttached(); this.onAttached(); // manager.add(this); setTimeout(() => { this.requestUpdateSize(); }, 10); }); this.ev_scroll = this.ev_scroll.bind(this); this.$BindedScrollers = []; this.stopScrollTO = -1; } ETLayoutController.prototype.onAttached = function () { this.bindScroller(); }; ETLayoutController.prototype.requestUpdateSize = function () { this.elt.table.body.updateYOffset(true); var beforeRect = this.elt.table.body.size; this.viewSize(); this.viewByScroll(); this.elt.table.body.calcSize(); var newRect = this.elt.table.body.size; if (newRect.width !== beforeRect.width || newRect.height !== beforeRect.height) { ResizeSystem/* default.updateUp */.Z.updateUp(this.elt.parentElement); } }; ETLayoutController.prototype.viewSize = function () { this.elt.table.calcSize(); var size = this.elt.table.size; if (size.trueValue) { this.elt.addClass('as-true-size'); } this.elt.addStyle('height', (size.height + 1) + 'px'); }; ETLayoutController.prototype.bindScroller = function () { var p = this.elt.parentElement; while (p) { p.addEventListener('scroll', this.ev_scroll); this.$BindedScrollers.push(p); p = p.parentElement; } document.addEventListener('scroll', this.ev_scroll); this.$BindedScrollers.push(document); }; ETLayoutController.prototype.unBindScroller = function () { while (this.$BindedScrollers.length) { this.$BindedScrollers.pop().removeEventListener('scroll', this.ev_scroll); } }; ETLayoutController.prototype.viewByScroll = function () { if (!this.elt.table) return; if (this.elt.table.size.trueValue) return; var bound = this.elt.getBoundingClientRect(); var outbound = (0,Dom/* traceOutBoundingClientRect */.DI)(this.elt);//todo: small than scroller var head = this.elt.table.head; var hs = 0; if (bound.top >= outbound.top) { hs = 0; this.elt.table.elt.addStyle('top', 0); return; } else if (bound.bottom < outbound.bottom) { hs = 1; } else { hs = (outbound.top - (bound.top + head.size.height)) / (bound.height - head.size.height - outbound.height); } var rowLNIdx = this.elt.adapter.length * hs; var y = outbound.top + head.size.height + hs * (outbound.height - head.size.height); var rowIdx = Math.floor(rowLNIdx); if (hs === 1) rowIdx = this.elt.adapter.length - 1; var body = this.elt.table.body; var currentOffset = body.rowOffset; this.elt.table.body.requestVisible(rowIdx); this.elt.table.body.waitLoaded(() => { if (currentOffset !== body.rowOffset) return; this.elt.table.body.updateYOffset(); var row = body.rows[rowIdx - body.rowOffset]; if (!row) return;//out of date, don't update var rowLNY = row.offsetY + row.offsetHeight * hs; var dy = y - bound.top - rowLNY - hs;//hs for border 1px this.elt.table.elt.addStyle('top', dy + 'px'); }); } ETLayoutController.prototype.ev_scroll = function () { this.viewByScroll(); clearTimeout(this.stopScrollTO); this.stopScrollTO = setTimeout(() => { this.viewByScroll(); }, 100); }; /** * * @param elt * @param adapterData * @constructor */ function ETAdapter(elt, adapterData) { this.elt = elt; this.data = adapterData.data; this.raw = adapterData; this.asyncSession = Math.random(); this.sync = null; } ETAdapter.prototype.notifyDataSheetChange = function () { var asyncSession = Math.random(); this.asyncSession = asyncSession; var cmdArr = [ () => this.getLength(), () => { var body = this.elt.table.body; var head = this.elt.table.head; body.clear(); body.drawFrom(0); var makeSize = () => { body.waitLoaded(() => { body.updateYOffset(true); this.elt.layoutCtrl.requestUpdateSize(); }); } if (this.elt.isDescendantOf(document.body)) { makeSize(); } else { this.elt.$attachhook.once('attached', makeSize); } } ]; execAsync(cmdArr, () => this.asyncSession === asyncSession); }; ETAdapter.prototype.notifyRowModifiedAt = function (idx) { this.sync = execAsync([ this.sync, () => { this.elt.table.body.modifiedRowAt(idx); if (this.elt.isDescendantOf(document.body)) { this.elt.table.body.waitLoaded(() => { this.elt.layoutCtrl.requestUpdateSize(); }); } } ]); }; ETAdapter.prototype.notifyRowRemoveAt = function (idx) { this.sync = execAsync([ this.sync, () => this.getLength(), () => { this.elt.table.body.removeRowAt(idx); if (this.elt.isDescendantOf(document.body)) { this.elt.table.body.waitLoaded(() => { this.elt.layoutCtrl.requestUpdateSize(); }); } } ]); }; ETAdapter.prototype.notifyAddRowAt = function (idx) { this.sync = execAsync([ this.sync, () => this.getLength(), () => { this.elt.table.body.addRowAt(idx); if (this.elt.isDescendantOf(document.body)) { this.elt.table.body.waitLoaded(() => { this.elt.layoutCtrl.viewSize(); }); } } ]); }; ETAdapter.prototype.getLength = function () { return execAsync([() => { var body = this.raw.data.body; var length; if (typeof body.length === "number") { length = body.rows.length; } else if (body.length && body.length.then) { length = body.length; } else if (typeof body.getLength === "function") { try { length = this.raw.data.body.getLength(this); } catch (e) { (0,safeThrow/* default */.Z)(e); } } else if (body.rows) length = body.rows.length; return length; }, l => { this.length = l; return l; }]); }; ETAdapter.prototype.getRowAt = function (idx) { var data; var body = this.raw.data.body; if (typeof body.getRowAt === "function") { try { data = body.getRowAt(idx, this); } catch (e) { (0,safeThrow/* default */.Z)(e); } } else if (body.rows) data = body.rows[idx]; return data; }; ETAdapter.prototype.renderHeadCell = function (elt, data, controller) { if (data.child) { if (data.child.map) { elt.addChild(data.child.map(function (it) { return (0,ACore._)(it); })); } else { elt.addChild((0,ACore._)(data.child)); } } if (data.render) { data.render.call(null, elt, data, controller); } }; ETAdapter.prototype.renderBodyCell = function (elt, data, idx, controller) { var body = this.raw.data.body; var template = body.rowTemplate; var cellTpl = template.cells[idx]; if (cellTpl.child) { if (cellTpl.child.map) { elt.addChild(cellTpl.child.map(function (it) { return (0,ACore._)(it); })); } else { elt.addChild((0,ACore._)(cellTpl.child)); } } if (cellTpl.render) { cellTpl.render.call(null, elt, data, controller); } if (cellTpl.style) elt.addStyle(cellTpl.style); }; ETAdapter.prototype.getRowLength = function () { var body = this.raw.data.body; var template = body.rowTemplate; return template.cells.length; }; /** * * @param {EfficientTable} wrapper * @param data * @constructor */ function ETTable(wrapper, data) { this.wrapper = wrapper; this.adapter = this.wrapper.adapter; this.data = data; this.head = new ETHead(this, this.data.head); this.body = new ETBody(this, this.data.body); this.elt = (0,ACore._)({ tag: 'table', class: 'as-dynamic-table', child: [ this.head.elt, this.body.elt ] }); this.handleStyle(); this.size = new Rectangle/* default */.Z(0, 0, 0, 0); this.size.trueValue = false; } ETTable.prototype.handleStyle = function () { var style = this.wrapper.extendStyle; var value; if (style.width) { value = (0,attribute.parseMeasureValue)(style.width); if (value) { if (value.unit === '%') { this.wrapper.style.setProperty('width', value); this.elt.addStyle('width', '100%'); } } } }; ETTable.prototype.calcSize = function () { this.head.calcSize(); this.body.calcSize(); this.size = this.head.size.clone(); this.size.height += this.body.size.height; this.size.trueValue = this.body.size.trueValue; }; /** * * @param {ETTable} table * @param data * @constructor */ function ETHead(table, data) { this.table = table; this.data = data || {}; if (!this.data.rows) this.data.rows = []; this.rows = this.data.rows.map(rowData => new ETHeadRow(this, rowData)); this.elt = (0,ACore._)({ tag: 'thead', class: 'as-dt-header', child: this.rows.map(it => it.elt) }); this.size = new Rectangle/* default */.Z(0, 0, 0, 0); } ETHead.prototype.calcSize = function () { var bound = this.elt.getBoundingClientRect(); this.size = Rectangle/* default.fromClientRect */.Z.fromClientRect(bound); }; /** * * @param {ETHead} head * @param data * @constructor */ function ETHeadRow(head, data) { this.head = head; this.data = data || {}; if (!this.data.cells) this.data.cells = []; this.cells = this.data.cells.map(cellData => new ETHeadCell(this, cellData)) this.elt = (0,ACore._)({ tag: 'tr', class: 'as-dt-header-row', child: this.cells.map(it => it.elt) }); } // (ETHeadRow) function ETHeadCell(row, data) { this.row = row; this.data = data || {}; this.elt = (0,ACore._)({ tag: 'th', class: 'as-dt-header-cell' }); if (data.attr && (0,utils.isNaturalNumber)(data.attr.colspan)) { this.elt.attr('colspan', data.attr.colspan); } if (data.attr && (0,utils.isNaturalNumber)(data.attr.rowspan)) { this.elt.attr('colspan', data.attr.rowspan); } if (data.style) this.elt.addStyle(data.style); this.row.head.table.adapter.renderHeadCell(this.elt, this.data, this); } /** * * @param {ETTable} table * @param data * @constructor */ function ETBody(table, data) { this.data = data; this.table = table; this.elt = (0,ACore._)({ tag: 'tbody', class: 'as-dt-body' }); this.rowOffset = 0; this.rows = []; /** * * @type {Rectangle|{trueValue:boolean}} */ this.size = new Rectangle/* default */.Z(0, 0, 0, 0); this.size.trueValue = false; this.needUpdateYOffset = false; this.sync = null; } ETBody.prototype.clear = function () { this.rowOffset = 0; var row; while (this.rows.length) { row = this.rows.shift(); this.rowOffset++; row.elt.remove(); row.revokeResource(); } this.needUpdateYOffset = true; }; ETBody.prototype.removeRowAt = function (idx) { var localIdx = idx - this.rowOffset; var row = this.rows[localIdx]; if (!row) return false; row.elt.selfRemove(); this.rows.splice(localIdx, 1); row.revokeResource(); for (var i = 0; i < this.rows.length; ++i) { this.rows[i].updateIdx(i + this.rowOffset); } this.drawFrom(this.rowOffset); }; ETBody.prototype.modifiedRowAt = function (idx) { var localIdx = idx - this.rowOffset; var row = this.rows[localIdx]; if (!row) return false; var newRow = new ETBodyRow(this, this.table.wrapper.adapter.getRowAt(idx)); newRow.updateIdx(idx); this.rows[localIdx] = newRow; row.elt.selfReplace(newRow.elt); this.needUpdateYOffset = true; }; ETBody.prototype.addRowAt = function (idx) { var localIdx = idx - this.rowOffset; var row = this.rows[localIdx]; if (!row) return false; var newRow = new ETBodyRow(this, this.table.wrapper.adapter.getRowAt(idx)); this.rows.splice(localIdx, 0, newRow); row.elt.parentElement.addChildBefore(newRow.elt, row.elt); for (var i = 0; i < this.rows.length; ++i) { this.rows[i].updateIdx(i + this.rowOffset); } this.needUpdateYOffset = true; }; ETBody.prototype.requestVisible = function (idx) { var maxRow = getMaxRowCount(); var length = this.table.wrapper.adapter.length; var pageIdx; var pageN = Math.ceil(Math.max(length / (maxRow / 3))); idx = Math.max(0, idx); idx = Math.min(length - 1, idx); pageIdx = Math.floor(idx / (maxRow / 3)); pageIdx = Math.min(pageN - 3, pageIdx - 1); pageIdx = Math.max(0, pageIdx); this.drawFrom(pageIdx * Math.floor(maxRow / 3)); }; ETBody.prototype.drawFrom = function (idx) { var adapter = this.table.wrapper.adapter; var maxRowCount = getMaxRowCount(); idx = Math.max(0, idx); var endIdx = Math.min(idx + maxRowCount, adapter.length); idx = Math.max(0, Math.min(endIdx - 1, idx)); var row; while (this.rowOffset + this.rows.length > idx + maxRowCount && this.rows.length) { row = this.rows.pop(); row.elt.remove(); } while (this.rowOffset < idx && this.rows.length) { row = this.rows.shift(); this.rowOffset++; row.elt.remove(); row.revokeResource(); this.needUpdateYOffset = true; } if (this.rows.length === 0) this.rowOffset = Math.min(adapter.length, idx + 1); var newRows = []; var newRow; while (this.rowOffset > idx && this.rowOffset > 0) { this.rowOffset--; newRow = new ETBodyRow(this, adapter.getRowAt(this.rowOffset)); newRows.push(newRow); newRow.updateIdx(this.rowOffset); this.rows.unshift(newRow); this.elt.addChildBefore(newRow.elt, this.elt.firstChild); this.needUpdateYOffset = true; } while (this.rowOffset + this.rows.length < endIdx) { newRow = new ETBodyRow(this, adapter.getRowAt(this.rowOffset + this.rows.length)); newRow.updateIdx(this.rowOffset + this.rows.length); newRows.push(newRow); this.rows.push(newRow); this.elt.addChild(newRow.elt); this.needUpdateYOffset = true; } }; /** * * @param {boolean} force */ ETBody.prototype.updateYOffset = function (force) { if (!this.needUpdateYOffset && !force) return; this.needUpdateYOffset = false; var tableBound = this.table.elt.getBoundingClientRect(); this.rows.forEach((row) => { row.calcSize(); var rowBound = row.size; row.offsetY = rowBound.y - tableBound.top; row.offsetHeight = rowBound.height; }); }; ETBody.prototype.calcSize = function () { var adapter = this.table.wrapper.adapter; var bound = this.elt.getBoundingClientRect(); if (this.rows.length === adapter.length) { this.size = Rectangle/* default.fromClientRect */.Z.fromClientRect(bound); this.size.trueValue = true; } else { this.size = Rectangle/* default.fromClientRect */.Z.fromClientRect(bound); this.size.height = bound.height / this.rows.length * adapter.length; this.size.trueValue = false; } }; ETBody.prototype.waitLoaded = function (cb) { waitAll(this.rows.map(row => row.data), cb); }; function ETBodyRow(body, data) { this.elt = (0,ACore._)({ tag: 'tr', class: 'as-dt-body-row' }); this.offsetY = 0; this.data = data; this.body = body; this.idx = 0; this.$idx = undefined; waitValue(this.data, data => { this.data = data; var adapter = body.table.wrapper.adapter; var length = adapter.getRowLength(); this.cells = Array(length).fill(null).map((u, i) => new ETBodyCell(this, i)); this.elt.addChild(this.cells.map(cell => cell.elt)); this.$idx = (0,ACore.$)('.as-dt-row-index', this.elt) || null; if (this.$idx) this.$idx.attr('data-idx', this.idx + 1); if (data.on && (data.on.click)) { this.elt.on('click', (event) => { data.on.click.call(this.elt, event, this); }); } if (adapter.data.body.rowTemplate.on && (typeof adapter.data.body.rowTemplate.on.click === "function")) { this.elt.on('click', (event) => { adapter.data.body.rowTemplate.on.click.call(this.elt, event, this); }); } }); this.size = new Rectangle/* default */.Z(0, 0, 0, 0); // this.cells = data.cells.map(cell => new ETBodyCell(this, cell)); /** * @name adapter * @type {ETAdapter} * @memberof ETBodyRow# */ } ETBodyRow.prototype.updateIdx = function (value) { this.idx = value; if (!this.cells) return; if (this.$idx === undefined) this.$idx = (0,ACore.$)('.as-dt-row-index', this.elt) || null; if (this.$idx) this.$idx.attr('data-idx', this.idx + 1); }; ETBodyRow.prototype.calcSize = function () { this.size = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.elt.getBoundingClientRect()); }; ETBodyRow.prototype.notifyRemove = function () { if (this.adapter) this.adapter.notifyRowRemoveAt(this.idx); }; ETBodyRow.prototype.notifyModified = function () { if (this.adapter) this.adapter.notifyRowModifiedAt(this.idx); } ETBodyRow.prototype.revokeResource = function () { // return; this.revokeResource = noop/* default */.Z; (0,utils.revokeResource)(this.elt); delete this.elt; this.body = null; this.notifyRemove = noop/* default */.Z; }; Object.defineProperty(ETBodyRow.prototype, 'adapter', { /** * * @returns {ETAdapter} */ get: function () { return this.body && this.body.table.wrapper && this.body.table.wrapper.adapter; } }) function ETBodyCell(row, idx) { this.elt = (0,ACore._)({ tag: 'td', class: 'as-dt-body-cell' }); this.row = row; var adapter = this.row.body.table.wrapper.adapter; adapter.renderBodyCell(this.elt, row.data, idx, this); } /** * @extends Attributes * @param {EfficientTable} elt * @constructor */ function ETColWidthDeclaration(elt) { AppPattern_Attributes.call(this, this); if (!elt.table) return; var temp = elt.table.head.rows.reduce((ac, row) => { var l = row.cells.reduce((ac1, cell) => { var colspan = cell.data.attr && (cell.data.attrs.colspan || cell.data.attrs.colSpan); colspan = parseInt(colspan + '', 10); if (!(0,utils.isNaturalNumber)(colspan) || !colspan) colspan = 1; var id = cell.data.id; if (id && (typeof id === "string")) { ac.id2idx[id] = ac1; } if (colspan === 1) { if (!ac.idx2cells[ac1]) ac.idx2cells[ac1] = []; ac.idx2cells[ac1].push(cell); } return ac1 + colspan; }, 0); ac.length = (Math.max(ac.length, l)); return ac; }, { length: 0, id2idx: {}, idx2cells: {} }); Array(temp.length).fill(0).forEach((u, i) => { this.defineProperty('' + i, { set: function (value, ...args) { var unit; if (args.length > 1) unit = args[0]; var headWith; var originValue = this.getProperty('' + i); var pOValue = (0,attribute.parseMeasureValue)(originValue); if (!(0,utils.isRealNumber)(value) || value < 0) { value = 'auto'; } else if (unit === 'px') { if (pOValue.unit === '%') { headWith = elt.table.head.elt.getBoundingClientRect().width; value = value / headWith * 100 + '%'; } else { value = value + 'px'; } } else if (unit === '%') { headWith = elt.table.head.elt.getBoundingClientRect().width; if (pOValue.unit === 'px') { value = value / 188 * headWith; } else { value = value + '%'; } } if (typeof value === "number") value = value + 'px'; var cells = temp.idx2cells[i] || []; cells.forEach(cell => { if (value === 'auto') { if (cell.data.style) { delete cell.data.style.width; cell.elt.removeStyle('width'); } } else { if (!cell.data.style) cell.data.style = {}; cell.data.style.width = value; cell.elt.addStyle('width', value); } }); }, get: function (...args) { var unit; if (args.length > 1) unit = args[0]; var ref = args[args.length - 1]; var value = ref.get(); var cells = temp.idx2cells[i] || []; if (cells.length === 0) return 0; if (unit === 'px') { value = cells[0].elt.getBoundingClientRect().width; } else if (unit === '%') { value = cells[0].elt.getBoundingClientRect().width / elt.table.head.elt.getBoundingClientRect().width * 100; } else { value = cells.reduce((ac, cell) => { var pValue; if (cell.data.style && cell.data.style.width) { pValue = (0,attribute.parseMeasureValue)(cell.data.style.width); if (!pValue || pValue.unit !== 'px') return ac; return pValue.value; } return ac; }, 'auto'); } return value; } }) }); Object.keys(temp.id2idx).forEach(id => { var idx = temp.id2idx[id]; this.defineProperty(id, { set: function (...args) { return this.setProperty(idx, ...args.slice(1)); }, get: function (...args) { return this.getProperty(idx, ...args.slice(1)); } }); }); } OOP/* default.mixClass */.ZP.mixClass(ETColWidthDeclaration, AppPattern_Attributes); Object.defineProperty(ETColWidthDeclaration.prototype, 'revokeResource', { value: function () { delete this.$node; delete this.revokeResource; }, writable: true, enumerable: false, configurable: true }) // EXTERNAL MODULE: ./node_modules/absol-acomp/css/compactdatagrid.css var compactdatagrid = __webpack_require__(2407); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/assets/icon/table_header_add.tpl /* harmony default export */ const table_header_add = ("<svg\n viewBox=\"0 0 24 24\"\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:svg=\"http://www.w3.org/2000/svg\"\n class=\"as-toggle-header-ico\">\n <path\n class=\"as-icon-table\"\n d=\"M 1 1 L 1 1.5 L 1 23 L 23 23 L 23 1 L 1 1 z M 2 2 L 22 2 L 22 10 L 2 10 L 2 2 z M 2 11 L 5 11 L 5 14 L 2 14 L 2 11 z M 6 11 L 9 11 L 9 14 L 6 14 L 6 11 z M 10 11 L 14 11 L 14 14 L 10 14 L 10 11 z M 15 11 L 18 11 L 18 14 L 15 14 L 15 11 z M 19 11 L 22 11 L 22 14 L 19 14 L 19 11 z M 2 15 L 5 15 L 5 18 L 2 18 L 2 15 z M 6 15 L 9 15 L 9 18 L 6 18 L 6 15 z M 10 15 L 14 15 L 14 18 L 10 18 L 10 15 z M 15 15 L 18 15 L 18 18 L 15 18 L 15 15 z M 19 15 L 22 15 L 22 18 L 19 18 L 19 15 z M 2 19 L 5 19 L 5 22 L 2 22 L 2 19 z M 6 19 L 9 19 L 9 22 L 6 22 L 6 19 z M 10 19 L 14 19 L 14 22 L 10 22 L 10 19 z M 15 19 L 18 19 L 18 22 L 15 22 L 15 19 z M 19 19 L 22 19 L 22 22 L 19 22 L 19 19 z \" />\n <path\n style=\"fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;\"\n d=\"m 9,6 h 6\"\n class=\"as-icon-minus\" />\n <path\n style=\"fill:none;stroke:#000000;stroke-width:2;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;\"\n d=\"M 12,9 V 3\"\n class=\"as-icon-add\" />\n</svg>\n"); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CompactDataGridEditor.js var EV_SELECTED_CELL_CHANGE = 'SELECTED_CELL_CHANGE'.toLowerCase(); var EV_CELL_DATA_CHANGE = 'change'; var EV_UNDO_APPLY = 'EV_UNDO_APPLY'.toLowerCase(); /** * loc: [row, col, rowHeight, colHeight] * @param {AElement} cell * @returns {number[]} */ var locOfCell = cell => (cell.getAttribute('data-loc') || 'Nan,NaN').split(',') .concat([cell.getAttribute('rowspan') || '1', cell.getAttribute('colspan') || '1']) .map(it => parseInt(it, 10)); var locOfCells = cells => { return cells.reduce((ac, cell) => { var cellLoc = locOfCell(cell); if (!ac) return cellLoc; return mergeLoc(ac, cellLoc) }, null); } function mergeLoc(loc1, loc2) { var rowLow = Math.min(loc1[0], loc2[0]); var colLow = Math.min(loc1[1], loc2[1]); var rowHigh = Math.max(loc1[0] + loc1[2] - 1, loc2[0] + loc2[2] - 1); var colHigh = Math.max(loc1[1] + loc1[3] - 1, loc2[1] + loc2[3] - 1); var res = [rowLow, colLow, rowHigh - rowLow + 1, colHigh - colLow + 1]; if (arguments[2]) res = mergeLoc(res, arguments[2]); return res; }; var locInLoc = (loc, ctn) => { var mlc = mergeLoc(loc, ctn); return locEqual(mlc, ctn); }; var locEqual = (loc1, loc2) => { return loc1[0] === loc2[0] && loc1[1] === loc2[1] && loc1[2] === loc2[2] && loc1[3] === loc2[3]; } var locCollapse = (loc1, loc2) => { if (loc1[0] + loc1[2] <= loc2[0]) return false; if (loc2[0] + loc2[2] <= loc1[0]) return false; if (loc1[1] + loc1[3] <= loc2[1]) return false; if (loc2[1] + loc2[3] <= loc1[1]) return false; return true; }; var varNameOf = o => { var res; if (!o) res = undefined; else if (typeof o === "string") res = o; else if (o.attr) res = o.attr('data-name'); else if (typeof o.name === "string") res = o.name; return res || undefined; }; var varTitleOf = o => { var res = undefined; if (!o) res = undefined; else if (o.attr) { res = o.attr('data-title'); if (typeof res !== "string") res = undefined; } else if (typeof o.title === "string") res = o.title; return res; }; var normalizeVariableData = data => { if (typeof data === "string") { data = data.trim(); if (data.length === 0) return null; return { name: data, title: data }; } else if (typeof data === "object" && data) { data = Object.assign({}, data); if (typeof data.name !== "string" || data.name.trim().length === 0) return null; data.name = data.name.trim(); if (typeof data.title !== "string" || data.title.trim().length === 0) data.title = data.name; return data; } return null; }; var normalizeUsedVariable = data => { if (typeof data === "string") { data = data.trim(); if (data.length === 0) return null; return { name: data }; } else if (typeof data === "object" && data) { data = Object.assign({}, data); if (typeof data.name !== "string" || data.name.trim().length === 0) return null; data.name = data.name.trim(); if (('title' in data) && (typeof data.title !== "string")) delete data.title; return data; } return null; } var variableDataOfElt = elt => { if (!elt.attr) return null; if (!elt.attr('data-default-title')) return null; var res = {}; res.name = elt.attr('data-name'); if (typeof res.name !== "string" || !res.name) return null; var title = elt.attr && elt.attr('data-title'); if (typeof title === "string") res.title = title; return res; } var varEltOfCell = cell => { return Array.prototype.filter.call(cell.childNodes, c => !!c.attr('data-default-title')); } var isChangeParent = (parentElt, elt, bf) => { if (parentElt !== elt.parentElement) return true; var children = varEltOfCell(parentElt); var idx; if (bf === 'end') { return children[children.length - 1] !== bf; } else { if (bf === elt) return false; idx = children.indexOf(bf); return children[idx - 1] !== elt; } }; var hoverXOf = (cell, bf) => { var children = varEltOfCell(cell); var bound, cBound; if (children.length > 0) { bound = cell.getBoundingClientRect(); if (bf === 'end') { cBound = children[children.length - 1].getBoundingClientRect(); return cBound.right + 10 - bound.left; } else { cBound = bf.getBoundingClientRect(); return cBound.left - bound.left; } } else { return 20; } } var defaultTextAlignOfElt = elt => { if (elt.tagName === 'TD') return 'left'; return 'center'; }; var textAlignOfElt = elt => { return elt.style.textAlign || defaultTextAlignOfElt(elt); } var defaultFontWeightOfElt = elt => { if (elt.tagName === 'TD') return 'normal'; return 'bold'; }; var fontWeightOfElt = elt => { return elt.style.fontWeight || defaultFontWeightOfElt(elt); }; var fontStyleOfElt = elt => { return elt.style.fontStyle || 'normal'; }; /** * @extends AElement * @constructor */ function CompactDataGridEditor() { /** * * @type {CDContext} */ var context = { editor: this, table: null, formatTool: null, varMng: null, selectCtrl: null, lcEmitter: new EventEmitter/* default */.ZP() } context.table = new CDTable(context); this.$body = (0,ACore.$)('.as-compact-data-grid-editor-body', this); this.$body.addChild(context.table.$table); context.undoMng = new CDUndoManager(context); context.selectCtrl = new CDSelectController(context); context.formatTool = new CDGFormatTool(context); context.varMng = new CDGVariableManager(context); // OOP.drillProperty(this, context.table, 'header', 'data'); // OOP.drillProperty(this, context.table, 'data', 'data'); OOP/* default.drillProperty */.ZP.drillProperty(this, context.varMng, 'variables'); var dataTO = -1; Object.defineProperties(this, { header: { set: function (value) { if (value) { context.table.header.data = value; context.table.header.hidden = false; } else { context.table.header.hidden = true; } clearTimeout(dataTO); dataTO = setTimeout(() => { context.table.autoFixRowsWidth(); context.formatTool.updateAvailableCommands(); context.undoMng.reset().commit(); }); }, get: function () { clearTimeout(dataTO); context.table.autoFixRowsWidth(); if (context.table.header.hidden) return null; return context.table.header.data; }, configurable: true }, data: { set: function (value) { context.varMng.rejectAllVariables(); context.table.body.data = value; clearTimeout(dataTO); dataTO = setTimeout(() => { context.table.autoFixRowsWidth(); context.formatTool.updateAvailableCommands(); context.undoMng.reset().commit(); }); }, get: function () { clearTimeout(dataTO); context.table.autoFixRowsWidth(); return context.table.body.data; }, configurable: true } }); var count = 0; context.lcEmitter.on(EV_CELL_DATA_CHANGE, () => { context.undoMng.commit(); context.formatTool.updateAvailableCommands(); if (window.ABSOL_DEBUG) Snackbar.show('change ' + (++count)); this.emit('change', { type: 'change', target: this }, this); }); context.lcEmitter.on(EV_UNDO_APPLY, () => { context.formatTool.updateAvailableCommands(); if (window.ABSOL_DEBUG) Snackbar.show('change ' + (++count)); this.emit('change', { type: 'change', target: this }, this); }); /** * @name data * @memberof CompactDataGridEditor# */ /** * @name header * @memberof CompactDataGridEditor# */ } /** * @typedef CDContext * @property {CompactDataGridEditor} editor * @property {CDTable} table * @property {CDGVariableManager} varMng * @property {CDUndoManager} undoMng * @property {CDGFormatTool} formatTool * @property {CDSelectController} selectCtrl * @property {EventEmitter} lcEmitter * */ CompactDataGridEditor.tag = 'CompactDataGridEditor'.toLowerCase(); CompactDataGridEditor.render = function () { return (0,ACore._)({ attr: { tabindex: 1 }, extendEvent: ['change'], class: 'as-compact-data-grid-editor', child: ['.as-compact-data-grid-editor-body'] }); }; CompactDataGridEditor.prototype.revokeResource = function () { var data = this.data; var header = this.header; Object.defineProperties(this, { data: { value: data, configurable: true, writable: true }, header: { value: header, configurable: true, writable: true } }); (0,utils.revokeResource)(this.grid); (0,utils.revokeResource)(this.varMng); this.grid = undefined; this.varMng = undefined; while (this.firstChild) { (0,utils.revokeResource)(this.firstChild); this.firstChild.remove(); } }; CompactDataGridEditor.prototype.init = function (props) { props = Object.assign({}, props); this.variables = props.variables; this.header = props.header; this.data = props.data; delete props.variables; delete props.header; delete props.data; Object.assign(this, props); }; ACore/* default.install */.Z.install(CompactDataGridEditor); /* harmony default export */ const js_CompactDataGridEditor = (CompactDataGridEditor); /** * * @param {CDContext} context * @constructor */ function CDGrid(context) { this.context = context; this.$grid = (0,ACore._)(this.gridCt); // /** // * @type {CompactDataGridEditor} // */ // this.elt = this.context.elt; // this.$body = $('tbody', this.elt); } CDGrid.prototype.gridCt = 'tbody'; CDGrid.prototype.rowCt = 'tr'; CDGrid.prototype.cellCt = 'td'; CDGrid.prototype.makeCell = function (data) { var attr = {}; if ((0,utils.isNaturalNumber)(data.rowSpan) && data.rowSpan > 1) { attr.rowspan = data.rowSpan; } else if ((0,utils.isNaturalNumber)(data.rowspan) && data.rowspan > 1) { attr.rowspan = data.rowspan; } if ((0,utils.isNaturalNumber)(data.colSpan) && data.colSpan > 1) { attr.colspan = data.colSpan; } else if ((0,utils.isNaturalNumber)(data.colspan) && data.colspan > 1) { attr.colspan = data.colspan; } return (0,ACore._)({ tag: this.cellCt, attr: attr, class: 'as-ca-cell', style: data.style || {} // child: }); }; CDGrid.prototype.hasCell = function (cell) { return cell.isDescendantOf(this.$grid); }; CDGrid.prototype.styleOfCell = function (cellElt) { var res = {}; ['textAlign', 'color', 'backgroundColor', 'fontWeight', 'whiteSpace'].forEach(key => { if (cellElt.style[key]) res[key] = cellElt.style[key]; }); if (res.textAlign === defaultTextAlignOfElt(cellElt)) delete res.textAlign; if (res.fontWeight === defaultFontWeightOfElt(cellElt)) delete res.fontWeight; if (res.whiteSpace !== 'nowrap') delete res.whiteSpace; for (var k in res) return res; return null; }; CDGrid.prototype.dataOfCell = function (cellElt) { var cellData = {}; var loc = locOfCell(cellElt); if (loc[2] > 1) cellData.rowSpan = loc[2]; if (loc[3] > 1) cellData.colSpan = loc[3]; var style = this.styleOfCell(cellElt); if (style) cellData.style = style; return cellData; }; CDGrid.prototype.makeRow = function (data) { var cells = data.cells || []; return (0,ACore._)({ tag: this.rowCt, class: 'as-ca-row', child: cells.map(it => this.makeCell(it)) }); }; CDGrid.prototype.updateCellLoc = function () { var row, cell; var gridElt = this.$grid; var height = Array(100).fill(0); var jj, loc; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; jj = 0; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; loc = locOfCell(cell); while (height[jj] > i) jj++; cell.attr('data-loc', i + ',' + jj); for (var k = 0; k < loc[3]; ++k) { height[jj + k] = i + loc[2]; } jj += loc[3]; } } var nCol = height.indexOf(0); gridElt.attr('data-width', nCol); return nCol; }; CDGrid.prototype.calcWidth = function () { var row, cell; var gridElt = this.$grid; var height = Array(100).fill(0); var jj, loc; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; jj = 0; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; loc = locOfCell(cell); while (height[jj] > i) jj++; for (var k = 0; k < loc[3]; ++k) { height[jj + k] = i + loc[2]; } jj += loc[3]; } } var nCol = height.indexOf(0); gridElt.attr('data-width', nCol); return nCol; }; CDGrid.prototype.getSize = function () { return { width: parseInt(this.$grid.attr('data-width'), 10), height: this.$grid.childNodes.length } }; CDGrid.prototype.fixRowLength = function (rowLength) { rowLength = rowLength || 1; var row, cell; var gridElt = this.$grid; var height = Array(100).fill(0); var jj, colspan, rowspan; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; jj = 0; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; colspan = parseInt(cell.attr('colspan'), 10) || 1; rowspan = parseInt(cell.attr('rowspan'), 10) || 1; while (height[jj] > i) jj++; for (var k = 0; k < colspan; ++k) { height[jj + k] = i + rowspan; } jj += colspan; } for (j = jj; j < rowLength; ++j) { row.addChild(this.makeCell({}).attr('data-loc', i + ',' + j)); height[j] = i + 1; } } }; CDGrid.prototype.getCellsFromLoc = function (loc) { var row, cell, cellLoc; var res = []; var gridElt = this.$grid; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; cellLoc = locOfCell(cell); if (locCollapse(cellLoc, loc)) res.push(cell); } } var newLoc = locOfCells(res); if (!locEqual(newLoc, loc)) res = this.getCellsFromLoc(newLoc); return res; }; CDGrid.prototype.addRowAt = function (newRowIdx) { var height = Array(50).fill(0); var row, cell, jj; var gridElt = this.$grid; var loc; if (gridElt.firstChild && gridElt.firstChild.lastChild) loc = locOfCell(gridElt.firstChild.lastChild); else loc = [0, 0, 1, 1]; var rowLength = loc[1] + loc[3]; for (var i = 0; i < gridElt.childNodes.length; ++i) { if (i === newRowIdx) { row = this.makeRow({ cell: [] }); gridElt.addChildBefore(row, gridElt.childNodes[i]); jj = 0; while (jj < rowLength) { while (height[jj] > newRowIdx) { jj++; } row.addChild(this.makeCell({})); height[jj] = i + 1; jj++; } ++i; } row = gridElt.childNodes[i]; jj = 0; for (var j = 0; j < row.childNodes.length; ++j) { while (height[jj] > i + 1) jj++; cell = row.childNodes[j]; loc = locOfCell(cell); if (i <= newRowIdx && i + loc[2] > newRowIdx) { loc[2]++; cell.attr('rowspan', loc[2]); } for (var k = 0; k < loc[3]; ++k) { height[jj + k] = i + loc[2]; } jj += loc[3]; } } if (newRowIdx === gridElt.childNodes.length) { row = this.makeRow({ cell: [] }) gridElt.addChild(row); jj = 0; while (jj < rowLength) { while (height[jj] > newRowIdx) jj++; row.addChild(this.makeCell({})); jj++; } } this.updateCellLoc(); } CDGrid.prototype.addColAt = function (newColIdx) { var height = Array(50).fill(0); var row, cell, jj; var gridElt = this.$grid; var colspan, rowspan; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; jj = 0; for (var j = 0; j < row.childNodes.length; ++j) { while (height[jj] > i) jj++; cell = row.childNodes[j]; colspan = parseInt(cell.getAttribute('colspan'), 10) || 1; rowspan = parseInt(cell.getAttribute('rowspan'), 10) || 1; if (jj === newColIdx) { row.addChildBefore(this.makeCell({}), cell); height[jj] = i + 1; j++; jj++; } else if (jj <= newColIdx && jj + colspan > newColIdx) { colspan++; cell.attr('colspan', colspan); } height[jj] = i + rowspan; jj += colspan; } if (jj === newColIdx) { row.addChild(this.makeCell({})); height[jj] = i + 1; } } this.updateCellLoc(); }; /** * * @param rowIdx * @param {number=} rowHeight */ CDGrid.prototype.removeRowAt = function (rowIdx, rowHeight) { if (!(0,utils.isNaturalNumber)(rowHeight)) rowHeight = 1; rowHeight = rowHeight || 1; var body = this.$grid; var row, cell; var loc; var rmLoc = [rowIdx, 0, rowHeight, 100]; var needSplitLocs = []; var needSplitCells = []; var childSplitCells = []; var i, j; for (i = 0; i < body.childNodes.length; ++i) { row = body.childNodes[i]; for (j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; loc = locOfCell(cell); if ((loc[2] > 1 || loc[3] > 1) && locCollapse(rmLoc, loc) && !locInLoc(loc, rmLoc)) { needSplitLocs.push(loc); needSplitCells.push(cell); childSplitCells.push(Array.prototype.slice.call(cell.childNodes)); } } } for (i = 0; i < needSplitCells.length; ++i) { this.splitCell(needSplitCells[i]); loc = needSplitLocs[i]; if (loc[0] < rowIdx) { if (loc[0] + loc[2] <= rowIdx + rowHeight) { loc[2] = rowIdx - loc[0]; } else { loc[2] -= rowHeight; } } else { loc[2] -= rowIdx + rowHeight - loc[0]; } } for (i = rowIdx + rowHeight - 1; i >= rowIdx; --i) { body.childNodes[i].remove(); } this.updateCellLoc(); var cells; for (i = 0; i < needSplitLocs.length; ++i) { loc = needSplitLocs[i]; cells = this.getCellsFromLoc(loc); cells[0].addChild(childSplitCells[i]); this.mergeCells(cells); } this.updateCellLoc(); }; /** * * @param colIdx * @param {number=} colWidth */ CDGrid.prototype.removeColAt = function (colIdx, colWidth) { if (!(0,utils.isNaturalNumber)(colWidth)) colWidth = 1; colWidth = colWidth || 1; var gridElt = this.$grid; var row, cell; var loc; var rmLoc = [0, colIdx, 100, colWidth]; var needSplitLocs = []; var needSplitCells = []; var childSplitCells = []; var i, j; for (i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; for (j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; loc = locOfCell(cell); if ((loc[2] > 1 || loc[3] > 1) && locCollapse(rmLoc, loc) && !locInLoc(loc, rmLoc)) { needSplitLocs.push(loc); needSplitCells.push(cell); childSplitCells.push(Array.prototype.slice.call(cell.childNodes)); } } } for (i = 0; i < needSplitCells.length; ++i) { this.splitCell(needSplitCells[i]); loc = needSplitLocs[i]; if (loc[1] < colIdx) { if (loc[1] + loc[3] <= colIdx + colWidth) { loc[3] = colIdx - loc[1]; } else { loc[3] -= colWidth; } } else { loc[3] -= colIdx + colWidth - loc[1]; } } var cells = this.getCellsFromLoc(rmLoc); cells.forEach(cell => cell.remove()); this.updateCellLoc(); for (i = 0; i < needSplitLocs.length; ++i) { loc = needSplitLocs[i]; cells = this.getCellsFromLoc(loc); cells[0].addChild(childSplitCells[i]); this.mergeCells(cells); } this.updateCellLoc(); }; CDGrid.prototype.mergeCells = function (cells) { var loc = locOfCells(cells); var cell0 = cells[0]; cell0.attr({ rowspan: loc[2], colspan: loc[3] }); for (var i = 1; i < cells.length; ++i) { cell0.addChild((0,ACore.$$)('.as-cag-var', cells[i])); cells[i].remove(); } this.updateCellLoc(); }; CDGrid.prototype.splitCell = function (originalCell) { // var originalLoc = locOfCell(originalCell); var height = Array(100).fill(0); var loc; var gridElt = this.$grid; var size = this.getSize(); loc = [0, 0, size.height, size.width]; var rowLength = loc[1] + loc[3]; originalCell.attr('rowspan', undefined); originalCell.attr('colspan', undefined); var row, cell; var jj; for (var i = 0; i < gridElt.childNodes.length; ++i) { row = gridElt.childNodes[i]; jj = 0; while (height[jj] > i) ++jj; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; loc = locOfCell(cell); while (jj < loc[1]) { if (height[jj] <= i) { row.addChildBefore(this.makeCell({}), cell); height[jj] = i + 1; ++j; } ++jj; } for (var k = 0; k < loc[3]; ++k) { height[jj + k] = i + loc[2]; } jj += loc[3]; while (height[jj] > i) ++jj; } while (jj < rowLength) { row.addChild(this.makeCell({})); height[jj] = i + 1; ++jj; ++j; } } this.updateCellLoc(); }; /** * @typedef CDGData * @property {CDGDataRow[]} */ /** * @typedef CDGDataRow * @property {CDGDataCell[]} */ /** * @typedef CDGDataCell * @property {{}} style * @property {string} text */ Object.defineProperty(CDGrid.prototype, 'data', { set: function (value) { this.$grid.clearChild(); var rows = (value && value.rows) || []; if (rows.length === 0) rows.push({ cells: [{}] }); this.$grid.addChild(rows.map(it => this.makeRow(it))); var nCol = this.updateCellLoc(); this.fixRowLength(nCol); }, get: function () { var res = {}; res.rows = Array.prototype.map.call(this.$grid.childNodes, (rowElt) => { var rowData = {}; rowData.cells = Array.prototype.map.call(rowElt.childNodes, cellElt => { return this.dataOfCell(cellElt); }); return rowData; }) return res; }, configurable: true }); /** * @extends CDGrid * @param {CDContext} context * @param {CDTable} table * @constructor */ function CDTableBody(context, table) { CDGrid.call(this, context); this.table = table; } (0,OOP/* mixClass */.Jx)(CDTableBody, CDGrid); CDTableBody.prototype.gridCt = 'tbody'; CDTableBody.prototype.makeCell = function (data) { var variables = data.variables || []; var attr = {}; if ((0,utils.isNaturalNumber)(data.rowSpan) && data.rowSpan > 1) { attr.rowspan = data.rowSpan; } else if ((0,utils.isNaturalNumber)(data.rowspan) && data.rowspan > 1) { attr.rowspan = data.rowspan; } if ((0,utils.isNaturalNumber)(data.colSpan) && data.colSpan > 1) { attr.colspan = data.colSpan; } else if ((0,utils.isNaturalNumber)(data.colspan) && data.colspan > 1) { attr.colspan = data.colspan; } return (0,ACore._)({ tag: 'td', attr: attr, class: 'as-ca-cell', style: data.style ||{}, child: variables.map(it => { it = normalizeUsedVariable(it); var name = it.name; return this.context.varMng.pickVariable(name); }) }); }; CDTableBody.prototype.dataOfCell = function (cellElt) { var cellData = CDGrid.prototype.dataOfCell.call(this, cellElt); var variables = (0,ACore.$$)('.as-cag-var', cellElt).map(varElt => variableDataOfElt(varElt)).filter(x => !!x); if (variables.length > 0) cellData.variables = variables; return cellData; }; /** * * @param {CDContext} context * @constructor */ function CDTable(context) { /** * * @type {CDContext} */ this.context = context; this.header = new CDTableHeader(context, this); this.body = new CDTableBody(context, this); this.$table = (0,ACore._)({ tag: 'table', class: 'as-cdg-table', child: [ this.header.$grid, this.body.$grid ] }); this.header.hidden = true;//default this.header.data = { rows: [{ cells: [{}] }] } } CDTable.prototype.autoFixRowsWidth = function () { var hL = this.header.calcWidth(); var bL = Math.max(1, this.body.calcWidth()); if (hL < bL) { this.header.fixRowLength(bL); } else if (hL > bL) { this.body.fixRowLength(bL); } }; /** * @extends CDGrid * @param {CDContext} context * @param {CDTable} table * @constructor */ function CDTableHeader(context, table) { CDGrid.call(this, context); this.table = table; } (0,OOP/* mixClass */.Jx)(CDTableHeader, CDGrid); CDTableHeader.prototype.gridCt = 'thead'; CDTableHeader.prototype.cellCt = 'th'; CDTableHeader.prototype.makeCell = function (data) { var res = CDGrid.prototype.makeCell.call(this, data); var beforeValue; var input = (0,ACore._)({ tag: js_PreInput, attr: { contenteditable: 'true', spellcheck: 'false' }, props: { value: (data.text || ' ') + '' }, on: { focus: function () { beforeValue = input.value; }, blur: () => { if (input.value !== beforeValue) { this.context.lcEmitter.emit(EV_CELL_DATA_CHANGE); } beforeValue = undefined; } } }); res.addChild(input); return res; }; CDTableHeader.prototype.dataOfCell = function (cellElt) { var cellData = CDGrid.prototype.dataOfCell.call(this, cellElt); cellData.text = cellElt.firstChild.value; return cellData; }; Object.defineProperty(CDTableHeader.prototype, 'hidden', { set: function (value) { if (value) { this.$grid.addClass('as-hidden'); } else { this.$grid.removeClass('as-hidden'); } }, get: function () { return this.$grid.hasClass('as-hidden'); }, configurable: true }); /** * * @param {CDContext} context * @constructor */ function CDSelectController(context) { this.context = context; this.editor = context.editor; this.lcEmitter = context.lcEmitter; Object.keys(this.constructor.prototype).filter(k => k.startsWith('ev_')) .forEach(key => this[key] = this[key].bind(this)); this.selectedGrid = null; this.selectedCells = []; (0,ACore._)({ tag: 'hanger', elt: this.context.table.$table, on: { draginit: this.ev_dragInit, drag: this.ev_drag, dragdeinit: this.ev_dragDeinit } }); } CDSelectController.prototype.cellOf = function (o) { while (o) { if (o.hasClass && o.hasClass('as-ca-cell')) return o; o = o.parentElement; } return null; }; /** * * @param {Vec2} pos */ CDSelectController.prototype.cellOfScreenPos = function (pos) { var row, cell, bound; var body = this.startingGrid.$grid; for (var i = 0; i < body.childNodes.length; ++i) { row = body.childNodes[i]; for (var j = 0; j < row.childNodes.length; ++j) { cell = row.childNodes[j]; bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(cell.getBoundingClientRect()); if (bound.containsPoint(pos)) return cell; } } return null; }; CDSelectController.prototype.ev_dragInit = function (event) { var cell = null; if (event.target.hasClass && event.target.hasClass('as-ca-cell')) { cell = event.target; } this.startingCell = cell; this.mouseDownCell = this.cellOf(event.target); if (this.mouseDownCell) { this.startingGrid = this.mouseDownCell.isDescendantOf(this.context.table.header.$grid) ? this.context.table.header : this.context.table.body; } this.hoveringCells = []; }; CDSelectController.prototype.ev_drag = function (event) { if (!this.startingCell) return; var curCell = this.cellOfScreenPos(event.currentPoint); if (!curCell) return; var startingLoc = locOfCell(this.startingCell); var endingLoc = locOfCell(curCell); var selectedLoc = mergeLoc(startingLoc, endingLoc); this.hoveringCells.forEach(cell => { cell.removeClass('as-hovering'); }); this.hoveringCells = this.startingGrid.getCellsFromLoc(selectedLoc); this.hoveringCells.forEach(cell => { cell.addClass('as-hovering'); }); }; CDSelectController.prototype.ev_dragDeinit = function (event) { this.hoveringCells.forEach(cell => { cell.removeClass('as-hovering'); }); if (this.hoveringCells.length > 0) { this.selectCells(this.hoveringCells); } else if (this.cellOf(event.target) === this.mouseDownCell) { this.selectCells([this.mouseDownCell]); } this.hoveringCells = null; this.hoveringCells = []; }; CDSelectController.prototype.selectCells = function (cells) { this.selectedCells.forEach(cell => cell.removeClass('as-selected')); this.selectedCells = cells.slice(); this.selectedCells.forEach(cell => cell.addClass('as-selected')); var focsVar = (0,ACore.$)('td.as-selected .as-cag-var.as-focus', this.editor); if (!focsVar) { focsVar = (0,ACore.$)('td.as-selected .as-cag-var', this.editor); this.context.varMng.focus(focsVar || null); } var sel, range; if (!focsVar) { focsVar = (0,ACore.$)('th.as-selected preinput', this.editor); if (focsVar) { sel = document.getSelection(); if (sel.rangeCount) { range = sel.getRangeAt(0); if (range.startContainer.nodeType !== Node.TEXT_NODE || range.startContainer.parentElement !== focsVar) { focsVar.focus(); focsVar.select(focsVar.value.length); } } else { focsVar.focus(); focsVar.select(focsVar.value.length); } } } this.lcEmitter.emit(EV_SELECTED_CELL_CHANGE); }; /** * * @param context * @constructor */ function CDGVariableManager(context) { this.context = context; this.editor = context.editor; this.lcEmitter = context.lcEmitter; /** * * @type {CDGrid} */ this.body = context.table.body; this.createView(); this._variables = []; this.variableDict = {}; this.pickedVariables = {}; this.availableVariables = {}; Object.keys(this.constructor.prototype).filter(k => k.startsWith('ev_')) .forEach(key => this[key] = this[key].bind(this)); this.focusVariable = null; } CDGVariableManager.prototype.focus = function (varElt) { if (this.focusVariable) { this.focusVariable.removeClass('as-focus'); } this.focusVariable = varElt; if (this.focusVariable) { this.focusVariable.addClass('as-focus'); } }; CDGVariableManager.revokeResource = function () { this.editor = undefined; this.grid = undefined; }; CDGVariableManager.prototype.createView = function () { this.$varMng = (0,ACore._)({ class: 'as-cag-var-mng', child: [] }); this.editor.addChildAfter(this.$varMng, this.context.formatTool.$tool); }; /** * * @param {string} name * @returns {*} */ CDGVariableManager.prototype.makeVariable = function (name) { var info = this.variableDict[name] || {}; var elt = (0,ACore._)({ tag: 'hanger', class: 'as-cag-var', attr: { 'data-name': name, }, child: [ // { tag: 'span', child: { text: name } } ], props: { hangOn: 3, }, on: { dragstart: this.ev_dragStart, dragend: this.ev_dragEnd, drag: this.ev_drag, click: () => { this.focus(elt); } } }); if (typeof info.title === "string") { elt.attr('data-title', info.title); } if (info) { elt.attr('data-default-title', info.title); } return elt; }; CDGVariableManager.prototype.pickVariable = function (name) { if (this.availableVariables[name]) { this.pickedVariables[name] = this.availableVariables[name]; delete this.availableVariables[name]; } else if (!this.pickedVariables[name]) { this.pickedVariables[name] = this.makeVariable(name); } return this.pickedVariables[name]; }; CDGVariableManager.prototype.rejectVariable = function (name) { if (this.pickedVariables[name]) { this.availableVariables[name] = this.pickedVariables[name]; delete this.pickedVariables[name]; } this.$varMng.addChild(this.availableVariables[name]); return this.availableVariables[name]; }; CDGVariableManager.prototype.rejectAllVariables = function () { Object.keys(this.pickedVariables).forEach(name => this.rejectVariable(name)); }; CDGVariableManager.prototype.variableElementOf = function (o) { var name = varNameOf(o); if (name === "string") return this.availableVariables[o] || this.pickedVariables[o]; if ((0,Dom/* isDomNode */.mV)(o)) { while (o) { if (o.hasClass && o.hasClass('as-cag-var')) { return o; } o = o.parentElement; } } return null; }; CDGVariableManager.prototype.findVariableLocation = function (rect) { var cells = (0,ACore.$$)('.as-ca-cell', this.body.$grid); var best = 0; var cellRect; var bestCell; var square; var i; for (i = 0; i < cells.length; ++i) { cellRect = Rectangle/* default.fromClientRect */.Z.fromClientRect(cells[i].getBoundingClientRect()); square = rect.collapsedSquare(cellRect); if (square > best) { bestCell = cells[i]; } } var res = { in: null }; if (bestCell) { res.in = bestCell; } else { res.in = null; } var varEltList, varElt, varBound; if (res.in) { varEltList = (0,ACore.$$)('.as-cag-var', res.in); res.bf = 'end'; for (i = varEltList.length - 1; i >= 0; --i) { varElt = varEltList[i]; if (!varElt.attr('data-default-title')) continue; varBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(varElt.getBoundingClientRect()); if (varBound.centerPoint().x > rect.centerPoint().x) { res.bf = varElt; } else break; } return res; } else { return null; } }; /** * * @param {AElement=} elt */ CDGVariableManager.prototype.openEditVariableDialog = function (elt) { elt = elt || this.focusVariable; if (!elt) return; var flushData = () => { var newTile = checkbox.checked ? undefined : titleInput.value; var oldTile = elt.attr('data-title'); if (typeof oldTile !== "string") oldTile = undefined; if (newTile !== oldTile) { elt.attr('data-title', newTile); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } } var finish = () => { flushData(); cancel(); } var cancel = () => { document.removeEventListener('click', clickOut); elt = null; follower.followTarget = null; follower.clearChild(); follower.remove(); ResizeSystem/* default.removeTrash */.Z.removeTrash(); finish = undefined; cancel = undefined; clickOut = undefined; } var clickOut = event => { if ((0,EventEmitter/* hitElement */.EY)(follower, event)) return; cancel(); }; setTimeout(() => { document.addEventListener('click', clickOut); }, 100); var checkboxUpdate = () => { if (checkbox.checked) { titleInput.disabled = true; titleInput.savedData = titleInput.value; titleInput.value = ''; } else { titleInput.disabled = false; titleInput.value = titleInput.value || titleInput.savedData || ''; } } var follower = (0,ACore._)({ tag: Follower/* default */.Z, class: ['as-dropdown-box-common-style', 'as-cdg-variable-edit-dialog'], style: { zIndex: (0,utils.findMaxZIndex)(elt) + 10, }, child: [ { style: { fontWeight: 'bold', padding: '10px 5px' }, child: { text: 'Tiêu đề' } }, { class: 'as-table-grid', child: [ { class: 'as-table-grid-row', child: [ { class: 'as-table-grid-cell', child: { tag: 'span', child: { text: 'Mặc định' } } }, { class: 'as-table-grid-cell', child: { tag: 'checkboxinput', props: { checked: typeof elt.attr('data-title') !== "string" }, on: { change: checkboxUpdate } } }, ] }, { class: 'as-table-grid-row', child: [ { class: 'as-table-grid-cell', child: { tag: 'span', child: { text: 'Giá trị' } } }, { class: 'as-table-grid-cell', child: { tag: 'input', attr: { type: 'text' }, props: { value: elt.attr('data-title') || '' }, class: 'as-text-input' } }, ] } ] }, { style: { textAlign: 'center', padding: '10px' }, child: [{ tag: 'flexiconbutton', props: { text: 'Xác nhận' }, style: { marginRight: '20px' }, on: { click: finish } }, { tag: 'flexiconbutton', props: { text: 'Hủy' }, on: { click: cancel } } ] } ], props: { followTarget: elt, } }).addTo(document.body); var checkbox = (0,ACore.$)('checkboxinput', follower); var titleInput = (0,ACore.$)('input[type="text"]', follower); checkboxUpdate(); }; CDGVariableManager.prototype.ev_dragStart = function (event) { var varElt = this.variableElementOf(event.target); var eltBound = varElt.getBoundingClientRect(); var offset = event.currentPoint.sub(new Vec2/* default */.Z(eltBound.left, eltBound.top)); this.draggingElt = varElt; this.dragOffset = offset; this.clonedElt = (0,ACore.$)(varElt.cloneNode(true)).addClass('as-clone-var').addStyle({ position: 'fixed', zIndex: (0,utils.findMaxZIndex)(varElt) + 2, left: eltBound.left + 'px', top: eltBound.top + 'px' }).addTo(document.body); varElt.addStyle('opacity', 0.8); this.hoverCell = null; }; CDGVariableManager.prototype.ev_drag = function (event) { var newPos = event.currentPoint.sub(this.dragOffset); this.clonedElt.addStyle({ left: newPos.x + 'px', top: newPos.y + 'px' }); var pointerRect = new Rectangle/* default */.Z(event.currentPoint.x - 10, event.currentPoint.y - 10, 20, 20); this.newLocation = this.findVariableLocation(pointerRect); var newLocation = this.newLocation; if (newLocation) { if (newLocation.in !== this.hoverCell) { if (this.hoverCell) this.hoverCell.removeClass('as-drag-over'); this.hoverCell = newLocation.in; this.hoverCell.addClass('as-drag-over'); } if (isChangeParent(newLocation.in, this.draggingElt, newLocation.bf)) { this.hoverCell.addClass('as-bf'); this.hoverCell.addStyle('--hover-x', hoverXOf(newLocation.in, newLocation.bf) + 'px'); } else { this.hoverCell.removeClass('as-bf').removeStyle('--hover-x'); } } else { if (this.hoverCell) this.hoverCell.removeClass('as-drag-over') .removeClass('as-bf').removeStyle('--hover-x'); } }; CDGVariableManager.prototype.ev_dragEnd = function () { this.draggingElt.removeStyle('opacity'); this.clonedElt.remove(); if (this.hoverCell) this.hoverCell.removeClass('as-drag-over'); var name = this.draggingElt.attr('data-name'); var newLocation = this.newLocation; if (newLocation) { if (isChangeParent(newLocation.in, this.draggingElt, newLocation.bf)) { this.draggingElt.selfRemove(); if (newLocation.bf === 'end') { newLocation.in.addChild(this.draggingElt); } else { newLocation.in.addChildBefore(this.draggingElt, newLocation.bf); } this.pickVariable(name); this.context.selectCtrl.selectCells([this.newLocation.in]); this.context.varMng.focus(this.draggingElt); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } } else { if (this.draggingElt.parentElement !== this.$varMng) { this.rejectVariable(name); this.$varMng.addChild(this.draggingElt); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } } }; CDGVariableManager.prototype.updateVariableInfo = function () { var i, elt; var varInfo; for (i in this.availableVariables) { elt = this.availableVariables[i]; varInfo = this.variableDict[i]; if (varInfo) elt.attr('data-default-title', varInfo.title) } for (i in this.pickedVariables) { elt = this.pickedVariables[i]; varInfo = this.variableDict[i]; if (varInfo) elt.attr('data-default-title', varInfo.title); } for (i = 0; i < this._variables.length; ++i) { varInfo = this._variables[i]; if (this.pickedVariables[varInfo.name] || this.availableVariables[varInfo.name]) continue; this.availableVariables[varInfo.name] = this.makeVariable(varInfo.name); this.$varMng.addChild(this.availableVariables[varInfo.name]); } } /// nếu không c trong danh sách thì tự bỏ ra Object.defineProperty(CDGVariableManager.prototype, 'variables', { set: function (variables) { if (!Array.isArray(variables)) variables = []; variables = variables.map(v => normalizeVariableData(v)).filter(x => !!x); var t = variables.reduce((ac, cr) => { if (!ac.dict[cr.name]) { ac.dict[cr.name] = cr; ac.arr.push(cr); } return ac; }, { arr: [], dict: {} }); this._variables = t.arr; this.variableDict = t.dict; this.updateVariableInfo(); // // this.availableVariables = {}; // this.$varMng.clearChild(); }, get: function () { return this._variables; } }); /** * * @param {CDContext} context * @constructor */ function CDUndoManager(context) { this.context = context; this.data = []; this.idx = -1; } CDUndoManager.prototype.revokeResource = function () { this.data = []; this.idx = -1; }; CDUndoManager.prototype.reset = function () { this.data = []; this.idx = -1; return this; } CDUndoManager.prototype.commit = function () { while (this.data.length - 1 > this.idx) this.data.pop(); var item = { header: this.context.table.header.data, data: this.context.table.body.data, headerHidden: this.context.table.header.hidden }; this.data.push(item); this.idx = this.data.length - 1; return this; }; CDUndoManager.prototype._applyTop = function () { var item = this.data[this.idx]; this.context.varMng.rejectAllVariables(); this.context.table.header.data = item.header; this.context.table.header.hidden = item.headerHidden; this.context.table.body.data = item.data; this.context.lcEmitter.emit(EV_UNDO_APPLY); } CDUndoManager.prototype.undo = function () { if (!this.canUndo()) return this; this.idx--; this._applyTop(); return this; }; CDUndoManager.prototype.redo = function () { if (!this.canRedo()) return this; this.idx++; this._applyTop(); return this; }; CDUndoManager.prototype.canRedo = function () { return this.idx + 1 < this.data.length; }; CDUndoManager.prototype.canUndo = function () { return this.idx > 0; }; /** * * @param {CDContext} context * @constructor */ function CDGFormatTool(context) { this.context = context; this.table = context.table; this.editor = context.editor; this.lcEmitter = context.lcEmitter; Object.keys(this.constructor.prototype).filter(k => k.startsWith('ev_')).forEach(k => this[k] = this[k].bind(this)); this.$tool = (0,ACore._)({ class: 'as-table-of-text-input-tool', child: [ { class: 'as-table-of-text-input-tool-group', child: [ { tag: RibbonButton/* default */.Z, attr: { "data-command": 'toggle_header' }, props: { items: [ { text: 'Show Header', arg: true, icon: (0,ACore._)(table_header_add).addClass('as-show-header') }, { text: 'Hide Header', arg: false, icon: table_header_add } ], icon: (0,ACore._)(table_header_add).addClass('as-show-header') } } ] }, { class: 'as-table-of-text-input-tool-group', child: [ { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-undo', attr: { 'data-command': 'undo', title: 'Undo' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-redo', attr: { 'data-command': 'redo', title: 'Redo' } }, ] }, { class: 'as-table-of-text-input-tool-group', child: [ { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-column-plus-before', attr: { 'data-command': 'left', title: 'Insert 1 column left' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-column-plus-after', attr: { 'data-command': 'right', title: 'Insert 1 column right' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-row-plus-before', attr: { 'data-command': 'above', title: 'Insert 1 row above' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], child: 'span.mdi.mdi-table-row-plus-after', attr: { 'data-command': 'bellow', title: 'Insert 1 row bellow' } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command', 'as-variant-danger'], attr: { 'data-command': 'removeCol', title: 'Delete column' }, child: { tag: 'span', class: ['mdi', 'mdi-table-column-remove'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command', 'as-variant-danger'], attr: { 'data-command': 'removeRow', title: 'Delete row' }, child: { tag: 'span', class: ['mdi', 'mdi-table-row-remove'], }, }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'merge', title: 'Merge Cells' }, child: { tag: 'span', class: ['mdi', 'mdi-table-merge-cells'], }, }] }, { class: 'as-table-of-text-input-tool-group', child: [ { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'textAlignLeft', title: 'Format text align left' }, child: { tag: 'span', class: ['mdi', 'mdi-format-align-left'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'textAlignCenter', title: 'Format text align center' }, child: { tag: 'span', class: ['mdi', 'mdi-format-align-center'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'textAlignRight', title: 'Format text align right' }, child: { tag: 'span', class: ['mdi', 'mdi-format-align-right'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'textFormatBold', title: 'Bold' }, child: { tag: 'span', class: ['mdi', 'mdi-format-bold'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'textFormatItalic', title: 'Italic' }, child: { tag: 'span', class: ['mdi', 'mdi-format-italic'], } }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'],//can checked attr: { 'data-command': 'wrap', title: 'Allow text wrap', }, child: { tag: 'span', class: ['mdi', 'mdi-wrap'], } } ] }, { tag: 'button', class: ['as-transparent-button', 'as-table-of-text-input-tool-command'], attr: { 'data-command': 'edit_variable' }, child: { tag: 'span', class: ['mdi', 'mdi-tag-edit-outline'], } } ] }); this.editor.addChildAfter(this.$tool, null); this.$commandBtns = (0,ACore.$$)('.as-table-of-text-input-tool >button', this.$tool).concat((0,ACore.$$)('.as-table-of-text-input-tool-group >button', this.$tool)) .reduce((ac, btn) => { var value = btn.attr('data-command'); if (!value) return ac; if (btn.isSupportedEvent('select')) { btn.on('select', (event) => { this.commands[value].exec.call(this, event.item.arg); }); } else btn.on('click', ev => { if (this.commands[value].checked) { this.commands[value].exec.call(this, !btn.hasClass('as-checked')); } else { this.commands[value].exec.call(this); } }); ac[value] = btn; return ac; }, {}); this.updateAvailableCommands(); this.lcEmitter.on(EV_SELECTED_CELL_CHANGE, this.updateAvailableCommands.bind(this)); } CDGFormatTool.prototype.updateAvailableCommands = function () { Object.values(this.$commandBtns).forEach(btn => { var name = btn.attr('data-command'); if (this.commands[name] && this.commands[name].available) { btn.disabled = !this.commands[name].available.call(this); } if (this.commands[name] && this.commands[name].checked) { if (this.commands[name].checked.call(this)) { btn.addClass('as-checked'); } else { btn.removeClass('as-checked'); } } else if (this.commands[name] && this.commands[name].getIcon) { btn.icon = this.commands[name].getIcon.call(this); } }); }; CDGFormatTool.prototype.addColAt = function (newColIdx) { this.table.header.addColAt(newColIdx); this.table.body.addColAt(newColIdx); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; CDGFormatTool.prototype.addRowAt = function (grid, newRowIdx) {//todo: wrong grid.addRowAt(newRowIdx); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; CDGFormatTool.prototype.removeRowAt = function (grid, rowIdx, rowHeight) { grid.removeRowAt(rowIdx, rowHeight); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; CDGFormatTool.prototype.removeColAt = function (rowIdx, colWidth) { this.table.header.removeColAt(rowIdx, colWidth); this.table.body.removeColAt(rowIdx, colWidth); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; CDGFormatTool.prototype.mergeCells = function (grid, cells) { grid.mergeCells(cells); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; CDGFormatTool.prototype.splitCell = function (grid, originalCell) { grid.splitCell(originalCell); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); }; /** * @this CDGFormatTool */ function hasSelectedCell() { var selectedCells = this.context.selectCtrl.selectedCells; return selectedCells.length > 0; } var checkTextAlign = alignVal => function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; for (var i = 0; i < selectedCells.length; ++i) { if (textAlignOfElt(selectedCells[i]) !== alignVal) return false; } return true; }; CDGFormatTool.prototype.commands = { undo: { /** * @this CDGFormatTool */ available: function () { return this.context.undoMng.canUndo(); }, exec: function () { this.context.undoMng.undo(); } }, redo: { available: function () { return this.context.undoMng.canRedo(); }, exec: function () { this.context.undoMng.redo(); } }, toggle_header: { /** * @this CDGFormatTool */ getIcon: function () { if (this.context && this.context.table.header.hidden) { return (0,ACore._)(table_header_add); } else { return (0,ACore._)(table_header_add).addClass('as-show-header') } }, /** * @this CDGFormatTool */ exec: function (arg) { if (!this.context.table.header.hidden === !!arg) return; this.context.table.header.hidden = !arg; this.lcEmitter.emit(EV_SELECTED_CELL_CHANGE); this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, left: { available: hasSelectedCell, /** * @this CDGFormatTool */ exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); var newColIdx = loc[1]; this.addColAt(newColIdx); } }, right: { available: hasSelectedCell, /** * @this CDGFormatTool */ exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); var newColIdx = loc[1] + loc[3]; this.addColAt(newColIdx); } }, above: { available: hasSelectedCell, /** * @this CDGFormatTool */ exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); var newRowIdx = loc[0]; var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; this.addRowAt(grid, newRowIdx); } }, bellow: { available: hasSelectedCell, /** * @this CDGFormatTool */ exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); var newRowIdx = loc[0] + loc[2]; var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; this.addRowAt(grid, newRowIdx); } }, removeRow: { available: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var loc = locOfCells(selectedCells); var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; var size = grid.getSize(); return loc[2] < size.height; }, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; this.removeRowAt(grid, loc[0], loc[2]); this.context.selectCtrl.selectCells([]); } }, removeCol: { available: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var loc = locOfCells(selectedCells); var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; var size = grid.getSize(); return loc[3] < size.width; }, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return; var loc = locOfCells(selectedCells); // var grid = this.context.table.body; // if (this.context.table.header.hasCell(selectedCells[0])) // grid = this.context.table.header; this.removeColAt(loc[1], loc[3]); this.context.selectCtrl.selectCells([]); } }, merge: { checked: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (selectedCells.length !== 1) return false; var loc = locOfCells(selectedCells); return loc[2] > 1 || loc[3] > 1; }, available: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var loc = locOfCells(selectedCells); return loc[2] > 1 || loc[3] > 1; }, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var loc = locOfCells(selectedCells); var grid = this.context.table.body; if (this.context.table.header.hasCell(selectedCells[0])) grid = this.context.table.header; var isMerged = selectedCells.length === 1 && (loc[2] > 1 || loc[3] > 1); if (isMerged) this.splitCell(grid, selectedCells[0]) else this.mergeCells(grid, selectedCells); selectedCells = grid.getCellsFromLoc(loc); this.context.selectCtrl.selectCells(selectedCells); } }, edit_variable: { /** * @this CDGFormatTool */ available: function () { var fv = this.context.varMng && this.context.varMng.focusVariable; return !!(fv && fv.isDescendantOf(this.context.editor)); }, /** * @this CDGFormatTool */ exec: function () { this.context.varMng.openEditVariableDialog(); } }, textAlignCenter: { checked: checkTextAlign('center'), available: hasSelectedCell, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if ((cell.style.textAlign || defaultTextAlignOfElt(cell)) !== 'center') { cell.style.textAlign = 'center'; changed = true; } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, textAlignRight: { checked: checkTextAlign('right'), available: hasSelectedCell, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if ((cell.style.textAlign || defaultTextAlignOfElt(cell)) !== 'right') { cell.style.textAlign = 'right'; changed = true; } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, textAlignLeft: { checked: checkTextAlign('left'), available: hasSelectedCell, exec: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if ((cell.style.textAlign || defaultTextAlignOfElt(cell)) !== 'left') { cell.style.textAlign = 'left'; changed = true; } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, wrap: { checked: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; for (var i = 0; i < selectedCells.length; ++i) { if (selectedCells[i].style.whiteSpace === 'nowrap') return false; } return true; }, available: hasSelectedCell, exec: function (flag) { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if (cell.style.whiteSpace === 'nowrap') { if (flag) { cell.style.whiteSpace = null; changed = true; } } else { if (!flag) { cell.style.whiteSpace = 'nowrap'; changed = true; } } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, textFormatBold: { checked: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; for (var i = 0; i < selectedCells.length; ++i) { if (fontWeightOfElt(selectedCells[i]) !== 'bold') return false; } return true; }, available: hasSelectedCell, exec: function (flag) { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if (fontWeightOfElt(cell) === 'bold') { if (!flag) { cell.style.fontWeight = 'normal'; changed = true; } } else { if (flag) { cell.style.fontWeight = 'bold'; changed = true; } } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } }, textFormatItalic: { checked: function () { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; for (var i = 0; i < selectedCells.length; ++i) { if (fontStyleOfElt(selectedCells[i]) !== 'italic') return false; } return true; }, available: hasSelectedCell, exec: function (flag) { var selectedCells = this.context.selectCtrl.selectedCells; if (!selectedCells.length) return false; var changed = false; var cell; for (var i = 0; i < selectedCells.length; ++i) { cell = selectedCells[i]; if (fontStyleOfElt(cell) === 'italic') { if (!flag) { cell.style.fontStyle = 'normal'; changed = true; } } else { if (flag) { cell.style.fontStyle = 'italic'; changed = true; } } } if (changed) this.lcEmitter.emit(EV_CELL_DATA_CHANGE); } } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/SelectRibbonMenu.js var addSelectedClass = item => { if (!item) return; if (Array.isArray(item.extendClasses)) { item.extendClasses.push('as-ribbon-selected'); } else { item.extendClasses = [item.extendClasses, 'as-ribbon-selected'].filter(x => !!x); } } var removeSelectedClass = item => { if (!item) return; if (Array.isArray(item.extendClasses)) { item.extendClasses = item.extendClasses.filter(it => it !== 'as-ribbon-selected'); } } /** * @extends {RibbonButton} * @constructor */ function SelectRibbonMenu() { RibbonButton/* default.apply */.Z.apply(this, arguments); this.addClass('as-select-ribbon-menu'); this._itemDict = {}; this._value = null; this.defineEvent('change'); this.on('select', (ev) => { var value = ev.item.value; if (this.value !== value) { this.value = value; this.emit('change', { target: this, type: 'change' }, this); } }); } SelectRibbonMenu.tag = 'SelectRibbonMenu'.toLowerCase(); SelectRibbonMenu.render = RibbonButton/* default.render */.Z.render; SelectRibbonMenu.property = Object.assign({}, RibbonButton/* default.property */.Z.property); SelectRibbonMenu.property.items = { set: function (items) { removeSelectedClass(this.selectedItem); items = items || []; RibbonButton/* default.property.items.set.call */.Z.property.items.set.call(this, items); this._itemDict = {}; var visit = (it) => { var key = (0,utils.keyStringOf)(it.value); this._itemDict[key] = it; } items.forEach(it => visit(it)); var selectedItem = this.selectedItem; addSelectedClass(selectedItem); selectedItem = Object.assign({ text: '', icon: null }, selectedItem); this.text = selectedItem.text; this.icon = selectedItem.icon; }, get: RibbonButton/* default.property.items.get */.Z.property.items.get } SelectRibbonMenu.property.value = { set: function (value) { var selectedItem = this.selectedItem; console.log('clear', selectedItem) removeSelectedClass(selectedItem); this._value = value; selectedItem = this.selectedItem; addSelectedClass(selectedItem); selectedItem = Object.assign({ text: '', icon: null }, selectedItem); this.text = selectedItem.text; this.icon = selectedItem.icon; }, get: function () { if (!this._items || !this._items.length || this._itemDict[(0,utils.keyStringOf)(this._value)]) return this._value; return this._items[0].value; } }; SelectRibbonMenu.property.selectedItem = { get: function () { if (this._itemDict[(0,utils.keyStringOf)(this._value)]) return this._itemDict[(0,utils.keyStringOf)(this._value)]; if (this._items && this._items.length) return this._items[0]; return null; } }; /* harmony default export */ const js_SelectRibbonMenu = (SelectRibbonMenu); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PathView.js /*** * @extends AElement * @constructor */ function PathView() { this._items = []; this.$items = []; } PathView.tag = 'PathView'.toLowerCase(); PathView.render = function () { return (0,ACore._)({ extendEvent: ['press'], class: 'as-path-view' }); }; PathView.property = {}; PathView.property.items = { set: function (value) { this.clearChild(); this._items = value || []; this.$items = this._items.map((item, i, array) => { item = item || {}; var $item = (0,ACore._)({ tag: 'button', class: ['as-path-view-item'], child: [] }); if (item.icon) { $item.addChild((0,ACore._)(item.icon).addClass('as-path-view-item-icon')); } if (item.text || item.name) { $item.addChild((0,ACore._)({ class: 'as-path-view-item-text', child: { text: item.text || item.name || '' } })); } if (i < array.length - 1) { $item.addChild((0,ACore._)({ class: 'as-path-view-item-arrow', child: 'span.mdi.mdi-chevron-right' })); } $item.on('click', (event) => { this.emit('press', { item: item, index: i, items: array, type: 'click', value: item.value, originalEvent: event }); }); this.$items.push($item); return $item; }); this.addChild(this.$items); }, get: function () { return this._items; } }; ACore/* default.install */.Z.install(PathView); /* harmony default export */ const js_PathView = (PathView); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/fontinput.css var fontinput = __webpack_require__(8965); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/FontInput.js const fonts = [ 'Arial', 'Verdana', 'Times New Roman', 'Courier New', 'Georgia', 'Palatino', 'Garamond', 'Bookman', 'Comic Sans MS', 'Trebuchet MS', 'Arial Black', 'Impact', "'Open Sans', sans-serif", "'Roboto', sans-serif", "'Big Shoulders Text', cursive", "'Montserrat', sans-serif", "'Oswald', sans-serif", "'Source Sans Pro', sans-serif", "'Roboto Condensed', sans-serif", "'Literata', serif", "'Roboto Mono', monospace", "'Roboto Slab', serif", "'Merriweather', serif", "'Noto Sans', sans-serif", "'Lora', serif", "'Muli', sans-serif", "'Open Sans Condensed', sans-serif", "'Playfair Display', serif", "'Nunito', sans-serif", "'Noto Serif', serif", "'Fira Sans', sans-serif", "'Inconsolata', monospace", "'Dosis', sans-serif", "'Nunito Sans', sans-serif", "'Arimo', sans-serif", "'Quicksand', sans-serif", "'Cabin', sans-serif", "'Josefin Sans', sans-serif", "'Varela Round', sans-serif", "'Anton', sans-serif", "'Lobster', cursive", "'Yanone Kaffeesatz', sans-serif", "'Source Code Pro', monospace", "'Baloo Bhai', cursive", "'Barlow', sans-serif", "'Dancing Script', cursive", "'Pacifico', cursive", "'Exo 2', sans-serif", "'Barlow Semi Condensed', sans-serif", "'EB Garamond', serif", "'Archivo Narrow', sans-serif", "'Asap', sans-serif", "'Comfortaa', cursive", "'Barlow Condensed', sans-serif", "'IBM Plex Sans', sans-serif", "'Maven Pro', sans-serif", "'Play', sans-serif", "'Exo', sans-serif", "'Amatic SC', cursive", "'Kanit', sans-serif", "'Fira Sans Condensed', sans-serif", "'Noto Sans SC', sans-serif", "'Vollkorn', serif", "'Prompt', sans-serif", "'Rokkitt', serif", "'Cuprum', sans-serif", "'Alegreya Sans', sans-serif", "'Francois One', sans-serif", "'Cormorant Garamond', serif", "'Alegreya', serif", "'Alfa Slab One', cursive", "'Noticia Text', serif", "'Saira Extra Condensed', sans-serif", "'Old Standard TT', serif", "'Tinos', serif", "'Fira Sans Extra Condensed', sans-serif", "'IBM Plex Serif', serif", "'Patrick Hand', cursive", "'M PLUS 1p', sans-serif", "'Prata', serif", "'Philosopher', sans-serif", "'Saira Semi Condensed', sans-serif", "'Archivo', sans-serif", "'Big Shoulders Display', cursive", "'Bangers', cursive", "'Playfair Display SC', serif", "'Cabin Condensed', sans-serif", "'Paytone One', sans-serif", "'Montserrat Alternates', sans-serif", "'Taviraj', serif", "'Spectral', serif", "'Lalezar', cursive", "'Asap Condensed', sans-serif", "'M PLUS Rounded 1c', sans-serif", "'Sigmar One', cursive", "'Saira', sans-serif", "'Pridi', serif", "'Mitr', sans-serif", "'Baloo', cursive", "'Cormorant', serif", "'Sarabun', sans-serif", "'Saira Condensed', sans-serif", "'Be Vietnam', sans-serif", "'Yeseva One', cursive", "'Lexend Peta', sans-serif", "'Alegreya Sans SC', sans-serif", "'IBM Plex Mono', monospace", "'Jura', sans-serif", "'Bevan', cursive", "'Lexend Exa', sans-serif", "'Sawarabi Gothic', sans-serif", "'Cousine', monospace", "'Markazi Text', serif", "'VT323', monospace", "'Baloo Bhaina', cursive", "'Space Mono', monospace", "'Encode Sans', sans-serif", "'Encode Sans Semi Expanded', sans-serif", "'Arima Madurai', cursive", "'Lexend Deca', sans-serif", "'Lexend Tera', sans-serif", "'Lexend Giga', sans-serif", "'Lexend Zetta', sans-serif", "'Lexend Mega', sans-serif", "'Arsenal', sans-serif", "'Itim', cursive", "'Noto Serif SC', serif", "'Pangolin', cursive", "'Lemonada', cursive", "'Encode Sans Condensed', sans-serif", "'Bai Jamjuree', sans-serif", "'Alegreya SC', serif", "'Noto Serif TC', serif", "'Judson', serif", "'Livvic', sans-serif", "'Krub', sans-serif", "'Trirong', serif", "'Niramit', sans-serif", "'Bungee Inline', cursive", "'Mali', cursive", "'Pattaya', sans-serif", "'Rosario', sans-serif", "'Bungee', cursive", "'Sriracha', cursive", "'Metrophobic', sans-serif", "'Faustina', serif", "'Darker Grotesque', sans-serif", "'Encode Sans Expanded', sans-serif", "'Chakra Petch', sans-serif", "'IBM Plex Sans Condensed', sans-serif", "'Maitree', serif", "'Baloo Bhaijaan', cursive", "'Cormorant Infant', serif", "'Saira Stencil One', cursive", "'Chonburi', cursive", "'Barriecito', cursive", "'Bahianita', cursive", "'Athiti', sans-serif", "'Sedgwick Ave', cursive", "'Patrick Hand SC', cursive", "'Srisakdi', cursive", "'Cormorant SC', serif", "'Andika', sans-serif", "'Podkova', serif", "'Bungee Shade', cursive", "'Baloo Da', cursive", "'Spectral SC', serif", "'Baloo Thambi', cursive", "'Baloo Chettan', cursive", "'Cormorant Upright', serif", "'Encode Sans Semi Condensed', sans-serif", "'Charm', cursive", "'Baloo Paaji', cursive", "'K2D', sans-serif", "'Farsan', cursive", "'David Libre', serif", "'Coiny', cursive", "'Baloo Tamma', cursive", "'Manuale', serif", "'Thasadith', sans-serif", "'Vollkorn SC', serif", "'Bungee Hairline', cursive", "'Kodchasan', sans-serif", "'Hepta Slab', serif", "'Cormorant Unicase', serif", "'Crimson Pro', serif", "'Grenze', serif", "'Charmonman', cursive", "'Baloo Tammudu', cursive", "'KoHo', sans-serif", "'Major Mono Display', monospace", "'Fahkwang', sans-serif", "'Bungee Outline', cursive", "'Sedgwick Ave Display', cursive" ];//only for test /** * @extends Follower * @constructor */ function FontFamilySelectList() { this.on('preupdateposition', this.eventHandler.ffPreUpdatePosition); this.$content = (0,ACore.$)('.as-font-family-select-list-content', this); this.$items = []; this.$selectedItem = null; this.$itemByValue = {}; this.$searchInput = (0,ACore.$)(Searcher/* default.tag */.Z.tag, this); this.$searchInput.on('stoptyping', this.eventHandler.searchChange); /** * * @type {string[]} * @memberOf FontFamilySelectList# */ this.items = fonts; this._searchingHolders = null;//not prepared } FontFamilySelectList.tag = 'FontFamilySelectList'.toLowerCase(); FontFamilySelectList.render = function () { return (0,ACore._)({ tag: Follower/* default */.Z, class: ['as-font-family-select-list', 'as-dropdown-box-common-style'], child: [ { class: 'as-font-family-select-list-header', child: { tag: Searcher/* default */.Z } }, { class: ['as-bscroller', 'as-font-family-select-list-content'], } ] }, true); }; FontFamilySelectList.property = {}; FontFamilySelectList.property.items = { set: function (items) { if (!Array.isArray(items)) items = []; this._items = items; this.$content.clearChild(); this.$itemByValue = {}; this._searchingHolders = null; this.$items = items.map(item => { var text = item.replace(/'/g, ''); text = text.replace(/,.+/, ''); var itemElt = (0,ACore._)({ class: 'as-font-family-select-item', style: { fontFamily: item }, attr: { 'data-value': item }, child: { text: text }, on: { click: () => { this.value = item; this.emit('select', { value: item }); } } }); this.$itemByValue[item] = itemElt; return itemElt; }); this.$content.addChild(this.$items); }, get: function () { return this._items; } }; FontFamilySelectList.property.value = { set: function (value) { if (this.$selectedItem) this.$selectedItem.removeClass('as-selected'); this._value = value; this.$selectedItem = this.$itemByValue[value]; if (this.$selectedItem) this.$selectedItem.addClass('as-selected'); }, get: function () { if (this.$itemByValue[this._value]) return this._value; return null; } }; FontFamilySelectList.prototype._makeHolder = function (item, value) { var res = { value: value, text: item }; res.text = res.text.trim().toLowerCase(); res.words = res.text.split(/\s+/).filter(w => !!w); res.text = res.words.join(' '); res.nacWords = res.words.map(w => (0,stringFormat.nonAccentVietnamese)(w)); res.nacText = res.nacWords.join(' '); res.nacWordDict = res.nacWords.reduce(function (ac, word) { ac[word] = true; return ac; }, {}); return res; }; FontFamilySelectList.prototype._prepareSearchingHolders = function () { if (this._searchingHolders) return; this._searchingHolders = this.items.map((item, idx) => this._makeHolder(item, idx)); }; FontFamilySelectList.prototype._calcMatching = function (queryHolder, itemHolder) { var res = {}; var score = 0; if (itemHolder.text.indexOf(queryHolder.text) >= 0 || itemHolder.nacText.indexOf(queryHolder.nacText) >= 0) { res.mustIncluded = true; } score += (0,stringMatching.wordsMatch)(queryHolder.words, itemHolder.words) / (0,Math_int.harmonicMean)(queryHolder.words.length, itemHolder.words.length); score += (0,stringMatching.wordsMatch)(queryHolder.nacWords, itemHolder.nacWords) / (0,Math_int.harmonicMean)(queryHolder.nacWords.length, itemHolder.nacWords.length); var dict = Object.keys(itemHolder.nacWordDict); Object.keys(queryHolder.nacWordDict).forEach(function (qWord) { var bestWordScore = 0; var bestWord = ''; var word; for (word in dict) { if ((0,stringMatching.wordLike)(qWord, word) > bestWordScore) { bestWordScore = (0,stringMatching.wordLike)(qWord, word); bestWord = word; } } if (bestWordScore > 0) { score += bestWordScore / (0,Math_int.harmonicMean)(qWord.length, bestWord.length); delete dict[bestWord]; } }); res.score = score; return res; }; FontFamilySelectList.eventHandler = {}; FontFamilySelectList.eventHandler.ffPreUpdatePosition = function () { if (!this.followTarget) return; var bound = this.followTarget.getBoundingClientRect(); var screenSizes = (0,Dom/* getScreenSize */.tE)(); var availableHeight = screenSizes.height - bound.bottom; availableHeight = Math.max(availableHeight, bound.top); availableHeight -= 50; this.$content.addStyle('max-height', availableHeight + 'px'); }; /** * @this FontFamilySelectList */ FontFamilySelectList.eventHandler.searchChange = function () { var query = this.$searchInput.value.trim(); var queryHolder = this._makeHolder(query, -1); var resultHolders, midScore, viewItemElements; if (query.length > 0) { this._prepareSearchingHolders(); this._searchingHolders.forEach((itemHolder) => { var match = this._calcMatching(queryHolder, itemHolder); Object.assign(itemHolder, match); }); resultHolders = this._searchingHolders.slice(); resultHolders.sort(function (a, b) { return b.score - a.score; }); midScore = resultHolders[0].score * 0.7; resultHolders = resultHolders.filter(function (holder) { return holder.score >= midScore || holder.mustIncluded; }); viewItemElements = resultHolders.map(holder => this.$items[holder.value]); this.$content.clearChild().addChild(viewItemElements); } else { this.$content.clearChild().addChild(this.$items); } this.updatePosition(); console.log(query) }; ACore/* default.install */.Z.install(FontFamilySelectList); /** * @extends AElement * @constructor */ function FontInput() { /** * @type {FontFamilySelectList} */ this.$selectList = (0,ACore._)('fontfamilyselectlist'); this.$selectList.cancelWaiting(); this.$selectList.sponsorElement = this; setTimeout(() => { this.$selectList.addTo(document.body); this.$selectList.followTarget = this; }, 100) } FontInput.tag = 'FontInput'.toLowerCase(); FontInput.render = function () { return (0,ACore._)({ class: 'as-font-input', }); }; FontInput.property = {}; /* harmony default export */ const js_FontInput = (FontInput); ACore/* default.install */.Z.install(FontInput); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/collapsibletreenavigator.css var collapsibletreenavigator = __webpack_require__(3478); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CollapsibleTreeNavigator.js /** * note * CTCollapsibleNode can only be selected when it has no children and noSelect = false. * CTNNode can be selected and can have children. */ var NODE_CONTENT_HEIGHT = BrowserDetector/* default.isMobile */.Z.isMobile? 45: 30; var css = new DynamicCSS/* default */.Z(); css.setRule('div.as-collapsible-tree-navigator', { '--node-content-height': NODE_CONTENT_HEIGHT + 'px' }).commit(); /** * @typedef {Object} CTNItemData * @property {string} text * @property {any} string * @property [icon] * @property [noSelect] - default = false */ /** * @extends AElement * @constructor */ function CollapsibleTreeNavigator() { /** * * @type {CTRoot} */ this.root = new CTRoot(this); /** * @type {{text:string, id:any, actiions:{}[]}[]} * @name items * @memberOf CollapsibleTreeNavigator# */ /** * @type {any} * @name value * @memberOf CollapsibleTreeNavigator# */ } CollapsibleTreeNavigator.tag = 'CollapsibleTreeNavigator'.toLowerCase(); CollapsibleTreeNavigator.render = function () { return (0,ACore._)({ class: 'as-collapsible-tree-navigator', extendEvent: ['change', 'action', 'clickitem'] }); }; CollapsibleTreeNavigator.prototype.nodeOf = function (nodeValue) { return this.root.nodeOf(nodeValue); }; CollapsibleTreeNavigator.prototype.updateNode = function (nodeValue, fieldName, value) { var nd = this.nodeOf(nodeValue); if (!nd) return; nd.rawData[fieldName] = value; if (['items', 'text', 'icon', 'value', 'count', 'color'].indexOf(fieldName) >= 0) { nd[fieldName] = value; this.root.updateSize(); } }; /** * * @param {any=}data */ CollapsibleTreeNavigator.prototype.notifyChange = function (data) { var nd; if (!data) {//fallback nd = this.root.nodeByValue[(0,utils.keyStringOf)(this.value)]; data = nd && nd.data; } data = data || null; var value = this.value; if (data) value = data.value; this.emit('change', { type: 'change', value: value, data: data }, this); }; /** * * @param {any=}data */ CollapsibleTreeNavigator.prototype.notifyClick = function (data) { this.emit('clickitem', { type: 'clickitem', data: data }, this); }; CollapsibleTreeNavigator.property = {}; CollapsibleTreeNavigator.property.value = { set: function (value) { this.root.value = value; }, get: function () { return this.root.value; } }; CollapsibleTreeNavigator.property.items = { set: function (items) { this.root.items = items; }, get: function () { return this.root.items; } }; ACore/* default.install */.Z.install(CollapsibleTreeNavigator); /* harmony default export */ const js_CollapsibleTreeNavigator = (CollapsibleTreeNavigator); /** * * @param {CollapsibleTreeNavigator} elt * @constructor */ function CTRoot(elt) { this.elt = elt; /** * * @type {CTCollapsibleNode[]} */ this.children = []; this.nodeByValue = {}; this.iconCount = 0; this.level = 0; this.looked = 0; } CTRoot.prototype.nodeOf = function (nodeValue) { return this.nodeByValue[(0,utils.keyStringOf)(nodeValue)]; } CTRoot.prototype.updateSelectedLine = function () { if (this.looked) return; var selectedNode = this.nodeOf(this.value); if (!selectedNode) return; var path = []; var c = selectedNode; while (c && c !== this) { path.unshift(c); c = c.parent; } var viewingNode = null; while (path.length) { c = path.shift(); viewingNode = c; if (c.status !== 'open') { break; } } if (!viewingNode) return; this.elt.addStyle('--selected-y', viewingNode.offsetY + 'px'); }; CTRoot.prototype.updateSize = function () { if (this.looked) return; this.elt.addStyle('min-width', Math.ceil(this.minWidth) + 'px'); if (this.elt.isDescendantOf(document.body)) { window.dispatchEvent(new Event('resize')); } }; CTRoot.prototype.clear = function () { while (this.children.length > 0) { this.children[0].remove(); } }; CTRoot.prototype.select = function (value) { this.children.forEach(c => c.select(value)); }; Object.defineProperty(CTRoot.prototype, 'offsetHeight', { get: function () { return this.children.reduce((ac, cr) => ac + cr.offsetHeight, 0) } }); Object.defineProperty(CTRoot.prototype, 'offsetY', { get: function () { return 0; } }); Object.defineProperty(CTRoot.prototype, 'contentHeight', { get: function () { return 0; } }); Object.defineProperty(CTRoot.prototype, 'items', { set: function (items) { this.looked++; var prevState = Object.keys(this.nodeByValue).reduce((ac, key) => { ac[key] = this.nodeByValue[key].status; return ac; }, {}); this.clear(); this.children = items.map(function (item) { return new CTCollapsibleNode(this, item); }, this); this.elt.addChild(this.children.map(nd => nd.domElt)); this.select(this.value); Object.keys(this.nodeByValue).forEach(key => { var nd = this.nodeByValue[key]; if (prevState[key] === 'open' && nd.status === 'close') { nd.status = 'open'; } else if (prevState === 'close' && nd.status === 'open') { nd.status = 'close'; } }); this.looked--; this.updateSize(); this.updateSelectedLine(); }, get: function () { return this.children.map((chd) => { return chd.data; }); } }); Object.defineProperty(CTRoot.prototype, 'value', { set: function (value) { this._value = value; this.looked++; this.select(value); this.looked--; this.updateSelectedLine(); }, get: function () { return this._value; } }); Object.defineProperty(CTRoot.prototype, 'data', { set: function (data) { data = Object.assign({ items: [], value: 0 }, data); this.items = data.items; this.value = data.value; }, get: function () { return { items: this.items, value: this.value }; } }); Object.defineProperty(CTRoot.prototype, 'minWidth', { get: function () { return this.children.reduce((ac, cr) => Math.max(ac, cr.minWidth), 0) + 4; } }) /** * * @param {CTRoot} parent * @param data * @constructor */ function CTCollapsibleNode(parent, data) { this.parent = parent; this.nodeByValue = parent.nodeByValue; this.root = parent; this.level = parent.level + 1; this.children = []; this.domElt = (0,ACore._)({ class: 'as-ctn-collapse-node', style: { '--level': this.level + '' }, child: [ { class: 'as-ctn-collapse-node-content', child: [ 'toggler-ico', { class: 'as-ctn-icon-ctn' }, { tag: 'span', class: 'as-ctn-text', child: { text: '' } }, { tag: 'span', class: 'as-ctn-count', style: { display: 'none' }, child: { text: '' } }, { class: 'as-ctn-right', } ], }, { class: 'as-ctn-collapse-node-children-ctn' } ] }); this.$toggler = (0,ACore.$)('toggler-ico', this.domElt); this.$content = (0,ACore.$)('.as-ctn-collapse-node-content', this.domElt); this.$childrenCtn = (0,ACore.$)('.as-ctn-collapse-node-children-ctn', this.domElt); this.$iconCtn = (0,ACore.$)('.as-ctn-icon-ctn', this.domElt); this.$text = (0,ACore.$)('.as-ctn-text', this.domElt); this.$count = (0,ACore.$)('.as-ctn-count', this.domElt); this.$right = (0,ACore.$)('.as-ctn-right', this.domElt); this.data = data; this.$content.on('click', this.ev_click.bind(this)); } CTCollapsibleNode.prototype.remove = function () { this.children.slice().forEach(child => child.remove()); var idx = this.parent.children.indexOf(this); var value = this.value; if (idx >= 0) { delete this.nodeByValue[(0,utils.keyStringOf)(value)]; this.parent.children.splice(idx, 1); this.domElt.remove(); } }; CTCollapsibleNode.prototype.select = function (value) { var res = false; if (this.data.value === value) { this.domElt.addClass('as-selected'); res = true; } else { this.domElt.removeClass('as-selected'); } var childRes = this.children.reduce((ac, it) => it.select(value) || ac, false); if (childRes && this.status === 'close') { this.status = 'open'; } res = res || childRes; return res; }; CTCollapsibleNode.prototype.ev_click = function (event) { if (this.$right && (0,EventEmitter/* hitElement */.EY)(this.$right, event)) return; var rootElt; if (this.domElt.hasClass('as-closing')) return; var isClickItem = false; var noSelect = this.rawData && this.rawData.noSelect; var tgBound; if (this.status === 'none') { isClickItem = !noSelect; } else { tgBound = this.$toggler.getBoundingClientRect(); if (noSelect || event.clientX < tgBound.right) { if (this.status === 'open') { this.status = 'close'; } else if (this.status === 'close') { this.status = 'open'; } } else { isClickItem = true; } } if (isClickItem) { rootElt = this.root.elt; if (rootElt && rootElt.value !== this.value) { rootElt.value = this.value; rootElt.notifyChange(this.data); } rootElt.notifyClick(this.data); } }; Object.defineProperty(CTCollapsibleNode.prototype, 'status', { set: function (value) { var prev = this.status; if (this.children.length > 0) { if (value !== 'open') value = 'close'; } else { value = 'none'; } if (prev === value) return; this._status = value; switch (value) { case 'open': // this.domElt.addStyle('--children-height', this.childrenHeight + 'px'); this.domElt.addClass('as-open').removeClass('as-close'); break; case 'close': // this.domElt.addStyle('--children-height', this.childrenHeight + 'px'); this.domElt.addClass('as-close').removeClass('as-open'); break; default: this.domElt.removeClass('as-open').removeClass('as-close'); break; } this.root.updateSelectedLine(); }, get: function () { return this._status || 'none'; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'icon', { get: function () { return this._icon || null; }, set: function (value) { this.$iconCtn.clearChild(); value = value || null; this._icon = value; if (value) { this.$iconCtn.addChild((0,ACore._)(value)); } } }); Object.defineProperty(CTCollapsibleNode.prototype, 'text', { get: function () { return this._text; }, set: function (value) { if (typeof value === 'number') value = value + ''; value = value || ''; this._text = value; this.$text.firstChild.data = value; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'count', { get: function () { return this._count; }, set: function (value) { if (typeof value !== 'number') value = parseInt(value); value = Math.round(value); if (!(0,utils.isNaturalNumber)(value)) value = 0; this._count = value; if (value) { this.$count.removeStyle('display'); this.$count.firstChild.data = value; } else { this.$count.addStyle('display', 'none'); this.$count.firstChild.data = ''; } } }); Object.defineProperty(CTCollapsibleNode.prototype, 'countDesc', { get: function () { return this._countDesc; }, set: function (value) { value = value || null; this._countDesc = value; if (value) { this.$count.attr('title', value); } else { this.$count.removeAttribute('title'); } } }); Object.defineProperty(CTCollapsibleNode.prototype, 'value', { get: function () { return this._value; }, set: function (value) { var prevValue = this._value; var key = (0,utils.keyStringOf)(prevValue); if (this.nodeByValue[key] === this) { delete this.nodeByValue[key]; } key = (0,utils.keyStringOf)(value); if (this.nodeByValue[key]) { value = value + '_' + (0,stringGenerate.randomIdent)(5); } this._value = value; key = (0,utils.keyStringOf)(value); this.nodeByValue[key] = this; this.domElt.attr('data-value', value + ''); } }); Object.defineProperty(CTCollapsibleNode.prototype, 'color', { get: function () { return this._color; }, set: function (value) { if (typeof value === 'string') { try { value = Color_Color/* default.parse */.Z.parse(value) } catch (e) { value = null; } } else if (!value || !value.getContrastYIQ) { value = null; } var textColor; if (value) { textColor = value.getContrastYIQ(); this.$content.addStyle('color', textColor + ''); this.$content.addStyle('background-color', value + ''); } else { this.$content.removeStyle('color'); this.$content.removeStyle('background-color'); } this._color = value + ''; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'items', { set: function (items) { while (this.children.length > 0) { this.children[0].remove(); } if (!Array.isArray(items)) items = []; this.children = items.map(it => new CTNNode(this, it)); this.$childrenCtn.addChild(this.children.map(c => c.domElt)); if (this.children.length) { if (this.rawData && this.rawData.initOpened) { this.status = 'open'; } else { this.status = 'close'; } } else { this.status = 'none'; } this.root.updateSelectedLine(); }, get: function () { return this.children.map(ch => ch.data); } }); Object.defineProperty(CTCollapsibleNode.prototype, 'actions', { set: function (actions) { if (!Array.isArray(actions)) actions = []; this._actions = actions; this.$right.clearChild(); actions.forEach(action => { var btn = (0,ACore._)({ tag: 'button', class: ['as-transparent-button'], child: action.icon, on: { click: (event) => { this.root.elt.emit('action', { action: action, data: this.rawData, type: 'action' }, this.root.elt); } } }); if (action.text) btn.attr('title', action.text); this.$right.addChild(btn); }); }, get: function () { return this._actions; } }) Object.defineProperty(CTCollapsibleNode.prototype, 'data', { set: function (data) { this.rawData = data || {}; data = Object.assign({ text: '', value: 0, icon: null, count: 0 }, data || {}); this.value = data.value; this.text = data.text; this.icon = data.icon; this.count = data.count; this.items = data.items; this.color = data.color; this.actions = data.actions; this.countDesc = data.countDesc || null; }, get: function () { var res = Object.assign({}, this.rawData, { text: this.text, value: this.value }); if (this.actions && this.actions.length) { res.actions = this.actions; } if (this.icon) res.icon = this.icon; if (this.count) res.count = this.count; if (this.color) res.color = this.color; return res; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'contentHeight', { get: function () { return NODE_CONTENT_HEIGHT + 1;//+1 for border } }); Object.defineProperty(CTCollapsibleNode.prototype, 'childrenHeight', { get: function () { return this.children.reduce((ac, cr) => ac + cr.offsetHeight, 0); } }); Object.defineProperty(CTCollapsibleNode.prototype, 'offsetHeight', { get: function () { var res = this.contentHeight; if (this.status === 'open') res += this.childrenHeight; return res; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'offsetY', { get: function () { var offsetY = this.parent.offsetY + this.parent.contentHeight; var sbs = this.parent.children; var sb; for (var i = 0; i < sbs.length; i++) { sb = sbs[i]; if (sb === this) break; offsetY += sb.offsetHeight; } return offsetY; } }); Object.defineProperty(CTCollapsibleNode.prototype, 'minWidth', { get: function () { var res = 50 + 8;//padding res += 14;//tg icon res += 7;//text margin res += Math.ceil((0,utils.measureText)(this.text, '14px arial').width); var countWidth = 0; if (this.count) { countWidth = (0,utils.measureText)(this.count + '', '14px arial').width + 10;//padding 5 countWidth = Math.ceil(countWidth); countWidth = Math.max(countWidth, 20);//min-width countWidth += 5; //margin } if (this.icon) res += 21; res += countWidth; res = this.children.reduce((ac, cr) => Math.max(ac, cr.minWidth), res); this.domElt.attr('data-min-width', res + ''); return res; } }); /** * * @param {CTNNode|CTCollapsibleNode} parent * @param data * @constructor */ function CTNNode(parent, data) { this.parent = parent; this.nodeByValue = parent.nodeByValue; this.root = parent.root; this.level = parent.level + 1; this.children = []; this.domElt = (0,ACore._)({ class: 'as-ctn-node', style: { '--level': this.level + '' }, child: [ { class: 'as-ctn-node-content', child: [ 'toggler-ico', { class: 'as-ctn-icon-ctn' }, { tag: 'span', class: 'as-ctn-text', child: { text: '' } }, { tag: 'span', class: 'as-ctn-count', style: { display: 'none' }, child: { text: '' } }, '.as-ctn-right' ] }, { class: 'as-ctn-node-children-ctn' } ] }); this.$content = (0,ACore.$)('.as-ctn-node-content', this.domElt); this.$toggler = (0,ACore.$)('toggler-ico', this.domElt); this.$content.on('click', this.ev_click.bind(this)); this.$childrenCtn = (0,ACore.$)('.as-ctn-node-children-ctn', this.domElt); this.$iconCtn = (0,ACore.$)('.as-ctn-icon-ctn', this.domElt); this.$text = (0,ACore.$)('.as-ctn-text', this.domElt); this.$count = (0,ACore.$)('.as-ctn-count', this.domElt); this.$right = (0,ACore.$)('.as-ctn-right', this.domElt); this.data = data; } //copy ['status', 'offsetHeight', 'childrenHeight', 'offsetY', 'select', 'text', 'count', 'countDesc','icon', 'value', 'data', 'items', 'actions', 'remove', 'ev_click', 'color'].forEach(method => { Object.defineProperty(CTNNode.prototype, method, Object.getOwnPropertyDescriptor(CTCollapsibleNode.prototype, method)); }); Object.defineProperty(CTNNode.prototype, 'minWidth', { get: function () { var res = this.level * 25 - 20 + 10;//padding res += 14;//tg icon res += 7;//text margin res += Math.ceil((0,utils.measureText)(this.text, '14px arial').width); this.domElt.attr('data-text-width', Math.ceil((0,utils.measureText)(this.text, '14px arial').width)) var countWidth = 0; if (this.count) { countWidth = (0,utils.measureText)(this.count + '', '14px arial').width + 10;//padding 5 countWidth = Math.ceil(countWidth); countWidth = Math.max(countWidth, 20);//min-width countWidth += 5; //margin-left } res += countWidth; this.domElt.attr('data-local-min-width', res + ''); res = this.children.reduce((ac, cr) => Math.max(ac, cr.minWidth), res); this.domElt.attr('data-min-width', res + ''); return res; } }); Object.defineProperty(CTNNode.prototype, 'contentHeight', { get: function () { return NODE_CONTENT_HEIGHT; } }); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/NotificationPanel.js var NotificationPanel = __webpack_require__(7570); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/pickinglist.css var pickinglist = __webpack_require__(3316); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/PickingList.js /** * @extends AElement * @constructor */ function PickingList() { this._items = []; this._values = []; /** * @type {PLItem[]} */ this.$items = []; /** * @type {any[]} * @name values * @memberOf PickingList# */ /** * @type {{text:string, value}[]} * @name items * @memberOf PickingList# */ } PickingList.tag = 'PickingList'.toLowerCase(); PickingList.render = function () { return (0,ACore._)({ class: 'as-picking-list', extendEvent: 'change', child: [] }) }; PickingList.property = {}; PickingList.property.items = { set: function (items) { items = items || []; this._items = items; this.$items.forEach(function (item) { item.remove(); }); var valuedDict = this._values.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr)] = true; return ac; }, {}) this.$items = items.map(it => { var elt = (0,ACore._)({ tag: PLItem, props: { text: it.text + '', value: it.value, checked: valuedDict[(0,utils.keyStringOf)(it.value)] }, on: { click: () => { elt.checked = !elt.checked; this.emit('change', { target: this, type: 'change' }, this); } } }); return elt; }); this.addChild(this.$items); }, get: function () { return this._items; } }; PickingList.property.values = { set: function (values) { this._values = values || []; var valuedDict = this._values.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr)] = true; return ac; }, {}); this.$items.forEach(function (item) { item.checked = !!valuedDict[(0,utils.keyStringOf)(item.value)]; }) }, get: function () { return this.$items.reduce(function (ac, itemElt) { if (itemElt.checked) { ac.push(itemElt.value); } return ac; }, []); } }; PickingList.property.selectedItems = { get: function () { var valuedDict = this._values.reduce((ac, cr) => { ac[(0,utils.keyStringOf)(cr)] = true; return ac; }, {}); return (this._items || []).filter(it => valuedDict[(0,utils.keyStringOf)(it.value)]); } }; /* harmony default export */ const js_PickingList = (PickingList); ACore/* default.install */.Z.install(PickingList); /** * @extends AElement * @constructor */ function PLItem() { this.$text = (0,ACore.$)('.as-picking-list-item-text', this); } PLItem.tag = 'PLItem'.toLowerCase(); PLItem.render = function () { return (0,ACore._)({ class: 'as-picking-list-item', child: [ { class: 'as-picking-list-item-text', child: { text: '' } }, { class: 'as-picking-list-item-checked', child: 'span.mdi.mdi-check' } ] }); }; PLItem.property = {}; PLItem.property.text = { set: function (value) { this.$text.firstChild.data = value + ''; }, get: function () { return this.$text.firstChild.data; } }; PLItem.property.value = { set: function (value) { this._value = value; this.attr('data-value', (0,utils.keyStringOf)(value)); }, get: function () { return this._value; } }; PLItem.property.checked = { set: function (value) { if (value) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } }, get: function () { return this.hasClass('as-checked'); } } // EXTERNAL MODULE: ./node_modules/absol-acomp/css/listcomparetool.css var listcomparetool = __webpack_require__(3); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/cmdtool.css var cmdtool = __webpack_require__(9144); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CMDTool.js /** * @typedef {Object} CMDTabListNodeDeclaration * @property {"tab_list"} type * @property {CMDTabNodeDeclaration[]} children */ /** * @typedef {Object} CMDTabNodeDeclaration * @property {"tab"} type * @property {string} name * @property {CMDGrupX2NodeDeclaration[]|CMDgroup_x1NodeDeclaration[]} children */ /** * @typedef {Object} CMDGrupX2NodeDeclaration * @property {"group_x2"} type * @property {CMDGrupX2NodeDeclaration[]|CMDgroup_x1NodeDeclaration[]} children */ /** * @typedef {Object} CMDgroup_x1NodeDeclaration * @property {"group_x1"} type * @property {CMDGrupX2NodeDeclaration[]|CMDgroup_x1NodeDeclaration[]} children */ /** * @typedef {Object} CMDCommandNodeDeclaration * @property {"trigger"|"font"|"color"} type */ /** * @extends Fragment * @constructor */ function CMDTool() { Fragment/* default.call */.Z.call(this); this.$nodes = {}; OOP/* default.drillProperty */.ZP.drillProperty(this, this, '$buttons', '$nodes');//adapt old version this.updateVisibility = this.updateVisibility.bind(this); } OOP/* default.mixClass */.ZP.mixClass(CMDTool, Fragment/* default */.Z); CMDTool.prototype.onStart = function () { this.getView(); }; /** * * if param is empty, update all buttons */ CMDTool.prototype.updateVisibility = function (...args) { var delegate = this.delegate; if (!delegate) return; var keys = []; if (args.length === 0) { keys = Object.keys(this.$nodes).filter(k=>k !== 'undefined');//remove apt nodes } else { keys = args.reduce((ac, cr) => { if (Array.isArray(cr)) ac = ac.concat(cr); else if (typeof cr === "string") ac.push(cr); return ac; }, []); } keys.forEach((name) => { if (!this.$nodes[name]) return; var descriptor = delegate.getCmdDescriptor(name); if (!descriptor) return; this.updateNode(this.$nodes[name], descriptor); }); }; CMDTool.prototype.onResume = function () { this.updateVisibility(); }; CMDTool.prototype.getView = function () { if (this.$view) return this.$view; this.$view = (0,ACore._)({ tag: 'bscroller', class: "as-form-cmd-tool", }); this.refresh(); return this.$view; }; CMDTool.prototype.createNode = function (nd, par) { var handler; if (Array.isArray(nd)) { nd = { type: 'group_x2', children: nd }; handler = this.cmdNodeHandlers[nd.type]; } else if (typeof nd === "string") { nd = Object.assign({ name: nd, type: 'trigger' }, this.delegate.getCmdDescriptor(nd)); if (typeof nd.desc === "function") { nd.desc = nd.desc.call(this.delegate); } handler = this.cmdNodeHandlers[nd.type]; } else handler = this.cmdNodeHandlers[nd.type]; var nodeElt = null; if (handler) { nodeElt = handler.create.call(this, nd, par); nodeElt.descriptor = nd; nodeElt.parentDescriptor = par; this.$nodes[nd.name] = nodeElt; } else { console.error("Not support node type: ", nd.type, nd); } return nodeElt; }; CMDTool.prototype.updateNode = function (nodeElt, nd) { if (!nodeElt) return; nd = Object.assign({}, nodeElt.descriptor,{disabled: false}, nd);//default disabled = false if (typeof nd.desc === "function") { nd.desc = nd.desc.call(this.delegate); } nodeElt.descriptor = nd; var par = nodeElt.parentDescriptor; var handler = this.cmdNodeHandlers[nd.type]; if (handler) { if (handler.update) handler.update.call(this, nd, par, nodeElt); } else { console.error("Not support node type: ", nd.type, nd); } }; CMDTool.prototype.refresh = function () { var delegate = this.delegate; if (!delegate) return; this.getView(); this.$view.clearChild(); this.$nodes = {}; var groupTree = delegate.getCmdGroupTree(); var visit = (node) => { return this.createNode(node, null); } this.$view.addChild(visit(groupTree)); }; CMDTool.prototype.cmdNodeHandlers = { tab_list: { /** * @this {CMDTool} * @param nd * @param par */ create: function (nd, par) { var items = nd.children.map((ch, idx) => { return { text: ch.name, value: idx + '' }; }); if (!this.$tabBar) { this.$tabBar = (0,ACore._)({ tag: js_StaticTabbar, style: { display: 'inline-block', fontSize: 12 / 0.7 + 'px', marginBottom: '5px' }, props: { value: '0' }, on: { change: () => { var idx = parseInt(this.$tabBar.value); this.$frames.forEach((frame, i) => { frame.addStyle('display', i === idx ? '' : 'none'); }); ResizeSystem/* default.updateUp */.Z.updateUp(this.$tabBar); } } }); this.$tabBarCtn = (0,ACore._)({ style: { textAlign: 'center', backgroundColor: 'rgba(169, 169, 169, 0.15)' }, child: [this.$tabBar] }); } this.$tabBar.items = items; if (!items[this.$tabBar.value]) this.$tabBar.value = '0'; if (!this.$tabList) { this.$tabList = (0,ACore._)({}); } this.$tabList.clearChild(); this.$tabList.addChild(this.$tabBarCtn); this.$frames = nd.children.map((ch, idx) => { return this.createNode(ch, nd).addStyle('display', idx + '' === this.$tabBar.value ? '' : 'none').addStyle('textAlign', 'left'); }); this.$tabList.addChild(this.$frames); return this.$tabList; }, /** * @this {CMDTool} * @param nd * @param par */ update: function (nd, par) { } }, tab: { /** * @this {CMDTool} * @param nd * @param par */ create: function (nd, par) { return (0,ACore._)({ class: 'as-cmd-tool-tab', attr: { 'data-name': nd.name }, child: (nd.children || []).map((ch) => { return this.createNode(ch, nd); }) }); }, /** * @this {CMDTool} * @param nd * @param par */ update: function (nd, par) { } }, group_x2: { /** * @this {CMDTool} * @param nd * @param par */ create: function (nd, par) { return (0,ACore._)({ class: 'as-cmd-tool-group-x2', child: (nd.children || []).map((ch) => { return this.createNode(ch, nd); }) }); }, /** * @this {CMDTool} * @param nd * @param par */ update: function (nd, par) { } }, group_x1: { /** * @this {CMDTool} * @param nd * @param par */ create: function (nd, par) { return (0,ACore._)({}); }, /** * @this {CMDTool} * @param nd * @param par */ update: function (nd, par) { } }, trigger: { /** * @this {CMDTool} * @param nd * @param par */ create: function (nd, par) { var extClasses = (!par || ['array', 'group_x2'].indexOf(par.type) >= 0) ? ['as-big'] : []; var title = nd.desc; var btn = (0,ACore._)({ tag: RibbonButton/* default */.Z, class: extClasses, attr: { title: title, 'data-cmd-name': nd.name }, props: { disabled: !!nd.disabled, descriptor: nd, text: nd.desc, icon: nd.icon, }, on: { click: () => { this.execCmd.apply(this, [nd.name].concat(btn.descriptor.args || [])); } } }); this.$nodes[nd.name] = btn; return btn; }, /** * @this {CMDTool} * @param nd * @param par * @param nodeElt */ update: function (nd, par, nodeElt) { nodeElt.disabled = !!nd.disabled; nodeElt.text = nd.desc; nodeElt.icon = nd.icon; } }, toggle_switch: { /** * @this {CMDTool} */ create: function (nd, par) { var name = nd.name; var self = this; var title = nd.desc; var btn = (0,ACore._)({ tag: RibbonButton/* default */.Z, class: ['as-type-toggle-switch', 'as-big'], attr: { title: title, 'data-group': nd.group, "data-name": name, 'data-cmd-name': name }, props: { text: nd.desc, icon: nd.icon, disabled: !!nd.disabled, descriptor: nd }, on: { click: function () { var newChecked = !this.hasClass('as-checked'); if (newChecked && nd.group) Object.keys(self.$nodes).forEach(function (otherName) { var otherBtn = self.$nodes[otherName]; if (otherName === name) return; if (otherBtn.hasClass('as-type-toggle-switch') && otherBtn.descriptor.group === nd.group && otherBtn.hasClass('as-checked')) { otherBtn.removeClass('as-checked'); self.execCmd.apply(self, [otherBtn.attr('data-name'), false].concat(otherBtn.descriptor.args || [])); } }); if (newChecked) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } self.execCmd.apply(self, [name, newChecked].concat(nd.args || [])); } } }); if (nd.checked) btn.addClass('as-checked'); return btn; }, /** * @this {CMDTool} * @param nd * @param par * @param nodeElt */ update: function (nd, par, nodeElt) { if (nd.checked) nodeElt.addClass('as-checked'); else { nodeElt.removeClass('as-checked'); } nodeElt.disabled = !!nd.disabled; nodeElt.text = nd.desc; nodeElt.icon = nd.icon; } }, ribbon: { create: function (nd, par) { var name = nd.name; var self = this; var btn = (0,ACore._)({ tag: RibbonButton/* default.tag */.Z.tag, class: 'as-big', attr: { 'data-cmd-name': name }, props: { icon: nd.icon || nd.items[0].icon, items: nd.items, descriptor: nd, disabled: !!nd.disabled, text: nd.desc }, on: { select: function (event) { //select a item in menu var item = event.item; this.icon = item.icon; self.execCmd.apply(self, [name].concat(item.args || []).concat(this.descriptor.args || [])); }, } }); return btn; }, update: function (nd, par, nodeElt) { nodeElt.items = nd.items; } }, color: { create: function (nd, par) { var name = nd.name; var btn = (0,ACore._)({ tag: RibbonButton/* default */.Z, class: ['as-big', 'as-type-color'], style: { '--value': nd.value || 'black' }, props: { icon: nd.icon, descriptor: nd, text: nd.desc, } }); btn.on('click', () => { if (btn.hasClass('as-checked')) return; btn.addClass('as-checked'); var onClickOut = (event) => { if ((0,EventEmitter/* hitElement */.EY)(picker, event)) return; finish(); } var finish = () => { btn.removeClass('as-checked'); picker.remove(); document.removeEventListener('click', onClickOut); }; setTimeout(() => { document.addEventListener('click', onClickOut); }, 100) var applyValue = value => { btn.addStyle('--value', value.toString('hex6')); //todo: call cmd this.execCmd(name, value); } var picker = (0,ACore._)({ tag: colorpicker_SolidColorPicker, style: { position: 'fixed', left: '0px', top: '0px', zIndex: (0,utils.findMaxZIndex)(btn) + 1 + '', visibility: 'hidden' }, props: { value: nd.value || 'black' } }).addTo(document.body); var pickerBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(picker.getBoundingClientRect()); var btnBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(btn.getBoundingClientRect()); var screenSize = (0,Dom/* getScreenSize */.tE)(); var screenBound = new Rectangle/* default */.Z(0, 0, screenSize.width, screenSize.height); var aBounds = [ new Rectangle/* default */.Z(btnBound.x, btnBound.y + btnBound.height, pickerBound.width, pickerBound.height), new Rectangle/* default */.Z(btnBound.x + btnBound.width - pickerBound.width, btnBound.y + btnBound.height, pickerBound.width, pickerBound.height), new Rectangle/* default */.Z(btnBound.x, btnBound.y - pickerBound.height, pickerBound.width, pickerBound.height), new Rectangle/* default */.Z(btnBound.x + btnBound.width - pickerBound.width, btnBound.y - pickerBound.height, pickerBound.width, pickerBound.height) ]; var bestSquare = 0; var bestBound; var square; for (var i = 0; i < aBounds.length; ++i) { square = aBounds[i].collapsedSquare(screenBound); if (square > bestSquare) { bestSquare = square; bestBound = aBounds[i]; } } picker.addStyle({ left: bestBound.x + 'px', top: bestBound.y + 'px', visibility: 'visible' }); picker.on('change', (event) => { applyValue(picker.value); }); picker.on('submit', (event) => { finish(); }); }); return btn; }, update: function (nd, par, nodeElt) { nodeElt.addStyle('--value', nd.value || 'black'); } }, font: { create: function (nd, par) { var btn = (0,ACore._)({ tag: RibbonButton/* default */.Z, props: { icon: nd.icon, text: nd.desc, } }); return btn; }, update: function (nd, par, nodeElt) { } } }; CMDTool.prototype.execCmd = function () { if (this._delegate) this._delegate.execCmd.apply(this._delegate, arguments); }; Object.defineProperty(CMDTool.prototype, 'delegate', { /** * * @param {CMDToolDelegate} value */ set: function (value) { if (this._delegate) { this._delegate.cmdToolPartner = null; } this._delegate = value; if (this._delegate) { this._delegate.cmdToolPartner = this; } }, get: function () { return this._delegate; } }); /* harmony default export */ const js_CMDTool = (CMDTool); function CMDToolDelegate() { /** * * @type {null|CMDTool} */ this.cmdToolPartner = null; /** * @type {null|CMDRunner} * @name cmdRunner * @memberOf CMDToolDelegate# */ } /** * * @returns {*[]} */ CMDToolDelegate.prototype.getCmdGroupTree = function () { return []; }; /** * * @param name * @returns {{type: string, icon: string, desc}} - return default descriptor */ CMDToolDelegate.prototype.getCmdDescriptor = function (name) { return { type: 'trigger', icon: 'span.mdi.mdi-command', desc: name }; }; CMDToolDelegate.prototype.execCmd = function (name, ...args) { if (this.cmdRunner) return this.cmdRunner.invoke(name, ...args); }; CMDToolDelegate.prototype.refresh = function () { if (this.cmdToolPartner) this.cmdToolPartner.refresh(); }; CMDToolDelegate.prototype.updateVisibility = function (...args) { if (this.cmdToolPartner) this.cmdToolPartner.updateVisibility(...args); }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/ListCompareTool.js var ListCompareTool_g = Svg/* default.ShareInstance._ */.ZP.ShareInstance._; /** * @typedef ListCompareToolItem * @property {string} text * @property {string} value * @property {string} [icon] - mdi icon or map from tag in form */ /** * @extends {AElement} * @constructor */ function ListCompareTool() { this.$header = (0,ACore.$)('.as-list-compare-tool-header', this); this.$before = (0,ACore.$)('.as-list-compare-tool-before', this); this.$after = (0,ACore.$)('.as-list-compare-tool-after', this); this.beforeCtrl = new LCTListController(this, this.$before); this.afterCtrl = new LCTListController(this, this.$after); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$body = (0,ACore.$)('.as-list-compare-tool-body', this); this.$attachhook.on('attached', () => { ResizeSystem/* default.add */.Z.add(this.$attachhook); this.$attachhook.requestUpdateSize(); }); this.$attachhook.requestUpdateSize = this.requestUpdateSize.bind(this); this.$operators = (0,ACore.$)('.as-list-compare-tool-operators', this); this.mapOperatorCtr = new LCTMapOperatorController(this); this.headerCtr = new LCTHeaderController(this); this.newLineTool = new LCTNewLineTool(this); this.removeLineTool = new LCTRemoveLineTool(this); this.cmdTool = new js_CMDTool(); this.cmdDelegate = new LCTCommandDelegate(this); this.cmdTool.delegate = this.cmdDelegate; this.$header.addChildAfter(this.cmdTool.getView(), null); this.layoutCtr = new LCTLayoutController(this); (0,OOP/* drillProperty */.pj)(this, this.mapOperatorCtr, 'mapOperators'); (0,OOP/* drillProperty */.pj)(this, this.beforeCtrl, 'beforeItems', 'items'); (0,OOP/* drillProperty */.pj)(this, this.afterCtrl, 'afterItems', 'items'); /** * @type {ListCompareToolItem[]} * @memberOf ListCompareTool# * @name beforeItems */ /** * @type {ListCompareToolItem[]} * @memberOf ListCompareTool# * @name afterItems */ /** * @type {mapOperators[]} * @memberOf ListCompareTool# * @name afterItems */ } ListCompareTool.tag = 'ListCompareTool'; ListCompareTool.render = function () { return (0,ACore._)({ extendEvent: 'change', attr: { tabindex: 1 }, class: ['as-list-compare-tool', 'as-width-auto', 'as-height-auto', 'as-max-height-auto'], child: [ { class: 'as-list-compare-tool-header', child: [ { class: 'as-list-compare-tool-check-ctn', child: [ { tag: js_CheckBox, class: 'as-list-compare-tool-changed-only-checkbox', props: { text: 'Chỉ hiện phần thay đổi', checked: false } } ] }, ] }, { class: 'as-list-compare-tool-body', child: [ '.as-list-compare-tool-before-title', '.as-list-compare-tool-after-title', { class: ['as-list-compare-tool-before', 'as-bscroller'], }, { class: 'as-list-compare-tool-spacing', }, { class: ['as-list-compare-tool-after', 'as-bscroller'], }, { class: 'as-list-compare-tool-operators', child: ListCompareTool_g({ tag: 'svg', child: [ { tag: 'defs', child: [ { tag: 'marker', class: 'as-lct-arrow', attr: { id: 'arrow', markerWidth: '3', markerHeight: '8', orient: 'auto', refX: '4.1', refY: '4' }, child: { tag: 'path', attr: { d: 'M0,0 V8 L4,4 Z' }, style: { fill: 'var(--line-color)' } } }, { tag: 'marker', class: 'as-lct-same-value-arrow', attr: { id: 'same-value-arrow', markerWidth: '3', markerHeight: '8', orient: 'auto', refX: '4.1', refY: '4' }, child: { tag: 'path', attr: { d: 'M0,0 V8 L4,4 Z' }, style: { fill: 'var(--line-color)' } } }, { tag: 'marker', class: 'as-lct-new-line-arrow', attr: { id: 'new-line-arrow', markerWidth: '3', markerHeight: '8', orient: 'auto', refX: '4.1', refY: '4' }, child: { tag: 'path', attr: { d: 'M0,0 V8 L4,4 Z' }, style: { fill: 'var(--line-color)' } } } ] } ] }) }, ] } ] }); }; ListCompareTool.property = {}; ListCompareTool.property.unchangeText = { set: function (text) { }, get: function () { } }; ListCompareTool.property.changeText = { set: function (text) { }, get: function () { } }; ListCompareTool.prototype.commands = { newLineTool: { /** * @this {ListCompareTool} */ exec: function () { setTimeout(() => { this.removeLineTool.disable(true); this.newLineTool.disable(false); this.cmdDelegate.updateVisibility(); }); }, descriptor: { type: 'toggle_switch', icon: 'span.mdi.mdi-pencil-plus', desc: () => 'Vẽ đường nối' } }, removeLineTool: { exec: function () { setTimeout(() => { this.newLineTool.disable(true); this.removeLineTool.disable(false); this.cmdDelegate.updateVisibility(); }); }, descriptor: { type: 'toggle_switch', icon: 'span.mdi.mdi-eraser', desc: () => 'Xóa đường nối' } } }; ListCompareTool.prototype.requestUpdateSize = function () { this.layoutCtr.onSizeChange(); this.mapOperatorCtr.updateStyleValues(); this.mapOperatorCtr.updatePosition(); }; ListCompareTool.prototype.notifyChange = function () { this.emit('change', {type: 'change', target: this}, this); }; /* harmony default export */ const js_ListCompareTool = (ListCompareTool); ACore/* default.install */.Z.install(ListCompareTool); /** * @extends CMDToolDelegate * @param {ListCompareTool} elt * @constructor */ function LCTCommandDelegate(elt) { CMDToolDelegate.call(this); this.elt = elt; } (0,OOP/* mixClass */.Jx)(LCTCommandDelegate, CMDToolDelegate); LCTCommandDelegate.prototype.getCmdGroupTree = function () { return ['newLineTool', 'removeLineTool']; }; LCTCommandDelegate.prototype.getCmdDescriptor = function (name) { if (name === 'undefined') console.trace(1) var res = Object.assign(this.elt.commands[name].descriptor); if (name === 'newLineTool') { res.checked = this.elt.newLineTool.state !== this.elt.newLineTool.ST_DISABLED; } else if (name === 'removeLineTool') { res.checked = this.elt.removeLineTool.state !== this.elt.newLineTool.ST_DISABLED; } return res; } LCTCommandDelegate.prototype.execCmd = function (name, ...args) { var cmd = this.elt.commands[name]; if (!cmd) return; cmd.exec.call(this.elt, args); } function LCTMapOperatorController(elt) { this.elt = elt; this.$ctn = (0,ACore.$)('.as-list-compare-tool-operators', this.elt); this.$canvas = (0,ACore.$)('svg', this.$ctn); this._mapOperators = []; /** * * @type {LCTMapLine[]} */ this.mapLines = []; } LCTMapOperatorController.prototype.updateStyleValues = function () { var bound = this.$ctn.getBoundingClientRect(); this.$canvas.attr('viewBox', '-0.5 -0.5 ' + bound.width + ' ' + bound.height) .attr('width', bound.width) .attr('height', bound.height); }; LCTMapOperatorController.prototype.updatePosition = function () { this.mapLines.forEach(line => { line.updatePosition(); }) }; LCTMapOperatorController.prototype.updateModifiedItems = function () { var mappedValues = this.mapLines.reduce((ac, cr) => { if (cr.beforeValue === cr.afterValue) return ac; ac[(0,utils.keyStringOf)(cr.beforeValue)] = true; ac[(0,utils.keyStringOf)(cr.afterValue)] = true; return ac; }, {}); this.elt.beforeCtrl.$items.forEach(it => { if (mappedValues[(0,utils.keyStringOf)(it.value)]) { it.addClass('as-mapped'); } else { it.removeClass('as-mapped'); } if (this.elt.afterCtrl.hasValue(it.value)) { it.removeClass('as-removed'); } else { it.addClass('as-removed'); } }); this.elt.afterCtrl.$items.forEach(it => { if (mappedValues[(0,utils.keyStringOf)(it.value)]) { it.addClass('as-mapped'); } else { it.removeClass('as-mapped'); } if (this.elt.beforeCtrl.hasValue(it.value)) { it.removeClass('as-added'); } else { it.addClass('as-added'); } }); }; LCTMapOperatorController.prototype.addNewMapOp = function (beforeValue, afterValue) { if (!this.elt.beforeCtrl.hasValue(beforeValue) || !this.elt.afterCtrl.hasValue(afterValue)) return; this.mapLines = this.mapLines.filter(it => { if (it.beforeValue === beforeValue || it.afterValue === afterValue) { it.remove(); return false; } return true; }); var line = new LCTMapLine(this.elt, beforeValue, afterValue); this.mapLines.push(line); this._mapOperators = this.mapLines.filter(it => it.beforeValue !== it.afterValue).map(it => it.exportData());//save this.updateModifiedItems(); this.updateStyleValues(); this.updatePosition(); }; LCTMapOperatorController.prototype.removeLine = function (line) { if (line.beforeValue === line.afterValue) return;//view only line var idx = this.mapLines.indexOf(line); if (idx < 0) return; this.mapLines.splice(idx, 1); line.remove(); var changedDict = this.mapLines.reduce((ac, it) => { ac[(0,utils.keyStringOf)(it.beforeValue)] = true; ac[(0,utils.keyStringOf)(it.afterValue)] = true; return ac; }, {}); var u = line.beforeValue; var v = line.afterValue; if (this.elt.beforeCtrl.hasValue(u) && this.elt.afterCtrl.hasValue(u) && !changedDict[(0,utils.keyStringOf)(u)]) { line = new LCTMapLine(this.elt, u, u); this.mapLines.push(line); } if (this.elt.beforeCtrl.hasValue(v) && this.elt.afterCtrl.hasValue(v) && !changedDict[(0,utils.keyStringOf)(v)]) { line = new LCTMapLine(this.elt, v, v); this.mapLines.push(line); } this._mapOperators = this.mapLines.filter(it => it.beforeValue !== it.afterValue).map(it => it.exportData());//save this.updateModifiedItems(); this.updateStyleValues(); this.updatePosition(); }; LCTMapOperatorController.prototype.redrawMapLines = function () { this.mapLines.forEach(it => { it.remove(); }); this.mapLines = []; var beforeItems = this.elt.beforeCtrl.items; var changedDict = this._mapOperators.reduce((ac, it) => { ac[(0,utils.keyStringOf)(it.u)] = true; ac[(0,utils.keyStringOf)(it.v)] = true; return ac; }, {}); beforeItems.forEach(it => { if (changedDict[(0,utils.keyStringOf)(it.value)]) return; if (this.elt.afterCtrl.hasValue(it.value)) { var line = new LCTMapLine(this.elt, it.value, it.value); this.mapLines.push(line); } }); var addedOpts = {}; this._mapOperators.forEach(it => { var key = (0,utils.keyStringOf)(it.u) + '|' + (0,utils.keyStringOf)(it.v); if (addedOpts[key]) return; addedOpts[key] = true; var line = new LCTMapLine(this.elt, it.u, it.v); this.mapLines.push(line); }); }; Object.defineProperty(LCTMapOperatorController.prototype, 'mapOperators', { set: function (operators) { if (!Array.isArray(operators)) operators = []; this._mapOperators = operators; this.redrawMapLines(); this.updateModifiedItems(); }, get: function () { return this.mapLines.filter(it => it.beforeValue !== it.afterValue).map(it => it.exportData()); } }); /** * * @param {ListCompareTool} elt * @constructor */ function LCTHeaderController(elt) { this.elt = elt; this.ev_viewChange = this.ev_viewChange.bind(this); this.$changedOnly = (0,ACore.$)('.as-list-compare-tool-changed-only-checkbox', elt); this.$changedOnly.on('change', this.ev_viewChange); } LCTHeaderController.prototype.ev_viewChange = function () { if (this.$changedOnly.checked) this.elt.addClass('as-view-changed-only'); else { this.elt.removeClass('as-view-changed-only'); } this.elt.requestUpdateSize(); } /** * * @param {ListCompareTool} elt * @param {AElement} ctnElt * @constructor */ function LCTListController(elt, ctnElt) { this.elt = elt; /** * * @type {AElement} */ this.$ctn = ctnElt; this.$ctn.on('scroll', this.ev_scroll.bind(this)); /** * * @type {LCTItem[]} */ this.$items = []; this._items = []; this.$itemByValue = {}; } LCTListController.prototype.updateStyleValues = function () { var minWidth = this.elt.beforeCtrl.$items.reduce((ac, it) => { return Math.max(ac, it.minWidth); }, 0); minWidth = this.elt.afterCtrl.$items.reduce((ac, it) => { return Math.max(ac, it.minWidth); }, minWidth); this.elt.addStyle('--item-min-width', minWidth + 'px'); }; LCTListController.prototype.itemEltOfValue = function (value) { return this.$itemByValue[(0,utils.keyStringOf)(value)] || null; }; LCTListController.prototype.hasValue = function (value) { return !!this.$itemByValue[(0,utils.keyStringOf)(value)]; }; LCTListController.prototype.ev_scroll = function () { this.elt.mapOperatorCtr.updatePosition(); }; Object.defineProperty(LCTListController.prototype, 'items', { set: function (items) { items = items || []; this._items = items; this.$ctn.clearChild(); this.$items = items.map(it => (0,ACore._)({ tag: LCTItem, props: { text: it.text, value: it.value, icon: it.icon } })); this.$ctn.addChild(this.$items); this.$itemByValue = this.$items.reduce((ac, it) => { ac[(0,utils.keyStringOf)(it.value)] = it; return ac; }, {}); this.updateStyleValues(); this.elt.mapOperatorCtr.updateStyleValues(); this.elt.mapOperatorCtr.updateModifiedItems(); this.elt.mapOperatorCtr.redrawMapLines(); }, get: function () { return this._items; } }); /** * * @param {ListCompareTool} elt * @constructor */ function LCTLayoutController(elt) { this.elt = elt; this._height = 'auto'; this._maxHeight = 'auto'; } LCTLayoutController.prototype.setHeight = function (height) { this._height = this.normalizeSizeValue(height); this.updateHeightStyle(); }; LCTLayoutController.prototype.setMaxHeight = function (maxHeight) { this._maxHeight = this.normalizeSizeValue(maxHeight); this.updateHeightStyle(); }; LCTLayoutController.prototype.normalizeSizeValue = function (value) { var parsed = (0,attribute.parseMeasureValue)(value); if (parsed) { value = parsed.value + parsed.unit; } else if (typeof value === "string") { if (value.indexOf('calc') < 0 && value.indexOf('var') < 0) { value = 'auto' } } else value = 'auto'; return value; }; LCTLayoutController.prototype.updateHeightStyle = function () { var height = this._height; var maxHeight = this._maxHeight; if (height === 'auto') { this.elt.style.removeProperty('--height'); this.elt.addClass('as-height-auto'); } else { this.elt.style.setProperty('--height', height); this.elt.removeClass('as-height-auto'); } if (maxHeight === 'auto') { this.elt.style.removeProperty('--max-height'); this.elt.addClass('as-max-height-auto'); } else { this.elt.style.setProperty('--max-height', maxHeight); this.elt.removeClass('as-max-height-auto'); } }; LCTLayoutController.prototype.onSizeChange = function () { var style = getComputedStyle(this.elt); var maxHeight = style.getPropertyValue('max-height'); if (maxHeight && maxHeight.indexOf('px') >= 0) { maxHeight = parseFloat(maxHeight.replace('px', '')); this.elt.addStyle('--list-max-height', maxHeight - 66 - 22 - 20 + 'px'); } else { this.elt.removeStyle('--list-max-height'); } }; /** * @param {ListCompareTool} elt * @param beforeValue * @param afterValue * @constructor */ function LCTMapLine(elt, beforeValue, afterValue) { this.beforeValue = beforeValue; this.afterValue = afterValue; this.elt = elt; this.$line = ListCompareTool_g({ tag: 'path', class: 'as-lct-line', attr: { 'marker-end': "url(#arrow)" }, }); this.$hitBox = ListCompareTool_g({ tag: 'path', class: 'as-lct-line-hit-box', }); this.$group = ListCompareTool_g({ tag: 'g', class: 'as-lct-line-group', child: [ this.$line, this.$hitBox ] }); this.$group.lctMapLine = this; this.elt.mapOperatorCtr.$canvas.addChild(this.$group); if (this.beforeValue === this.afterValue) { this.$group.addClass('as-same-value'); this.$line.attr('marker-end', "url(#same-value-arrow)"); } } LCTMapLine.prototype.exportData = function () { return { u: this.beforeValue, v: this.afterValue, } }; LCTMapLine.prototype.updatePosition = function () { var beforeItemElt = this.elt.beforeCtrl.itemEltOfValue(this.beforeValue); var afterItemElt = this.elt.afterCtrl.itemEltOfValue(this.afterValue); if (!beforeItemElt || !afterItemElt) { this.$line.attr('d', null); return; } var beforeBound = beforeItemElt.getBoundingClientRect(); if (!beforeBound.width) { this.$line.attr('d', null); this.$hitBox.attr('d', null); return; } var afterBound = afterItemElt.getBoundingClientRect(); if (!afterBound.width) { this.$hitBox.attr('d', null); this.$line.attr('d', null); return; } var canvasBound = this.elt.mapOperatorCtr.$canvas.getBoundingClientRect(); // if (canvasBound.top > beforeBound.bottom || canvasBound.bottom < beforeBound.top) { // if (canvasBound.top > afterBound.bottom || canvasBound.bottom < afterBound.top) { // this.$hitBox.attr('d', null); // this.$line.attr('d', null); // return; // } // } var x, y; var canvasOffsetPoint = new Vec2/* default */.Z(canvasBound.left, canvasBound.top); x = beforeBound.right - 5; y = beforeBound.top + beforeBound.height / 2 - 1;//1 is border var startPoint = new Vec2/* default */.Z(x, y).sub(canvasOffsetPoint); x = afterBound.left + 5; y = afterBound.top + afterBound.height / 2 - 1; var endPoint = new Vec2/* default */.Z(x, y).sub(canvasOffsetPoint); var d = 'M' + startPoint.x + ' ' + startPoint.y + ' L' + endPoint.x + ' ' + endPoint.y; this.$line.attr('d', d); this.$hitBox.attr('d', d); }; LCTMapLine.prototype.remove = function () { this.$group.remove(); }; /** * * @param {ListCompareTool} elt * @constructor */ function LCTNewLineTool(elt) { this.elt = elt; this.state = this.ST_NONE; for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } this.elt.on('click', this.ev_click); this.$beforeItem = null; this.$afterItem = null; this.$line = ListCompareTool_g({ tag: 'path', class: ['as-lct-line', 'as-new-line'], attr: { 'marker-end': "url(#new-line-arrow)" }, }); this.elt.mapOperatorCtr.$canvas.addChild(this.$line); } LCTNewLineTool.prototype.ST_DISABLED = 'DISABLED'; LCTNewLineTool.prototype.ST_NONE = 'NONE'; LCTNewLineTool.prototype.ST_STARTED = 'STATED'; LCTNewLineTool.prototype.disable = function (flag) { if (this.state === this.ST_NONE && flag) { this.state = this.ST_DISABLED; } else if (this.state === this.ST_DISABLED && !flag) { this.state = this.ST_NONE; } } LCTNewLineTool.prototype.findItemElt = function (elt) { while (elt) { if (elt.hasClass && elt.hasClass('as-lct-item')) { return elt; } elt = elt.parentElement; } return null; } LCTNewLineTool.prototype.isBeforeItemElt = function (elt) { return elt && elt.isDescendantOf(this.elt.beforeCtrl.$ctn); }; LCTNewLineTool.prototype.ev_click = function (event) { var itemElt; if (this.state === this.ST_NONE) { itemElt = this.findItemElt(event.target); if (itemElt && (itemElt.hasClass('as-removed') || itemElt.hasClass('as-added'))) { if (this.isBeforeItemElt(itemElt)) { this.$beforeItem = itemElt; } else { this.$afterItem = itemElt; } itemElt.addClass('as-active'); this.state = this.ST_STARTED; setTimeout(() => { document.addEventListener('click', this.ev_clickOut); }, 1); document.addEventListener('mousemove', this.ev_mouseMove); } } else if (this.state === this.ST_STARTED) { itemElt = this.findItemElt(event.target); if (itemElt && (itemElt.hasClass('as-removed') || itemElt.hasClass('as-added'))) { if (this.isBeforeItemElt(itemElt)) { if (this.$beforeItem) { this.$beforeItem.removeClass('as-active'); } if (this.$beforeItem === itemElt) { this.$beforeItem = null; } else { this.$beforeItem = itemElt; itemElt.addClass('as-active'); } } else { if (this.$afterItem) { this.$afterItem.removeClass('as-active'); } if (this.$afterItem === itemElt) { this.$afterItem = null; } else { this.$afterItem = itemElt; itemElt.addClass('as-active'); } } if (this.$beforeItem && this.$afterItem) { this.elt.mapOperatorCtr.addNewMapOp(this.$beforeItem.value, this.$afterItem.value); this.$beforeItem.removeClass('as-active'); this.$afterItem.removeClass('as-active'); this.state = this.ST_NONE; this.elt.notifyChange(); } else if (!this.$beforeItem && !this.$afterItem) { this.state = this.ST_NONE; } else { this.$line.attr('d', null); } } else { } if (this.state === this.ST_NONE) {//finish this.$beforeItem = null; this.$afterItem = null; this.$line.attr('d', null); document.removeEventListener('click', this.ev_clickOut); document.removeEventListener('mousemove', this.ev_mouseMove); } } }; LCTNewLineTool.prototype.ev_mouseMove = function (event) { if (this.state !== this.ST_STARTED) return; var currentPoint = new Vec2/* default */.Z(event.clientX, event.clientY); var startPoint; var endPoint; var canvasBound = this.elt.mapOperatorCtr.$canvas.getBoundingClientRect(); var canvasOffsetPoint = new Vec2/* default */.Z(canvasBound.left, canvasBound.top); var itemBound; if (this.$beforeItem) { itemBound = this.$beforeItem.getBoundingClientRect(); startPoint = new Vec2/* default */.Z(itemBound.right - 5, itemBound.top + itemBound.height / 2 - 1).sub(canvasOffsetPoint); endPoint = currentPoint.sub(canvasOffsetPoint); } else if (this.$afterItem) { itemBound = this.$afterItem.getBoundingClientRect(); startPoint = currentPoint.sub(canvasOffsetPoint); endPoint = new Vec2/* default */.Z(itemBound.left + 5, itemBound.top + itemBound.height / 2 - 1).sub(canvasOffsetPoint); } this.$line.attr('d', 'M' + startPoint.x + ' ' + startPoint.y + ' L' + endPoint.x + ' ' + endPoint.y); }; LCTNewLineTool.prototype.ev_clickOut = function (event) { var itemElt = this.findItemElt(event.target); if (itemElt && (itemElt.hasClass('as-removed') || itemElt.hasClass('as-added'))) return; if (this.$beforeItem) { this.$beforeItem.removeClass('as-active'); } if (this.$afterItem) { this.$afterItem.removeClass('as-active'); } this.$beforeItem = null; this.$afterItem = null; this.$line.attr('d', null); this.state = this.ST_NONE; document.removeEventListener('click', this.ev_clickOut); document.removeEventListener('mousemove', this.ev_mouseMove); } LCTNewLineTool.prototype.ev_keydown = function (event) { }; function LCTRemoveLineTool(elt) { this.elt = elt; this.state = this.ST_DISABLED; this.$cursor = null; this.ev_mouseMove = this.ev_mouseMove.bind(this); this.ev_click = this.ev_click.bind(this); this.elt.mapOperatorCtr.$canvas.on('click', this.ev_click); } LCTRemoveLineTool.prototype.ST_DISABLED = 'DISABLED'; LCTRemoveLineTool.prototype.ST_NONE = 'NONE'; LCTRemoveLineTool.prototype.disable = function (flag) { if (this.state === this.ST_NONE && flag) { this.state = this.ST_DISABLED; this.elt.removeClass('as-remove-line-tool-active'); this.$cursor.remove(); } else if (this.state === this.ST_DISABLED && !flag) { this.state = this.ST_NONE; this.elt.addClass('as-remove-line-tool-active'); this.$cursor = (0,ACore._)({ class: 'as-lct-cursor', child: 'span.mdi.mdi-eraser' }).addTo(this.elt.$body); document.addEventListener('mousemove', this.ev_mouseMove); } } LCTRemoveLineTool.prototype.findMapLine = function (elt) { while (elt) { if (elt.lctMapLine) { return elt.lctMapLine; } elt = elt.parentElement; } return null; } LCTRemoveLineTool.prototype.ev_click = function (event) { if (this.state === this.ST_DISABLED) return; var line = this.findMapLine(event.target); if (line) { this.elt.mapOperatorCtr.removeLine(line); this.elt.notifyChange(); } }; LCTRemoveLineTool.prototype.ev_mouseMove = function (event) { var point = new Vec2/* default */.Z(event.clientX, event.clientY); var bodyBound = this.elt.$body.getBoundingClientRect(); if (bodyBound.width === 0) { document.removeEventListener('mousemove', this.ev_mouseMove);//element is removed } point = point.sub(new Vec2/* default */.Z(bodyBound.left, bodyBound.top)); this.$cursor.addStyle({ left: point.x - 9 + 'px', top: point.y - 24 + 'px' }); }; LCTRemoveLineTool.prototype.ev_mouseDown = function (event) { }; LCTRemoveLineTool.prototype.ev_mouseUp = function (event) { }; /** * @extends {AElement} * @constructor */ function LCTItem() { this.$text = (0,ACore.$)('.as-lct-item-text', this); this.$iconCtn = (0,ACore.$)('.as-lct-item-icon-ctn', this); this._icon = null; /** * @name icon * @memberOf LCTItem# */ /** * @type string * @name text * @memberOf LCTItem# */ /** * @type any * @name value * @memberOf LCTItem# */ /** * @type number * @name minWidth * @memberOf LCTItem# */ } LCTItem.tag = 'LCTItem'.toLowerCase(); LCTItem.render = function () { return (0,ACore._)({ class: 'as-lct-item', child: [ { class: 'as-lct-item-icon-ctn', }, { class: 'as-lct-item-text' } ] }); }; LCTItem.property = {}; LCTItem.property.text = { set: function (value) { value = value || ''; value = value + ''; this.$text.attr('data-text', value); }, get: function () { return this.$text.attr('data-text'); } }; LCTItem.property.value = { set: function (value) { this._value = value; this.attr('data-value', value + ''); }, get: function () { return this._value; } }; LCTItem.property.icon = { set: function (value) { value = value || ''; this._icon = value; this.$iconCtn.clearChild(); this.$icon = null; if (value) { if ((0,Dom/* isDomNode */.mV)(value)) { if (value.parentElement) value = value.cloneNode(true); } else value = (0,ACore._)(value); this.$icon = (0,ACore.$)(value).addClass('as-lct-icon'); this.$iconCtn.addChild(this.$icon); } }, get: function () { return this._icon; } }; LCTItem.property.minWidth = { get: function () { var res = 25 + 10; res += TextMeasure/* default.measureWidth */.Z.measureWidth(this.text, TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14) + 20; return Math.ceil(res) } }; ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/dom/install.js var publicCreators = [ Icons/* MdiStoreMarkerOutline */.CY, js_AutoCompleteInput, BoardTable/* default */.ZP, Board/* default */.Z, js_BScroller, js_ButtonArray, js_ButtonRange, js_CalendarInput, OldCalendarInput, CheckBoxInput/* default */.Z, js_CheckBox, CheckboxButton/* default */.Z, js_CheckListItem, CheckListBox, js_CheckTreeLeafOnlyBox, ChromeCalendar/* default */.Z, js_ChromeTimePicker, js_ChromeTime24Picker, js_CircleSectionLabel, js_CountdownClock, js_CountdownText, js_CollapsibleTreeNavigator, js_DateInYearPicker, js_DateInYearInput, js_DateTimeInput, DropZone/* default */.Z, js_ExpressionInput, js_IdentTextInput, js_EmojiPickerTooltip, js_FileInputBox, js_FileListItem, js_FileListInput, Finder/* default */.ZP, FontFamilySelectList, js_FontInput, Scroller/* Scrollbar */.LW, Scroller/* VScrollbar */.eP, Scroller/* HScrollbar */.MP, Scroller/* VScroller */.k$, Scroller/* HScroller */.bJ, ContextMenu/* default */.Z, Menu/* HMenu */.ch, Menu/* VMenuItem */.zV, Menu/* VMenu */.T$, Menu/* Dropright */.KZ, Menu/* VMenuLine */.ee, Menu/* Dropdown */.Lt, Menu/* HMenuItem */.E, Menu/* VMenu */.T$, Menu/* VRootMenu */.p, Menu/* MenuButton */.j2, js_DateInput2, js_DateNLevelInput, Hanger/* default */.Z, js_DraggableHStack, js_DraggableVStack, js_DropPanel, js_DropPanelStack, js_EditableText, EmojiPicker/* default */.Z, js_EmojiCounter, js_EmojiCounterList, Sprite/* default */.ZP, ExpTree/* ExpNode */.$P, ExpTree/* default */.ZP, ExpTree/* ExpGroup */.uz, js_DVExpTree, FlexiconButton/* default */.Z, js_FlexiconInput, Follower/* default */.Z, js_FollowerToggler, js_Frame, js_FrameView, js_TabFrame, TabView/* default */.Z, js_SinglePage, js_HexaSectionLabel, js_VRuler, js_HRuler, js_IconSprite, js_LinearColorBar, js_LinearColorTinyBar, js_MediaInput, MessageInput/* default */.ZP, MessageInput/* MessageQuote */.RD, Modal/* default */.Z, js_LoadingCubeModal, numberinput_NumberInput, js_NumberSpanInput, OnsScreenWindow, OnScreenWidget/* default */.Z, js_PageIndicator, js_PageSelector, js_PreInput, ProgressBar/* default */.Z, js_ProgressCircle, js_QuickListButton, QuickMenu/* default */.Z, js_QuickPath, js_PathMenu, js_PathView, Radio/* default */.Z, RadioButton/* default */.Z, js_RadioInput, RibbonSplitButton/* default */.Z, RibbonButton/* default */.Z, js_SelectRibbonMenu, js_RotatedText, SelectList/* default */.ZP, js_RemoteSvg, ResizeBox/* default */.Z, Searcher/* default */.Z, js_SelectListBox, js_SelectTreeBox, SelectMenu2, js_SelectBox, js_MultiSelectMenu, js_MultiCheckTreeLeafBox, BrowserDetector/* default.isMobile */.Z.isMobile ? multichecktreeleafmenu_MultiCheckTreeLeafMenu : js_MultiCheckTreeLeafMenu, js_SelectBoxItem, js_DualSelectBox, BrowserDetector/* default.isMobile */.Z.isMobile ? dualselectmenu_DualSelectMenu : js_DualSelectMenu, js_SelectTable, js_SelectTable2, js_SelectTreeMenu, js_SelectTreeLeafBox, /*BrowserDetector.isMobile ? SelectTreeLeafMenuV2 :*/ js_SelectTreeLeafMenu, js_SpanInput, Snackbar, js_StaticTabbar, js_Switch, tablescroller_TableScroller, js_TableVScroller, treetable_TreeTable, TextArea2/* default */.Z, js_TextClipboard, js_TimeInput, js_Time24Input, js_TimeRange24Input, js_TimeSelectInput, js_TimePicker, js_DateTimeInput, Tooltip/* default */.Z, js_CopyableIconTooltip, Toast/* default */.Z, js_TreeList, js_TreeListItem, js_TokenField, WidthHeightSizer, js_TrackBar, js_TrackBarInput, Icons/* SpinnerIco */.i_, Icons/* ProcessOutlineIcon */.Vt, Icons/* ProcedureOutlineIcon */.V4, Icons/* ImportantOutlineIcon */.Bm, Icons/* EmojiMutedIcon */.Ty, VerticalTreeDiagramNode, js_VerticalTreeDiagram, js_MultiCheckMenu, js_CheckTreeItem, js_CheckTreeBox, js_MultiCheckTreeMenu, MessageDialog/* default */.Z, YesNoQuestionDialog/* default */.Z, js_TOCItem, js_TOCList, ckeditor_CKPlaceholder, ckeditor_CKInlineShortText, js_VerticalTimeline, WindowBox/* default */.Z, js_LocationView, js_LocationPicker, js_LocationInput, js_PlaceSearchAutoCompleteInput, js_MKNavigator, js_ProcessLBar, js_KVCommentItem, dynamictable_DynamicTable, js_EfficientTable, objectmergetool_ObjectMergeTool, tokenizeiput_TokenizeHyperInput, selectlistbox_SelectListBox, // MCheckTreeBox, checktreeleafbox_MCheckTreeLeafBox, selecttreeleafbox_MSelectTreeLeafBox, dualselectbox_MDualSelectBox, js_PickingList, js_TreeChart, js_TableOfTextInput, js_CompactDataGridEditor, MHeaderBar/* default */.Z, MExploreSectionBreak, MExploreItemBlock, MExploreGroup, MSpringboardMenu, colorpicker_SolidColorPicker, colorpicker_ColorPickerButton, ColorCell, SelectColorSchemeMenu/* default */.ZP, NotificationPanel/* MNPNotificationVirtualDropdown */.FW, NotificationPanel/* NPDropdownButton */.sP, NotificationPanel/* default */.ZP, NotificationPanel/* NPSection */.PL, NotificationPanel/* NPItem */.Ee, NotificationPanel/* NPList */.Bd, js_ListCompareTool ]; /*** * * @param {Dom} core */ function install(core) { core.install(publicCreators); core.install('checkboxbutton', CheckBoxInput/* default */.Z); core.install('selectbox', js_MultiSelectMenu); if (BrowserDetector/* default.isMobile */.Z.isMobile) { core.install('selectmenu', selectmenu_MSelectMenu); core.install('mselectmenu', selectmenu_MSelectMenu); // core.install('selecttreemenu', MSelectTreeMenu) } // core.install('mselectmenu', SelectMenu2); core.install('mselecttreemenu', js_SelectTreeMenu) core.install('MSelectTreeLeafMenu'.toLowerCase(), js_SelectTreeLeafMenu); core.install('MMultiCheckTreeMenu'.toLowerCase(), js_MultiCheckTreeMenu); core.install('MMultiCheckTreeLeafMenu'.toLowerCase(), js_MultiCheckTreeLeafMenu); core.install('mknav', js_MKNavigator); } /* harmony default export */ const dom_install = (install); /***/ }), /***/ 8556: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Vm": () => (/* binding */ FinderFileSystem), "ZP": () => (/* binding */ finder_Finder) }); // UNUSED EXPORTS: FinderCommands // EXTERNAL MODULE: ./node_modules/absol-acomp/css/finder.css var finder = __webpack_require__(5277); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/mobileapp.css var mobileapp = __webpack_require__(8789); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ResizeSystem.js var ResizeSystem = __webpack_require__(6700); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/FlexiconButton.js var FlexiconButton = __webpack_require__(3929); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ExpTree.js var ExpTree = __webpack_require__(2917); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/messageinput/MessageInput.js + 2 modules var MessageInput = __webpack_require__(4877); // EXTERNAL MODULE: ./node_modules/absol/src/Converter/ext2MineType.js var ext2MineType = __webpack_require__(9691); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol/src/Math/random.js var random = __webpack_require__(7848); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/EventEmitter.js var EventEmitter = __webpack_require__(863); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/TaskManager.js /*** * * @param {TaskManager} manager * @param {function(finishTask: function, bundle: any): (void|Promise)=} func * @param {any=} bundle * @constructor */ function Task(manager, func, bundle) { this.manager = manager; this.id = (0,stringGenerate.randomIdent)(12); this.func = func; this.bundle = bundle; this.state = 0; } Task.prototype.begin = function () { if (this.state !== 0) return; this.state = 1; var sync; if (this.func) { try { sync = this.func(this.end.bind(this), this.bundle); } catch (error) { console.error(error); } } if (sync && sync.then) sync.catch(error => console.error(error)).then(this.end.bind(this)); }; Task.prototype.end = function () { if (this.state !== 1) return; this.state = 2; this.manager.onFinishTask(this); }; function TaskManager(opt) { EventEmitter/* default.call */.ZP.call(this); opt = opt || {}; this.limit = ((typeof opt.limit === "number") && opt.limit >= 1) ? opt.limit : Infinity; this.pendingTasks = []; this.runningTasks = []; } OOP/* default.mixClass */.ZP.mixClass(TaskManager, EventEmitter/* default */.ZP); /*** * * @param {function(finishTask: function, bundle: any): (void|Promise)} func * @param {any} bundle */ TaskManager.prototype.requestTask = function (func, bundle) { var task = new Task(this, func, bundle); if (this.runningTasks.length < this.limit) { this.runningTasks.push(task); this.emit('task_begin', { type: 'task_begin', task }, this); task.begin(); } else { this.pendingTasks.push(task); } } TaskManager.prototype.onFinishTask = function (task) { var idx = this.runningTasks.indexOf(task); if (idx < 0) return; this.runningTasks.splice(idx, 1); this.emit('task_end', { type: 'task_end', task }, this); while (this.pendingTasks.length > 0 && this.runningTasks.length < this.limit) { task = this.pendingTasks.shift(); this.runningTasks.push(task); this.emit('task_begin', { type: 'task_begin', task }, this); task.begin(); } } TaskManager.prototype.newTask = function () { var task = new Task(this, null, null); this.runningTasks.push(task); this.emit('task_begin', { type: 'task_begin', task }, this); task.begin(); return task; }; /* harmony default export */ const AppPattern_TaskManager = (TaskManager); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Modal.js var Modal = __webpack_require__(9826); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/MessageDialog.js var MessageDialog = __webpack_require__(3488); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Hanger.js var Hanger = __webpack_require__(655); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Vec2.js var Vec2 = __webpack_require__(557); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Rectangle.js var Rectangle = __webpack_require__(2759); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/WindowBox.js var WindowBox = __webpack_require__(774); // EXTERNAL MODULE: ./node_modules/absol/src/Network/FileSaver.js var FileSaver = __webpack_require__(5447); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/DropZone.js var DropZone = __webpack_require__(1577); // EXTERNAL MODULE: ./node_modules/absol/src/Detector/BrowserDetector.js var BrowserDetector = __webpack_require__(9399); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ContextMenu.js var ContextMenu = __webpack_require__(7054); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextArea2.js var TextArea2 = __webpack_require__(5789); // EXTERNAL MODULE: ./node_modules/absol-acomp/assets/exticons/catalog.json var catalog = __webpack_require__(2398); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/finder/FileThumbnail.js var thumbnailCache = {}; var dbSync; var getDb = () => { dbSync = dbSync || new Promise((resolve) => { var request = window.indexedDB.open('FileThumbnailDB', 1); request.onupgradeneeded = (event) => { var db = event.target.result db.createObjectStore("files", {}); }; request.onsuccess = (event) => { var db = event.target.result; var request1; if (localStorage.getItem('FileThumbnail_clear_cache') === '1') { localStorage.removeItem('FileThumbnail_clear_cache'); request1 = db.transaction('files', 'readwrite').objectStore('files').clear(); request1.onsuccess = () => { resolve(db); } request1.onerror = () => { resolve(null); } } else resolve(db); } request.onerror = () => { resolve(null); } }); return dbSync; } var dbGetItem = (key) => { return getDb().then(db => { if (!db) return null; var request = db.transaction('files').objectStore('files').get(key); return new Promise(resolve => { request.onsuccess = (event) => { var data = event.target.result; resolve(data); }; request.onerror = () => { resolve(null); } }) }); }; var dbSetItem = (key, value) => { return getDb().then(db => { if (!db) return null; var objectStore = db.transaction('files', 'readwrite').objectStore('files'); var request = objectStore.put(value, key); return new Promise(resolve => { request.onsuccess = (event) => { var data = event.target.result; resolve(data); }; request.onerror = () => { resolve(null); } }); }); }; document.addEventListener('keydown', (event) => { if (event.ctrlKey && event.key === 'F5') { localStorage.setItem('FileThumbnail_clear_cache', '1'); } }); var url2small = url => { return new Promise(resolve => { var image = new Image(); image.crossOrigin = 'anonymous'; image.crossorigin = 'anonymous'; image.src = url; image.onload = function () { var now = new Date(); if (image.naturalWidth <= 200 && image.naturalHeight < 200) { resolve(url); return; } var scale = Math.min(200 / image.naturalWidth, 200 / image.naturalHeight); var width = Math.round(image.naturalWidth * scale); var height = Math.round(image.naturalHeight * scale); var canvas = document.createElement('canvas'); canvas.width = width; canvas.height = height; var ctx = canvas.getContext('2d'); for (var i = 0; i < 20; ++i) for (var j = 0; j < 20; ++j) { ctx.fillStyle = (i ^ j) & 1 ? '#BBBBBB' : '#FFFFFF'; ctx.fillRect(i * 10, j * 10, 10, 10); } ctx.drawImage(image, 0, 0, width, height); resolve(canvas.toDataURL('image/jpeg', 0.5)); }; }); }; var getThumbnailUrl = url => { if (!thumbnailCache[url]) { thumbnailCache[url] = dbGetItem(url).then(result => { if (!result) { result = url2small(url).then(canvasResult => { if (canvasResult) dbSetItem(url, canvasResult); return canvasResult; }); } return result; }); } return thumbnailCache[url]; }; function FileThumbnail() { this._value = null; this.$fileName = (0,ACore.$)('.as-file-thumbnail-file-name', this); this.$bg = (0,ACore.$)('.as-file-thumbnail-background', this); /*** * @type {string} * @name fileName * @memberOf FileThumbnail# */ /*** * @type {string|null} * @name fileType * @memberOf FileThumbnail# */ /*** * @type {string|null} * @name thumbnail * @memberOf FileThumbnail# */ /*** * @type {boolean} * @name isDirectory * @memberOf FileThumbnail# */ } FileThumbnail.tag = 'FileThumbnail'.toLowerCase(); FileThumbnail.render = function () { return (0,ACore._)({ class: 'as-file-thumbnail', child: [ { class: 'as-file-thumbnail-background' }, { class: 'as-file-thumbnail-file-name', child: [] }, { class: 'as-file-thumbnail-check', child: 'span.mdi.mdi-check-bold' } ] }); }; FileThumbnail.prototype._updateFileName = function () { var fileName = this.fileName; if (!fileName) { return; } var parts; var matched; matched = fileName.match(/([^_+\-.]+)|([_+\-.]+)/g); parts = matched || []; if (parts.length > 2 && parts[parts.length - 2] === '.') { parts[parts.length - 2] += parts[parts.length - 1]; parts.pop(); } parts = parts.map(txt => { return (0,ACore._)({ tag: 'span', child: { text: txt } }); }); this.$fileName.clearChild().addChild(parts); }; FileThumbnail.prototype._updateThumbnail = function () { var previewUrl; var thumbnail = this.thumbnail; var fileType = this.isDirectory ? 'folder' : this.fileType; if (thumbnail) { if (typeof thumbnail === "string") { this._previewUrl = thumbnail; getThumbnailUrl(thumbnail).then(smallerUrl => { if (thumbnail !== this._previewUrl) return; this.$bg.addStyle('backgroundImage', 'url("' + smallerUrl + '")'); }) } else if (thumbnail instanceof Blob || thumbnail instanceof File) { thumbnail.url = thumbnail.url || URL.createObjectURL(thumbnail); this._previewUrl = thumbnail.url; } } if (catalog.indexOf(fileType) >= 0) { previewUrl = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + fileType + '.svg'; } else { previewUrl = MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/' + 'blank' + '.svg'; } if (previewUrl) { this.$bg.addStyle('backgroundImage', 'url("' + encodeURI(previewUrl) + '")'); } else { this.$bg.removeStyle('backgroundImage'); } } FileThumbnail.property = {}; FileThumbnail.property.value = { set: function (value) { value = value || null; this._value = value; this._valueInfo = (0,utils.fileInfoOf)(value); this._updateFileName(); this._updateThumbnail(); }, get: function () { return this._value; } }; FileThumbnail.property.fileName = { set: function (value) { this._fileName = value; this._updateFileName(); }, get: function () { return this._fileName || (this._valueInfo && this._valueInfo.name) || null; } }; FileThumbnail.property.fileType = { set: function (value) { this._fileType = value; this._updateThumbnail(); }, /*** * @this FileInputBox * @return {*} */ get: function () { if (this.isDirectory) return null; return this._fileType || (this._valueInfo && this._valueInfo.type) || null; } }; FileThumbnail.property.checked = { set: function (value) { if (value) { this.addClass('as-checked'); } else { this.removeClass('as-checked'); } }, get: function () { return this.hasClass('as-checked'); } }; FileThumbnail.property.thumbnail = { set: function (value) { this._thumbnail = value || null; this._updateThumbnail(); }, get: function () { return this._thumbnail; } }; FileThumbnail.property.isDirectory = { set: function (value) { if (value) { this.addClass('as-is-directory'); } else { this.removeClass('as-is-directory'); } }, get: function () { return this.hasClass('as-is-directory'); } } ACore/* default.install */.Z.install(FileThumbnail); /* harmony default export */ const finder_FileThumbnail = (FileThumbnail); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Searcher.js var Searcher = __webpack_require__(9024); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Context.js var Context = __webpack_require__(5721); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringFormat.js var stringFormat = __webpack_require__(6382); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DomSignal.js var DomSignal = __webpack_require__(5150); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/RibbonButton.js var RibbonButton = __webpack_require__(9664); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/finder/Finder.js var isMobile = BrowserDetector/* default.isMobile */.Z.isMobile; /*** * @extends AElement * @constructor */ function Finder() { if (isMobile) this.addClass('as-mobile'); // if (BrowserDetector.isMobile) alert("Chưa hỗ trợ điện thoại!"); this.$attachhook = (0,ACore._)('attachhook').addTo(this); this.$attachhook.requestUpdateSize = () => { this.layoutCtn.update(); this.navCtrl.notifyVisibleContentItems(); }; this.$attachhook.once('attached', () => { ResizeSystem/* default.add */.Z.add(this.$attachhook); this.layoutCtn.update(); this.navCtrl.onStart(); this.navCtrl.notifyVisibleContentItems(); ContextMenu/* default.auto */.Z.auto(); }); this.domSignal = new DomSignal/* default */.ZP((0,ACore._)('attachhook').addTo(this)); this.$header = (0,ACore.$)('.as-finder-header', this); this.$nomalActionCtn = (0,ACore.$)('.as-finder-normal-action-button-ctn', this); this.$tinyActionCtn = (0,ACore.$)('.as-finder-tiny-action-button-ctn', this); this.$contentHeader = (0,ACore.$)('.as-finder-content-header', this); this.$navCtn = (0,ACore.$)('.as-finder-nav-ctn', this); this.$nav = (0,ACore.$)(ExpTree/* ExpGroup.tag */.uz.tag, this.$navCtn); this.$searchCtn = (0,ACore.$)('.as-finder-search-ctn', this); this.$contentCtn = (0,ACore.$)('.as-finder-content-ctn', this); this.$content = (0,ACore.$)('.as-finder-content', this); this.$body = (0,ACore.$)('.as-finder-body', this); this.$commandButtons = (0,ACore.$$)('.as-finder-nav-header button', this) .concat((0,ACore.$$)('.as-finder-content-header button', this)) .concat((0,ACore.$$)('.as-finder-search-footer button', this)) .concat((0,ACore.$$)('.as-finder-search-header button', this)) .reduce((ac, cr) => { var name = cr.attr('name'); ac[name] = cr; if (cr.items) {//ribbon button cr.on('select', (event) => { this.execCommand(name, event.item.value, event.item); }); } else { cr.on('click', () => { this.execCommand(name); }); } return ac; }, {}); this.$searchTypeSelect = (0,ACore.$)('.as-finder-search-type-select', this); this.$searchText = (0,ACore.$)('.as-finder-search-text', this); this.fileSystem = new AbsolFileSystem(); this.layoutCtn = new LayoutController(this); this.navCtrl = new NavigatorController(this); this.selectCtrl = isMobile ? new MobileSelectController(this) : new SelectController(this); this.uploadCtrl = new UploadController(this); this.commandCtrl = new CommandController(this); this.folderDialog = new FolderDialog(this); this.searchCtrl = new SearchController(this); /*** * @type {string} * @name displayPath * @memberOf Finder# */ /*** * @type {string} * @name path * @memberOf Finder# */ /*** * @type {string} * @name rootPath * @memberOf Finder# */ /*** * @type {string} * @name accept * @memberOf Finder# */ } Finder.tag = 'Finder'.toLowerCase(); Finder.render = function () { return (0,ACore._)({ class: 'as-finder', extendEvent: ['selectedchange', 'dblclickfile'], attr: { 'data-selected-file-count': '0', 'data-selected-folder-count': '0' }, child: [ { class: 'as-finder-header', child: [ { class: 'as-finder-normal-action-button-ctn', /* child: Finder.prototype.actions.map(act => ({ tag: FlexiconButton.tag, attr: { name: act.name }, props: { text: act.text, // icon: act.icon } }))*/ }, { class: 'as-finder-tiny-action-button-ctn', /*child: Finder.prototype.actions.map(act => ({ tag: 'button', attr: { name: act.name, title: act.text }, child: act.icon }))*/ } ] }, { class: ['as-finder-nav-ctn'], child: [ { class: 'as-finder-nav-header', child: [ { class: 'as-finder-nav-header-left', child: [{ tag: 'button', class: 'as-transparent-button', attr: { title: "Close Navigator", name: 'nav_toggle' }, child: 'span.mdi.mdi-menu-open' }] }, { class: 'as-finder-nav-header-right', child: [ { tag: 'button', class: 'as-transparent-button', attr: { title: "Search", name: 'switch_to_search' }, child: 'span.mdi.mdi-magnify', }, { tag: 'button', class: 'as-transparent-button', attr: { title: "Expand All", name: 'nav_expand_all' }, child: 'span.mdi.mdi-arrow-expand-vertical', }, { tag: 'button', class: 'as-transparent-button', attr: { title: "Collapse All", name: 'nav_collapse_all' }, child: 'span.mdi.mdi-arrow-collapse-vertical' }, { tag: 'button', class: 'as-transparent-button', attr: { title: "Reload", name: 'reload' }, child: 'span.mdi.mdi-reload' } ] } ] }, { tag: ExpTree/* ExpGroup.tag */.uz.tag, class: 'as-bscroller' } ] }, { class: 'as-finder-search-ctn', child: [ { class: 'as-finder-search-header', child: [{ tag: 'button', class: 'as-transparent-button', attr: { title: "Close Navigator", name: 'nav_toggle' }, child: 'span.mdi.mdi-menu-open' }] }, { class: 'as-finder-search-body', child: [ { tag: Searcher/* default.tag */.Z.tag, class: 'as-finder-search-text', }, { class: 'as-finder-search-field', child: [ { child: { text: 'Kiểu' } }, { child: { tag: 'selectmenu', class: 'as-finder-search-type-select', props: { items: [ { text: 'Tất cả', value: 'all', icon: 'span.mdi.mdi-asterisk' }, { text: 'Hình ảnh', value: 'image', icon: 'span.mdi.mdi-image-outline' }, { text: 'Tài liệu', value: 'document', icon: 'span.mdi.mdi-file-document' } ] } } } ] }, { class: 'as-finder-search-footer', child: [ { tag: FlexiconButton/* default.tag */.Z.tag, attr: { name: 'start_search' }, props: { text: 'OK' } }, { tag: FlexiconButton/* default.tag */.Z.tag, attr: { name: 'cancel_search' }, props: { text: 'Hủy' } } ] } ] } ] }, { tag: DropZone/* default.tag */.Z.tag, attr: { 'data-view-as': 'list' }, class: ['as-finder-body'], child: [ { class: 'as-finder-content-header', child: [ { class: 'as-finder-content-header-left', child: [ { tag: 'button', attr: { title: 'Open Navigator', name: 'nav_toggle' }, class: 'as-transparent-button', child: ['span.mdi.mdi-menu'] }, { tag: RibbonButton/* default */.Z, attr: { title: 'View As', name: 'content_view_as' }, class: 'as-transparent-button', props: { text: 'List', icon: 'span.mdi.mdi-format-list-bulleted-square', items: [ { icon: 'span.mdi.mdi-format-list-bulleted-square', text: 'List', value: 'list', }, { text: 'Medium Icons', icon: 'span.mdi.mdi-grid', value: 'content' }, { text: 'Lage Icons', icon: 'span.mdi.mdi-image-outline', value: 'lage_icons' } ] }, // child: ['span.mdi.mdi-format-list-bulleted-square'] } ] }, { class: 'as-finder-content-header-right', } ] }, { tag: Hanger/* default.tag */.Z.tag, class: 'as-finder-content-ctn', props: { hangOn: 5 }, child: { class: ['as-finder-content',] } }, { class: 'as-finder-upload-overlay', child: [ { class: 'as-finder-upload-overlay-icon-ctn', child: 'span.mdi.mdi-cloud-upload-outline' }, { child: { text: 'Thả file vào đây để tải lên' } } ] } ] } ] }); }; Finder.property = {}; Finder.property.fileSystem = { set: function (fs) { this._fileSystem = fs; }, get: function () { return this._fileSystem; } }; Finder.property.path = { set: function (path) { this.navCtrl.path = path; }, get: function () { return this.navCtrl.path; } }; Finder.property.displayPath = { // set: function (path) { // this.navCtrl.path = path; // }, get: function () { return this.navCtrl.displayPath; } }; Finder.property.rootPath = { set: function (path) { this.navCtrl.rootPath = path; }, get: function () { return this.navCtrl.rootPath; } }; Finder.property.selectedFiles = { get: function () { return this.selectCtrl.$selectedItems.filter(elt => elt.stat && !elt.stat.isDirectory).map(elt => elt.stat); } } Finder.prototype.execCommand = function (name) { return this.commandCtrl.execCommand.apply(this.commandCtrl, arguments); }; Finder.prototype.addCommand = function (name, descriptor) { this.commandCtrl.addCommand(name, descriptor); }; Finder.prototype.addButton = function (name, bf) { this.commandCtrl.addButton(name, bf); }; /**** * * @param {string} name * @param {string=} bf */ Finder.prototype.addFolderMenuItem = function (name, bf) { this.commandCtrl.addFolderMenuItem(name, bf); }; Finder.prototype.findZIndex = function () { var c = this; var res = 0; var zIndex; while (c) { zIndex = parseInt(getComputedStyle(c).getPropertyValue('z-index')); if (!isNaN(zIndex)) res = Math.max(zIndex, res); c = c.parentElement; } return res; }; ACore/* default.install */.Z.install(Finder); /* harmony default export */ const finder_Finder = (Finder); var FinderCommands = {}; Finder.prototype.commands = FinderCommands; FinderCommands.upload = { text: 'Tải lên', icon: 'span.mdi.mdi-upload-outline', match: function (fileElt) { return !fileElt && this.searchCtrl.state !== 'RUNNING' && this.dirStat && this.dirStat.writable; }, /*** * @this Finder */ exec: function () { (0,utils.openFileDialog)({ multiple: true }).then(files => { if (files && files.length > 0) { this.uploadCtrl.upload(files); } }) } }; FinderCommands.upload_to_folder = { text: 'Tải lên', icon: 'span.mdi.mdi-upload-outline', match: function (treElt) { return treElt && treElt.stat && treElt.stat.writable; }, /*** * @this Finder */ exec: function () { //todo: selected folder (0,utils.openFileDialog)({ multiple: true }).then(files => { if (files && files.length > 0) { this.uploadCtrl.upload(files); } }) } }; FinderCommands.delete = { icon: 'span.mdi.mdi-delete-outline', text: 'Xóa', /*** * @this Finder */ match: function (fileElt) { return fileElt && this.selectCtrl.$selectedItems.length > 0 && this.selectCtrl.$selectedItems.every(elt => elt.stat && !elt.stat.isDirectory && elt.stat.writable); }, /*** * @this Finder */ exec: function () { var paths = this.selectCtrl.$selectedItems.map(elt => elt.stat.path); var names = this.selectCtrl.$selectedItems.map(elt => elt.fileName); if (names.length === 0) return; var contentElt = (0,ACore._)({ style: { maxHeight: '50vh', overflow: 'auto' }, child: { style: { display: 'table' }, child: names.map(name => ({ style: { display: 'table-row' }, child: [ { style: { display: 'table-cell', padding: '5px 20px 5px 10px' }, child: { style: { 'min-width': '30em', }, child: { text: name } } }, { style: { display: 'table-cell', padding: '5px 10px' }, child: { class: 'as-finder-task-check', style: { 'min-width': '3em', textAlign: 'right', }, child: 'span' } } ] })) } }); var modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style: { zIndex: this.findZIndex() + 9000 }, child: { tag: MessageDialog/* default.tag */.Z.tag, props: { dialogTitle: 'Xóa file', dialogActions: [ { name: "ok", text: "OK" }, { name: 'cancel', text: 'Hủy' } ] }, child: [{ child: { tag: 'span', child: { text: "Xác nhận xóa những file dưới đây: " } } }, contentElt], on: { action: (event, sender) => { var promises; var errors = []; if (event.action.name === 'ok') { sender.$actionBtns[0].disabled = true; sender.$actionBtns[0].text = "Đang tiến hành xóa.."; sender.$actionBtns[1].disabled = true; promises = paths.map((path, i) => { return this.fileSystem.unlink(path).then(() => { (0,ACore.$)('.as-finder-task-check', contentElt.firstChild.childNodes[i]).addChild((0,ACore._)('span.mdi.mdi-check')) }).catch(err => { errors.push(err); (0,ACore.$)('.as-finder-task-check', contentElt.firstChild.childNodes[i]) .addChild((0,ACore._)('span.mdi.mdi-alert-decagram-outline')) .addChild((0,ACore._)({ tag: 'span', class: '.as-finder-task-error-message', child: { text: err.message } })) }); }); Promise.all(promises).then(() => { var commands = {}; if (errors.length > 0) { errors.forEach(err => { if (err.command) { commands[err.command] = true; } }); if (commands.reload) this.execCommand('reload'); sender.$actionBtns[1].disabled = false; sender.$actionBtns[0].text = "Hoàn thành"; } else { this.navCtrl.reload(this.path, true).then(() => modal.remove()); } }); } else { modal.remove(); } } } } }).addTo(document.body); } }; FinderCommands.view = { icon: 'span.mdi.mdi-eye-outline', text: 'Xem', match: function (fileElt) { return !!fileElt; }, /*** * @this Finder */ exec: function () { var elt = this.selectCtrl.$selectedItems[0]; if (!elt) return; if (elt.stat.isDirectory) { this.navCtrl.viewDir(elt.stat.path); return; } var url = elt.stat.url; if (!url) return; var type = elt.fileType; if (type === 'xlsx' || type === 'docx' || type === 'xls' || type === 'doc' || type === 'ppt' || type === 'pptx') { url = 'https://view.officeapps.live.com/op/embed.aspx?src=' + encodeURIComponent(url); } else { url = encodeURI(url); } var mineType = ext2MineType/* default */.Z[type] || 'none'; var content; if (mineType.startsWith('video')) { content = (0,ACore._)({ tag: 'video', style: { maxWidth: 'calc(90vw - 20px)', maxHeight: 'calc(90vh - 80px)', width: '900px', height: 'auto' }, attr: { autoplay: 'true', controls: 'true' }, props: { src: url } }); } else if (mineType.startsWith('audio')) { content = (0,ACore._)({ tag: 'audio', style: { margin: '5px' }, attr: { autoplay: 'true', controls: 'true' }, props: { src: url } }); } else if (mineType.startsWith('image')) { content = (0,ACore._)({ tag: 'img', style: { maxWidth: 'calc(90vw - 20px)', maxHeight: 'calc(90vh - 80px)', width: 'auto', height: 'auto' }, attr: {}, props: { src: url } }); } else { content = (0,ACore._)({ tag: 'iframe', style: { maxWidth: 'calc(90vw - 20px)', maxHeight: 'calc(90vh - 80px)', width: '900px', height: '600px' }, props: { src: url, onload: function () { // console.log(this.contentWindow.document.body.offsetHeight, this.contentWindow.document.body.offsetWidth) } } }); } var modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style: { zIndex: this.findZIndex() + 9000 }, child: { tag: WindowBox/* default.tag */.Z.tag, child: content, props: { windowTitle: elt.stat.displayName || elt.stat.name, windowActions: [ { name: 'close', icon: 'span.mdi.mdi-close' } ] }, on: { action: () => { modal.remove(); } } } }).addTo(document.body); } }; FinderCommands.download = { icon: 'span.mdi.mdi-download-outline', text: 'Tải về', match: function (elt) { return elt && this.selectCtrl.$selectedItems.length > 0 && this.selectCtrl.$selectedItems.every(elt => elt.stat && !elt.stat.isDirectory); }, /*** * @this Finder */ exec: function () { var taskMng = new AppPattern_TaskManager({ limit: 4 }); this.selectCtrl.$selectedItems.forEach(elt => { if (elt.isDirectory) return; var url = elt.stat.url; if (!url) return; taskMng.requestTask(function (onFinish, bundle) { (0,FileSaver.saveAs)(bundle.url, bundle.name) setTimeout(onFinish, 100); }, { url: url, name: elt.fileName }); }); } }; FinderCommands.rename = { icon: 'span.mdi.mdi-rename', text: 'Đổi tên', /*** * @this Finder */ match: function (elt) { return elt && this.selectCtrl.$selectedItems.length === 1 && elt.stat && !elt.stat.isDirectory && elt.stat.writable;//todo: rename folder }, /*** * @this Finder */ exec: function () { var elt = this.selectCtrl.$selectedItems[0]; if (!elt) return; var path = elt.stat.path; var value = elt.fileName; var input = (0,ACore._)({ tag: TextArea2/* default.tag */.Z.tag, style: { outline: 'none', position: 'absolute', zIndex: 100, left: 0, bottom: 0, width: '100%' }, props: { value: elt.fileName }, on: { blur: () => { var newValue = input.value.replace(/<>:\\\/\|\?\*\^/g, '').trim(); input.remove(); if (!value) return; if (value === newValue) return; this.fileSystem.rename(path, newValue).then(newStat => { elt.stat = newStat; elt.value = newStat.url; elt.fileName = newStat.displayName || newStat.name; }); } } }); elt.addChild(input); input.on('keydown', function (event) { if (event.key.match(/<>:\\\/\|\?\*\^/)) { event.preventDefault(); setTimeout(() => input.updateSize(), 30) } else if (event.key === 'Enter') { input.blur(); } else if (event.key === 'Escape') { input.value = value; input.updateSize(); input.blur(); } }, true); input.updateSize(); input.focus(); var ext = value.match(/\.[a-zA-Z0-9]+$/); if (ext) { ext = ext[0]; } else { ext = ''; } input.setSelectionRange(0, value.length - ext.length); } }; FinderCommands.copy = { icon: 'span.mdi.mdi-content-copy', text: 'Sao chép', exec: function () { } }; FinderCommands.move = { text: 'Di chuyển', icon: 'span.mdi.mdi-file-move-outline', match: function (fileElt) { if (arguments.length === 0) { return this.selectCtrl.$selectedItems.every(elt => elt.stat.writable); } return fileElt && fileElt.stat && fileElt.stat.writable; }, /*** * @this Finder */ exec: function () { var itemElements = this.selectCtrl.$selectedItems.slice(); var paths = itemElements.map(elt => elt.stat.path); var names = itemElements.map(elt => elt.fileName); if (names.length === 0) return; var currentFolderPath = this.path; this.folderDialog.open(currentFolderPath, false, (newFolderPath, stat) => newFolderPath !== currentFolderPath && stat.writable, 'Di chuyển file').then(newFolderPath => { if (!newFolderPath) return; if (newFolderPath === currentFolderPath) return; var contentElt = (0,ACore._)({ style: { maxHeight: '50vh', overflow: 'auto' }, child: { style: { display: 'table' }, child: names.map(name => ({ style: { display: 'table-row' }, child: [ { style: { display: 'table-cell', padding: '5px 20px 5px 10px' }, child: { style: { 'min-width': '30em', }, child: { text: name } } }, { style: { display: 'table-cell', padding: '5px 10px' }, child: { class: 'as-finder-task-check', style: { 'min-width': '3em', textAlign: 'right', }, child: 'span' } } ] })) } }); var modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style: { zIndex: this.findZIndex() + 9000 }, child: { tag: MessageDialog/* default.tag */.Z.tag, props: { dialogTitle: 'Di chuyển file', dialogActions: [{ name: 'close', text: 'Đóng' }] }, child: [{ child: { tag: 'span', child: { text: "Danh sách đang di chuyển: " } } }, contentElt], on: { action: (event, sender) => { modal.remove(); } } } }).addTo(document.body); var errors = []; var promises = paths.map((path, i) => { var newPath = newFolderPath + '/' + path.split('/').pop(); return this.fileSystem.move(path, newPath).then(() => { (0,ACore.$)('.as-finder-task-check', contentElt.firstChild.childNodes[i]).addChild((0,ACore._)('span.mdi.mdi-check')) }).catch(err => { errors.push(err); (0,ACore.$)('.as-finder-task-check', contentElt.firstChild.childNodes[i]) .addChild((0,ACore._)('span.mdi.mdi-alert-decagram-outline')).addChild((0,ACore._)({ tag: 'span', class: '.as-finder-task-error-message', child: { text: err.message } })); }); }); Promise.all(promises).then(() => { var commands = {}; if (errors.length > 0) { errors.forEach(err => { if (err.command) { commands[err.command] = true; } }); if (commands.reload) this.execCommand('reload'); } else { this.navCtrl.reload(this.path, true).then(() => modal.remove()); } }); }); } }; FinderCommands.move_dir = { text: 'Di chuyển', icon: 'span.mdi.mdi-folder-arrow-right-outline', match: function (expElt) { return expElt && expElt.stat && expElt.stat.writable && !expElt.stat.isVirtual; }, /*** * @this Finder */ exec: function (expElt) { var path = expElt.stat.path; var currentFolderPath = path.split('/'); var name = currentFolderPath.pop(); currentFolderPath = currentFolderPath.join('/'); this.folderDialog.open(currentFolderPath, true, newPath => !newPath.startsWith(path), 'Di chuyển thư mục').then(newFolderPath => { if (!newFolderPath) return; return this.fileSystem.move(path, newFolderPath + '/' + name).then(() => { this.path = newFolderPath + '/' + name; this.navCtrl.reload(this.rootPath).then(() => { this.navCtrl.viewDir(this.path) }); }); }) } }; FinderCommands.rmdir = { text: 'Xóa', icon: 'span.mdi.mdi-delete-outline', /*** * @this Finder * @param elt */ match: function (elt) { if (elt.stat && elt.stat.isVirtual) return false; if (elt) return elt.stat && elt.stat.writable; return false; }, exec: function (elt) { } }; FinderCommands.select_all = { text: 'Chọn tất cả', icon: 'span.mdi.mdi-select-all', match: function (fileElt) { return !fileElt; }, /*** * @this Finder */ exec: function () { this.selectCtrl.selectAll(); } }; FinderCommands.nav_expand_all = { /*** * @this Finder */ exec: function () { this.navCtrl.expandAll(); } }; FinderCommands.nav_collapse_all = { /*** * @this Finder */ exec: function () { this.navCtrl.collapseAll(); } }; FinderCommands.reload = { /*** * @this Finder */ exec: function () { this.fileSystem.clearCache(); this.navCtrl.reload().then(() => { this.navCtrl.viewDir(this.path); }); } }; FinderCommands.content_view_as = { /*** * @this Finder */ exec: function (value, item) { this.$commandButtons['content_view_as'].text = item.text; this.$commandButtons['content_view_as'].icon = item.icon; this.$body.attr('data-view-as', value); } }; FinderCommands.switch_to_search = { /*** * @this Finder */ exec: function () { this.searchCtrl.start(); } }; FinderCommands.cancel_search = { /*** * @this Finder */ exec: function () { this.searchCtrl.stop(); this.navCtrl.viewDir(this.path); } }; FinderCommands.start_search = { /*** * @this Finder */ exec: function () { this.searchCtrl.search(); } }; FinderCommands.nav_toggle = { icon: 'span.mdi.mdi-menu', exec: function () { if (this.hasClass('as-nav-open')) { this.removeClass('as-nav-open'); } else { this.addClass('as-nav-open'); } } }; /*** * * @param {Finder} elt * @constructor */ function LayoutController(elt) { this.elt = elt; this.actionButtonWidth = 0; this.elt.domSignal.on('requestUpdateActionButtonSize', this.updateActionButtonSize.bind(this)); this.elt.on('click', this.ev_click.bind(this)) } LayoutController.prototype.requestUpdateActionButtonSize = function () { this.elt.domSignal.emit('requestUpdateActionButtonSize'); }; LayoutController.prototype.updateActionButtonSize = function () { var font = this.elt.$nomalActionCtn.getComputedStyleValue('font'); var fontSize = this.elt.$nomalActionCtn.getFontSize(); this.actionButtonWidth = Array.prototype.reduce.call(this.elt.$nomalActionCtn.childNodes, (ac, cr) => { return ac + Math.max(110, 0.715 * fontSize * 2 + (0,utils.measureText)(cr.text, font).width) + 10; }, 60); this.update(); }; LayoutController.prototype.update = function () { var bound = this.elt.getBoundingClientRect(); if (bound.width < 500) { if (!this.elt.hasClass('as-mini-layout')) this.elt.addClass('as-mini-layout'); } else { if (this.elt.hasClass('as-mini-layout')) { this.elt.removeClass('as-mini-layout'); this.elt.removeClass('as-nav-open'); } } if (this.elt.hasClass('as-action-button-minimized')) { if (this.actionButtonWidth <= bound.width) { this.elt.removeClass('as-action-button-minimized'); } } else { if (this.actionButtonWidth > bound.width) { this.elt.addClass('as-action-button-minimized'); } } var bodyBound = this.elt.$body.getBoundingClientRect(); var col = Math.floor(bodyBound.width / 300) || 1; this.elt.$body.addStyle('--col', col + ''); }; LayoutController.prototype.ev_click = function (event) { if (event.target === this.elt) { this.elt.removeClass('as-nav-open'); } }; /*** * * @param {Finder} elt * @constructor */ function CommandController(elt) { Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this.elt = elt; this.$normalActionCtn = this.elt.$nomalActionCtn; this.$tinyActionCtn = this.elt.$tinyActionCtn; this.commands = Object.assign({}, this.elt.commands); this.buttonNames = ['upload', 'view', 'download', 'move', 'rename', 'delete']; this.folderMenuItemNames = ['upload_to_folder', 'move_dir']; this.contentMenuItemNames = ['view', 'download', 'upload', 'select_all', 'move', 'delete', 'rename']; this.$navCtn = this.elt.$navCtn; this.$navCtn.defineEvent('contextmenu').on('contextmenu', this.ev_navContextMenu); this.$contentCtn = this.elt.$contentCtn; this.$contentCtn.defineEvent('contextmenu').on('contextmenu', this.ev_contentContextMenu); this.updateButtons(); } CommandController.prototype.updateButtons = function () { this.$normalActionCtn.clearChild(); var buttons = this.buttonNames.map(name => { var desc = this.commands[name] || {}; return (0,ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, attr: { name: name }, props: { text: desc.text || name }, on: { click: () => { this.execCommand(name); } } }); }); this.$normalActionCtn.addChild(buttons); buttons = this.buttonNames.map(name => { var desc = this.commands[name] || {}; return (0,ACore._)({ tag: 'button', class: 'as-transparent-button', attr: { name: name }, child: desc.icon, on: { click: () => { this.execCommand(name); } } }); }); this.$tinyActionCtn.addChild(buttons); this.elt.layoutCtn.requestUpdateActionButtonSize(); }; CommandController.prototype.execCommand = function (name) { var args = Array.prototype.slice.call(arguments, 1); var desc = this.commands[name]; if (desc && typeof desc.exec === 'function') { return desc.exec.apply(this.elt, args); } return null; }; CommandController.prototype.addCommand = function (name, desc) { this.commands[name] = Object.assign({}, this.commands[name], desc); }; /**** * * @param {string} name * @param {string=} bf */ CommandController.prototype.addButton = function (name, bf) { var idx = this.buttonNames.indexOf(bf); var bfElt, smallBfElt; if (idx >= 0) { this.buttonNames.splice(idx, 0, name); bfElt = (0,ACore.$)(`button[name="${name}"]`, this.$normalActionCtn); smallBfElt = (0,ACore.$)(`button[name="${name}"]`, this.$tinyActionCtn); } else { this.buttonNames.push(name); } var desc = this.commands[name] || {}; this.$normalActionCtn.addChildBefore((0,ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, attr: { name: name }, props: { text: desc.text || name }, on: { click: () => { this.execCommand(name); } } }), bfElt); this.$tinyActionCtn.addChild((0,ACore._)({ tag: 'button', class: 'as-transparent-button', attr: { name: name }, child: desc.icon, on: { click: () => { this.execCommand(name); } } }), smallBfElt); this.elt.layoutCtn.requestUpdateActionButtonSize(); }; /**** * * @param {string} name * @param {string=} bf */ CommandController.prototype.addFolderMenuItem = function (name, bf) { idx = this.folderMenuItemNames.indexOf(name); if (idx >= 0) return; var idx = this.folderMenuItemNames.indexOf(bf); if (idx >= 0) this.folderMenuItemNames.splice(idx, 0, name); else this.folderMenuItemNames.push(name); }; /**** * * @param {string} name * @param {string=} bf */ CommandController.prototype.addContentMenuItem = function (name, bf) { idx = this.folderMenuItemNames.indexOf(name); if (idx >= 0) return;//todo var idx = this.folderMenuItemNames.indexOf(bf); if (idx >= 0) this.folderMenuItemNames.splice(idx, 0, name); else this.folderMenuItemNames.push(name); }; CommandController.prototype.ev_navContextMenu = function (event) { var expTree; var c = event.target; while (c && !expTree) { if (c.stat) expTree = c; c = c.parentElement; } if (expTree) this.elt.navCtrl.viewDir(expTree.stat.path, [this.elt.rootPath].concat(expTree.getPath()).join('/')); var items = this.folderMenuItemNames.map(name => { var desc = this.commands[name]; if (!desc) return null; if (typeof desc.match === "function") { if (!desc.match.call(this.elt, expTree)) return null; } return { text: desc.text, icon: desc.icon, cmd: name } }).filter(x => !!x); if (items.length > 0) { event.showContextMenu({ items: items }, (event) => { var cmd = event.menuItem.cmd; this.execCommand(cmd, expTree); }); } }; CommandController.prototype.ev_contentContextMenu = function (event) { var fileElt; var c = event.target; while (c && !fileElt) { if (c.stat) fileElt = c; c = c.parentElement; } var selectedElements = this.elt.selectCtrl.$selectedItems; if (fileElt && selectedElements.indexOf(fileElt) < 0) { this.elt.selectCtrl.deselectAll(); this.elt.selectCtrl.select(fileElt); } // if (expTree) this.elt.navCtrl.viewDir(expTree.stat.path, [this.elt.rootPath].concat(expTree.getPath()).join('/')); var items = this.contentMenuItemNames.map(name => { var desc = this.commands[name]; if (!desc) return null; if (typeof desc.match === "function") { if (!desc.match.call(this.elt, fileElt)) return null; } return { text: desc.text, icon: desc.icon, cmd: name } }).filter(x => !!x); if (items.length > 0) { event.showContextMenu({ items: items }, (event) => { var cmd = event.menuItem.cmd; this.execCommand(cmd, fileElt); }); } }; /*** * for desktop * @param {Finder} elt * @constructor */ function SelectController(elt) { this.elt = elt; this.$selectedItems = [];// first element is focus this.$content = this.elt.$content; this.$contentCtn = this.elt.$contentCtn; Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this._setupSelectTool(); } /*** * * @protected */ SelectController.prototype._setupSelectTool = function () { this._draged = false; this._dragOffset = new Vec2/* default */.Z(0, 0); this.$selectArea = (0,ACore._)('.as-finder-select-area'); this.$contentCtn.on('draginit', this.ev_dragInit) .on('dragdeinit', this.ev_dragDeinit) .on('dragstart', this.ev_dragStart) .on('drag', this.ev_drag) .on('dragend', this.ev_dragEnd); }; SelectController.prototype.deselectAll = function () { while (this.$selectedItems.length > 0) { this.$selectedItems.pop().checked = false; } this._updateCount(); this.elt.emit('selectedchange'); }; SelectController.prototype.select = function (elt) {//todo: more option this.deselectAll(); this.$selectedItems.push(elt); elt.checked = true; this._updateCount(); this.elt.emit('selectedchange'); }; SelectController.prototype.selectAll = function () {//todo: more option this.deselectAll(); var fileElements = Array.prototype.slice.call(this.$content.childNodes); this.$selectedItems.push.apply(this.$selectedItems, fileElements); fileElements.forEach(elt => { elt.checked = true; }); this._updateCount(); this.elt.emit('selectedchange'); }; SelectController.prototype.ev_dragInit = function (event) { if (event.target.tagName === 'INPUT' || event.target.tagName === 'TEXTAREA') { event.cancel(); return; } // event.preventDefault(); this._draged = false; }; SelectController.prototype.ev_dragDeinit = function (event) { if (!this._draged) this.ev_click(event); }; SelectController.prototype.ev_dragStart = function (event) { this._draged = true; this.elt.addClass('as-dragging'); this.$selectArea.addStyle('z-index', this.elt.findZIndex() + 100 + '').addTo(document.body); var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.$content.getBoundingClientRect()); this._dragOffset = event.currentPoint.sub(bound.A()); var pos = bound.A().add(this._dragOffset); this.$selectArea.addStyle({ left: pos.x + 'px', top: pos.y + 'px', }); }; SelectController.prototype.ev_drag = function (event) { this._draged = true; var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.$content.getBoundingClientRect()); var A = bound.A().add(this._dragOffset); var C = event.currentPoint; var sRect = Rectangle/* default.boundingPoints */.Z.boundingPoints([A, C]); this.$selectArea.addStyle({ left: sRect.x + 'px', top: sRect.y + 'px', width: sRect.width + 'px', height: sRect.height + 'px', }); }; SelectController.prototype.ev_dragEnd = function () { while (this.$selectedItems.length > 0) { this.$selectedItems.pop().checked = false; } var selectBound = Rectangle/* default.fromClientRect */.Z.fromClientRect(this.$selectArea.getBoundingClientRect()); Array.prototype.forEach.call(this.$content.childNodes, elt => { var bound = Rectangle/* default.fromClientRect */.Z.fromClientRect(elt.getBoundingClientRect()); if (selectBound.isCollapse(bound, 0)) { this.$selectedItems.push(elt); elt.checked = true; } }); this._draged = true; this.$selectArea.remove(); this.elt.removeClass('as-dragging'); this._updateCount(); this.elt.layoutCtn.update(); this.elt.emit('selectedchange'); }; SelectController.prototype._updateCount = function () { var folderCount = this.$selectedItems.filter(elt => elt.stat.isDirectory).length; this.elt.attr('data-selected-file-count', this.$selectedItems.length - folderCount + ''); this.elt.attr('data-selected-folder-count', folderCount + ''); } SelectController.prototype.ev_click = function (event) { event = event.originalEvent || event.originEvent || event; var c = event.target; var itemElt; while (c && !itemElt) { if (c.hasClass && c.hasClass('as-file-thumbnail')) { itemElt = c; break; } c = c.parentElement; } var focusIdx; var currentIdx; if (this.$selectedItems.length === 0 && itemElt) { this.$selectedItems.push(itemElt); itemElt.checked = true; } else if ((0,EventEmitter/* isMouseRight */.Ed)(event)) { } else if (!event.ctrlKey && !event.shiftKey) { while (this.$selectedItems.length > 0) { this.$selectedItems.pop().checked = false; } if (itemElt) { this.$selectedItems.push(itemElt); itemElt.checked = true; } } else if (event.shiftKey) { if (itemElt) { focusIdx = Array.prototype.indexOf.call(this.$content.childNodes, this.$selectedItems[0]); currentIdx = Array.prototype.indexOf.call(this.$content.childNodes, itemElt); while (this.$selectedItems.length > 1) { this.$selectedItems.pop().checked = false; } while (currentIdx !== focusIdx) { itemElt = this.$content.childNodes[currentIdx]; this.$selectedItems.push(itemElt); itemElt.checked = true; if (currentIdx < focusIdx) currentIdx++; else currentIdx--; } } } else if (event.ctrlKey) { if (itemElt) { currentIdx = this.$selectedItems.indexOf(itemElt); if (currentIdx >= 0) { this.$selectedItems.splice(currentIdx, 1); itemElt.checked = false; } else { this.$selectedItems.unshift(itemElt); itemElt.checked = true; } } } this._updateCount(); this.elt.layoutCtn.update(); this.elt.emit('selectedchange'); }; /*** * @extends SelectController * @param elt * @constructor */ function MobileSelectController(elt) { SelectController.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(MobileSelectController, SelectController); MobileSelectController.prototype._setupSelectTool = function () { this.$content.on('click', this.ev_click); }; /*** * * @param {Finder} elt * @constructor */ function UploadController(elt) { /*** * * @type {Finder} */ this.elt = elt; this.$body = this.elt.$body; Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this.$body.on({ fileenter: this.ev_fileEnter, filedrop: this.ev_fileDrop }) } UploadController.prototype.upload = function (files) { var screenSize = (0,Dom/* getScreenSize */.tE)(); var contentElt = (0,ACore._)({ style: { maxHeight: '50vh', overflow: 'auto' }, child: { style: { display: 'table' }, child: files.map(file => ({ style: { display: 'table-row' }, child: [ { style: { display: 'table-cell', padding: '5px 20px 5px 10px' }, child: { style: { 'width': Math.min(screenSize.width - 180, 800) / 14 + 'em', textOverflow: 'ellipsis', overflow: 'hidden' }, child: { text: file.name } } }, { style: { display: 'table-cell', padding: '5px 10px' }, child: { class: 'as-upload-percent', style: { 'min-width': '3em', textAlign: 'right', color: 'rgb(30,237,219)' }, child: { text: '' } } } ] })) } }); var modal = (0,ACore._)({ tag: Modal/* default.tag */.Z.tag, style: { zIndex: this.elt.findZIndex() + 9000 }, child: { tag: MessageDialog/* default.tag */.Z.tag, props: { dialogTitle: 'Tải lên', }, child: contentElt } }).addTo(document.body); //because file system in keeview not allow writing multiple file at the same time var syncs = files.reduce((sync, file, i) => { var percentText = (0,ACore.$)('.as-upload-percent', contentElt.firstChild.childNodes[i]); return sync.then(()=>{ return this.elt.fileSystem.writeFile(this.elt.path + '/' + file.name, file, done => { var textBound = percentText.getBoundingClientRect(); var ctnBound = contentElt.getBoundingClientRect(); if (textBound.bottom > ctnBound.bottom) { contentElt.scrollTop += textBound.bottom - ctnBound.bottom; } percentText.firstChild.data = Math.round(done * 100) + '%'; }); }); }, Promise.resolve()); syncs.then(() => { this.elt.navCtrl.reload(this.elt.path, true).then(() => modal.remove()); }); }; UploadController.prototype.ev_fileEnter = function (event) { var files = Array.prototype.slice.call(event.dataTransfer.files); if (files.length === 0) return; }; UploadController.prototype.ev_fileDrop = function (event) { if (this.elt.searchCtrl.state === "RUNNING") return; var files = event.files; if (files.length > 0) this.upload(files); }; /*** * @extends EventEmitter * @param {Finder} elt * @constructor */ function FolderDialog(elt) { EventEmitter/* default.call */.ZP.call(this); this.elt = elt; } OOP/* default.mixClass */.ZP.mixClass(FolderDialog, EventEmitter/* default */.ZP); FolderDialog.prototype._init = function () { if (this.$modal) return; this.$modal = (0,ACore._)({ tag: 'modal', class: 'as-finder-folder-dialog-modal', child: { tag: MessageDialog/* default.tag */.Z.tag, props: { dialogTitle: 'Duyệt thư mục', dialogActions: [ { name: 'ok', text: 'OK' }, { name: 'cancel', text: 'Hủy' } ] }, child: [ { class: 'as-finder-folder-dialog-content', child: [ { class: 'as-finder-folder-dialog-selected-ctn', child: [ { tag: 'span', child: { text: 'Đã chọn thư mục: ' } }, { tag: 'span', child: { text: ' ... ' } } ] }, { class: 'as-finder-folder-dialog-tree-ctn', child: [ { tag: ExpTree/* ExpGroup.tag */.uz.tag }, { tag: ExpTree/* ExpTree.tag */.yb.tag, class: 'as-finder-folder-dialog-tree-root', props: { name: 'root', icon: 'span.mdi.mdi-harddisk' } } ] } ] } ] } }); this.$dialog = (0,ACore.$)(MessageDialog/* default.tag */.Z.tag, this.$modal); this.$treeCtn = (0,ACore.$)('.as-finder-folder-dialog-tree-ctn', this.$modal); this.$rootTree = (0,ACore.$)('.as-finder-folder-dialog-tree-root', this.$modal); this.$content = (0,ACore.$)('.as-finder-folder-dialog-content', this.$modal); this.$expGroup = (0,ACore.$)(ExpTree/* ExpGroup.tag */.uz.tag, this.$content); this.$selectedCtn = (0,ACore.$)('.as-finder-folder-dialog-selected-ctn', this.$content); this.$selectedPath = this.$selectedCtn.childNodes[1]; this.$activeNode = null; } FolderDialog.prototype.open = function (initPath, showRoot, checkFunc, title) { var cPath = initPath; this._init(); var fileSystem = this.elt.fileSystem; var zIndex = this.elt.findZIndex() + 9000; this.$modal.addStyle('z-index', zIndex + ''); this.$modal.addTo(document.body); if (this.$activeNode) { this.$activeNode.active = false; this.$activeNode = null; } this.$dialog.$actionBtns[0].disabled = true; this.$dialog.dialogTitle = title || 'Duyệt'; var makeTree = (path, ctnElt, level) => { level = level || 0; return fileSystem.readDir(path).then(dirs => Promise.all(dirs.map(dir => fileSystem.stat(path + '/' + dir)))) .then(stats => stats.filter(stat => { return stat.isDirectory })) .then(stats => { var syncs = []; ctnElt.clearChild(); var children = stats.map(stat => { var nodePath = path + '/' + stat.name; var node = (0,ACore._)({ tag: ExpTree/* ExpTree.tag */.yb.tag, props: { stat: stat, name: stat.displayName || stat.name, icon: { tag: 'img', props: { src: MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/folder.svg' } }, path: nodePath }, on: { statuschage: () => { }, press: () => { if (this.$activeNode) this.$activeNode.active = false; this.$activeNode = node; this.$activeNode.active = true; this.$selectedPath.firstChild.data = node.getPath().join('/'); cPath = nodePath; if (checkFunc && !checkFunc(cPath, stat)) { this.$dialog.$actionBtns[0].disabled = true; } else { this.$dialog.$actionBtns[0].disabled = false; } } } }); if (nodePath === cPath) { node.active = true; this.$activeNode = node; } if (checkFunc && !checkFunc(nodePath, stat)) { node.getNode().addStyle('opacity', 0.3 + ''); } node.getNode().on({ dblclick: () => { if (node.status === 'close') { node.status = 'open'; } else if (node.status === 'open') { node.status = 'close'; } } }); if (stat.name !== 'node_modules') syncs.push(makeTree(nodePath, node, level + 1)); return node; }); children.forEach(c => { ctnElt.addChild(c); }); if (children.length) { ctnElt.status = level > 1 ? 'close' : 'open'; } else { ctnElt.status = 'none'; } return Promise.all(syncs); }); } var onRootPress; if (showRoot) { this.$expGroup.addStyle('display', 'none'); this.$rootTree.removeStyle('display'); if (cPath === this.elt.rootPath) { this.$activeNode = this.$rootTree; this.$activeNode.active = true; } onRootPress = () => { var node = this.$rootTree; var nodePath = this.elt.rootPath; if (this.$activeNode) this.$activeNode.active = false; this.$activeNode = node; this.$activeNode.active = true; this.$selectedPath.firstChild.data = node.getPath().join('/'); cPath = nodePath; if (cPath === initPath || (checkFunc && !checkFunc(cPath, { writable: true }))) { this.$dialog.$actionBtns[0].disabled = true; } else { this.$dialog.$actionBtns[0].disabled = false; } }; this.$rootTree.on('press', onRootPress); } else { this.$expGroup.removeStyle('display'); this.$rootTree.addStyle('display', 'none'); } makeTree(this.elt.rootPath, showRoot ? this.$rootTree : this.$expGroup).then(() => { var p; if (this.$activeNode) { this.$selectedPath.firstChild.data = this.$activeNode.getPath().join('/'); p = this.$activeNode.getParent(); while (p) { if (p.status === 'close') { p.status = 'open'; } p = p.getParent && p.getParent(); } setTimeout(() => { (0,utils.vScrollIntoView)(this.$activeNode.firstChild); }, 10) } }); return new Promise((resolve) => { var finish = (event) => { this.$dialog.off('action', finish); this.$modal.remove(); if (event.action.name === 'cancel') resolve(null); else resolve(cPath); if (onRootPress) { this.$rootTree.off('press', onRootPress); } } this.$dialog.on('action', finish); }); }; var isMatchAccept = (accept, statInfo) => { if (accept && (typeof accept === "object") && accept.accept) accept = accept.accept; if (typeof accept !== "string") return true; if (!accept) return true; if (statInfo.isDirectory) return true; var fileInfo = (0,utils.fileInfoOf)(statInfo); if (accept.startsWith('image')) { return fileInfo.mimeType && fileInfo.mimeType.startsWith('image'); } return true;// not handle other case } /*** * * @param {Finder} elt * @constructor */ function NavigatorController(elt) { this.elt = elt; this.path = ''; this.rootPath = ''; this._states = {}; this._notifiedVisibleIdx = 0; this.$navCtn = this.elt.$navCtn; this.$nav = this.elt.$nav; this.$contentCtn = this.elt.$contentCtn; this.$content = this.elt.$content; Object.keys(this.constructor.prototype).forEach(key => { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } }); this.$contentCtn.on('scroll', this.ev_contentScroll); } NavigatorController.prototype.onStart = function () { /** * * @type {AbsolFileSystem} */ this.fileSystem = this.elt.fileSystem; this.$treeByPath = {}; this.$treeByPath[this.rootPath || '..'] = this.$nav; this.reload(this.rootPath, true); }; NavigatorController.prototype.reload = function (fromPath, autoOpen) { var opened = !autoOpen; var makeTree = (path, ctnElt) => { if (!opened && ctnElt.path) { this.viewDir(ctnElt.path, [this.elt.rootPath].concat(ctnElt.getPath()).join('/')); opened = true; } return this.fileSystem.readDir(path).then(dirs => Promise.all(dirs.map(dir => this.fileSystem.stat(path + '/' + dir)))) .then(stats => stats.filter(stat => { return stat.isDirectory })) .then(stats => { var syncs = []; ctnElt.clearChild(); var children = stats.map(stat => { var nodePath = path + '/' + stat.name; var node = (0,ACore._)({ tag: ExpTree/* ExpTree.tag */.yb.tag, props: { stat: stat, name: stat.displayName || stat.name, icon: { tag: 'img', props: { src: MessageInput/* default.iconAssetRoot */.ZP.iconAssetRoot + '/folder.svg' } }, path: nodePath, }, on: { statuschage: () => { this._states[path + '/' + stat.name] = node.status; }, press: () => { if (this.path !== nodePath) this.viewDir(nodePath, [this.elt.rootPath].concat(node.getPath()).join('/')); } } }); node.getNode().on({ dblclick: () => { if (node.status === 'close') { node.status = 'open'; } else if (node.status === 'open') { node.status = 'close'; } this._states[nodePath] = node.status; } }); this.$treeByPath[nodePath] = node; if (stat.name !== 'node_modules') syncs.push(makeTree(nodePath, node)); if (!opened) { this.viewDir(nodePath, [this.elt.rootPath].concat(node.getPath()).join('/')); opened = true; } return node; }); children.forEach(c => { ctnElt.addChild(c); }); if (children.length) { if (this._states[ctnElt.path] === 'close' || this._states[ctnElt.path] === 'open') { ctnElt.status = this._states[ctnElt.path]; } else { ctnElt.status = 'close'; } } else { ctnElt.status = 'none'; } return Promise.all(syncs); }); } if (this.$treeByPath[fromPath || '..']) return makeTree(fromPath, this.$treeByPath[fromPath || '..']); return Promise.resolve(); }; NavigatorController.prototype.viewDir = function (path) { this.elt.selectCtrl.deselectAll(); if (this.$treeByPath[this.path]) { this.$treeByPath[this.path].active = false; this.$treeByPath[this.path].active = false; } this.path = path; this.$treeByPath[this.path].active = true; var c = this.$treeByPath[this.path].getParent(); while (c) { if (c.status === 'close') c.status = 'open'; c = c.getParent && c.getParent(); } (0,utils.vScrollIntoView)(this.$treeByPath[this.path].firstChild); this.fileSystem.stat(path).then(stat => { this.elt.dirStat = stat; if (this.path !== path) return; if (stat.writable) this.elt.addClass('as-writable-folder'); else this.elt.removeClass('as-writable-folder'); if (stat.isVirtual) { this.elt.addClass('as-virtual-folder'); } else { this.elt.removeClass('as-virtual-folder'); } }) this.fileSystem.readDir(path).then(dirs => Promise.all(dirs.map(dir => this.fileSystem.stat(path + '/' + dir)))) .then(stats => { if (this.path !== path) return; stats.sort((a, b) => { var aName, bName; if (a.isDirectory === b.isDirectory) { aName = a.displayName || a.name; bName = b.displayName || b.name; if (aName < bName) return -1; return 1; } else { if (a.isDirectory) return -1; return 1; } }); stats = stats.filter(x => isMatchAccept(this.elt.accept, x)); this.viewContent(stats); }); }; NavigatorController.prototype.viewContent = function (stats) { this.clearContent(); stats.forEach(stat => { this.pushContentItem(stat); }); this.notifyVisibleContentItems(); }; NavigatorController.prototype.clearContent = function () { this._notifiedVisibleIdx = 0; this.$content.clearChild(); }; NavigatorController.prototype.pushContentItem = function (stat) { var elt = (0,ACore._)({ tag: finder_FileThumbnail.tag, extendEvent: ['visible'], attr: { title: stat.displayName || stat.name }, props: { isDirectory: stat.isDirectory, value: stat.url, fileName: stat.displayName || stat.name, stat: stat }, on: { visible: () => { var mineType = ext2MineType/* default */.Z[elt.fileType]; if (mineType && mineType.startsWith('image/')) { elt.thumbnail = stat.url; } }, dblclick: () => { var prevented = false; var event; if (!stat.isDirectory) { event = { fileElt: elt, stat: stat, preventDefault: () => { prevented = true; } }; this.elt.emit('dblclickfile', event); } if (!prevented) this.elt.execCommand('view'); } } }); this.$content.addChild(elt); }; NavigatorController.prototype.notifyVisibleContentItems = function () { var elt; var bound = this.$contentCtn.getBoundingClientRect(); var eBound; while (this._notifiedVisibleIdx < this.$content.childNodes.length) { elt = this.$content.childNodes[this._notifiedVisibleIdx]; eBound = elt.getBoundingClientRect(); if (eBound.top < bound.bottom) { elt.emit('visible'); } else { break; } this._notifiedVisibleIdx++; } }; NavigatorController.prototype.expandAll = function () { var visit = nodeElt => { if (nodeElt.status === 'close') { nodeElt.status = 'open'; this._states[nodeElt.path] = 'open'; } if (nodeElt.status === 'open') { nodeElt.getChildren().forEach(visit); } }; Array.prototype.forEach.call(this.$nav.childNodes, visit); }; NavigatorController.prototype.collapseAll = function () { var visit = nodeElt => { if (nodeElt.status === 'open') { nodeElt.status = 'close'; this._states[nodeElt.path] = 'close'; } if (nodeElt.status === 'close') { nodeElt.getChildren().forEach(visit); } }; Array.prototype.forEach.call(this.$nav.childNodes, visit); }; NavigatorController.prototype.ev_contentScroll = function (event) { this.notifyVisibleContentItems(); }; var fileTextQuery2Regex = text => { var code = (0,stringFormat.nonAccentVietnamese)(text.toLowerCase()) .replace(/[.,+^$()\[\]{}|\\]/g, x => '\\' + x) .replace(/\*+/g, '(.*)') .replace(/\?/g, '.'); return new RegExp(code, 'i'); } /*** * @extends Context * @param {Finder} elt * @constructor */ function SearchController(elt) { Context/* default.apply */.Z.apply(this); this.elt = elt; this.$searchText = this.elt.$searchText.on('keydown', event => { if (event.key === 'Enter') { this.$searchText.blur(); this.search(); } }); } OOP/* default.mixClass */.ZP.mixClass(SearchController, Context/* default */.Z); SearchController.prototype.onStart = function () { // console.log('start') this.elt.addClass('as-searching'); this.$searchText.value = ''; this.$searchText.focus(); }; SearchController.prototype.onStop = function () { this.elt.removeClass('as-searching'); this.session = (0,stringGenerate.randomIdent)(10); this.$searchText.waiting = false; }; SearchController.prototype.search = function () { var session = (0,stringGenerate.randomIdent)(10); this.session = session; this.elt.navCtrl.clearContent(); this.$searchText.waiting = true; var fileSystem = this.elt.fileSystem; var rootPath = this.elt.rootPath; var result = []; var type = this.elt.$searchTypeSelect.value; var text = this.$searchText.value.trim(); var regex = fileTextQuery2Regex(text); var isMatched = stat => { var fileInfo = (0,utils.fileInfoOf)(stat.displayName || stat.name); var mineType = fileInfo.mimeType || ''; var fileType = fileInfo.type || ''; fileType = fileType.toLowerCase(); if (mineType && type !== 'all') { if (type === 'image' && !mineType.startsWith('image') && type !== 'svg') { return false; } else if (type === 'document' && ['doc', 'docx', 'pdf', 'xlsx'].indexOf(fileType) < 0 && !mineType.startsWith('text')) { return false; } } if (text.length === 0) return true; if (stat.displayName && stat.displayName.match(regex)) return true; if (stat.name && (0,stringFormat.nonAccentVietnamese)(stat.name.toLowerCase()).match(regex)) return true; return false; } var handleStat = stat => { if (session !== this.session) return; if (stat.isDirectory) return new Promise(rs => { setTimeout(() => { rs(visitDir(stat.path)); }, 5); }); if (isMatched(stat)) { this.elt.navCtrl.pushContentItem(stat); this.elt.navCtrl.notifyVisibleContentItems(); } }; var handleDirResult = (dir, names) => { var syncs = names.map(name => { return fileSystem.stat(dir + '/' + name).then(stat => { if (session !== this.session) return; if (stat) return handleStat(stat); }); }); return Promise.all(syncs); } var visitDir = path => { return fileSystem.readDir(path).then((names => handleDirResult(path, names))); } visitDir(rootPath).then(() => { if (session !== this.session) return; this.$searchText.waiting = false; }); }; /*** * * @constructor */ function FinderFileSystem() { } FinderFileSystem.prototype.supporteDisplayName = false; FinderFileSystem.prototype.readDir = function (path) { }; FinderFileSystem.prototype.unlink = function (path) { console.log(path); }; FinderFileSystem.prototype.stat = function (path) { }; FinderFileSystem.prototype.rmdir = function (path) { }; FinderFileSystem.prototype.mkdir = function (path) { }; FinderFileSystem.prototype.writeFile = function (file, data) { }; FinderFileSystem.prototype.copy = function () { }; FinderFileSystem.prototype.rename = function (path, name) { }; FinderFileSystem.prototype.move = function (oldPath, newPath) { }; FinderFileSystem.prototype.clearCache = function () { }; /*** * @extends FinderFileSystem * @constructor */ function AbsolFileSystem() { FinderFileSystem.apply(this, arguments); this.sync = Promise.resolve(); this.cache = { readDir: {}, stats: {} }; this.taskMng = new AppPattern_TaskManager({ limit: 4 }); } OOP/* default.mixClass */.ZP.mixClass(AbsolFileSystem, FinderFileSystem); AbsolFileSystem.prototype.API_PREFIX = location.href.indexOf('localhost') >= 0 ? 'https://absol.cf' : ''; AbsolFileSystem.prototype.clearCache = function () { this.cache = { readDir: {}, stats: {} }; }; AbsolFileSystem.prototype.readDir = function (path) { this.sync = this.sync.then(() => { if (this.cache.readDir[path || '..']) return this.cache.readDir[path || '..']; return fetch(this.API_PREFIX + '/filesystem/ls.php', { method: 'POST', cache: "no-cache", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ path: path }) }).then(res => res.json()).then(res => { res = res.filter(c => c.path.startsWith('/html')); res.forEach(c => { c.name = c.path.split('/').pop(); c.url = c.path.replace('/html', this.API_PREFIX ||location.origin) }); this.cache.readDir[path || '..'] = res.map(c => c.name); res.forEach(c => { this.cache.stats[c.path] = c; }); }).then(() => { return this.cache.readDir[path || '..']; }); }); return this.sync; }; AbsolFileSystem.prototype.stat = function (path) { return this.sync.then(() => { path = path || ''; if (this.cache.stats[path || '..']) return this.cache.stats[path || '..']; var dir = path.split('/'); dir.pop(); dir = dir.join('/'); return this.readDir(dir).then(() => { return this.cache.stats[path || '..']; }) }); } /*** * * @param file * @param {File|Blob}data * @param {function(done: number):void=}onProcess */ AbsolFileSystem.prototype.writeFile = function (file, data, onProcess) { if (file.toLowerCase().endsWith('.php')) file += '.txt'; var folderPath = file.split('/'); folderPath.pop(); folderPath = folderPath.join('/'); delete this.cache.readDir[folderPath]; var prefix = ['file', new Date().getTime(), (0,random/* randomArbitrary */.Ld)(0, 1000000) >> 0].join('_'); var parts = []; var chuck_limit = 2 << 20; var partName; var fileSize = data.size; var fileStartOffset = 0; var fileEndOffset = 0; var idx = 0; var syncs = []; var syncDone = 0; var bundle; var began = false; var handle = bundle => { return new Promise(rs => { this.taskMng.requestTask((finishTask, bundle) => { if (typeof onProcess === "function" && !began) { began = true; onProcess(syncDone / (syncs.length || 1)); } var form = new FormData(); form.append('action', 'upload_part'); form.append('fileUpload', bundle.file, bundle.name); fetch(this.API_PREFIX + '/filesystem/writefile.php', { method: 'POST', body: form }).then(res => res.text()).then(text => { if (text !== 'OK') throw new Error(text); syncDone++; if (typeof onProcess === "function") { onProcess(syncDone / (syncs.length || 1)); } rs(location.origin); finishTask(); }); }, bundle); }) } while (fileStartOffset < fileSize) { fileEndOffset = Math.min(fileStartOffset + chuck_limit, fileSize); partName = prefix + '.p' + idx; parts.push(partName); bundle = { file: data.slice(fileStartOffset, fileEndOffset), idx: idx, name: partName }; idx++; fileStartOffset = fileEndOffset; syncs.push(handle(bundle)); } return Promise.all(syncs).then(() => { var form = new FormData(); form.append('action', 'join_parts'); form.append('parts', parts.join(';')); form.append('path', file); fetch(this.API_PREFIX + '/filesystem/writefile.php', { method: 'POST', body: form }).then(res => res.text()).then(text => { if (text !== 'OK') throw new Error(text); }); }); }; AbsolFileSystem.prototype.unlink = function (path) { var folderPath = path.split('/'); folderPath.pop(); folderPath = folderPath.join('/'); delete this.cache.readDir[folderPath]; var form = new FormData(); form.append('action', 'delete_files'); form.append('paths', path); return fetch(this.API_PREFIX + '/filesystem/writefile.php', { method: 'POST', body: form }).then(res => res.text()).then(text => { if (text !== 'OK') throw new Error(text); }); }; AbsolFileSystem.prototype.rename = function (path, name) { var folderPath = path.split('/'); folderPath.pop(); folderPath = folderPath.join('/'); var form = new FormData(); form.append('action', 'rename'); form.append('path', path); form.append('new_name', name); return fetch(this.API_PREFIX + '/filesystem/writefile.php', { method: 'POST', body: form }).then(res => res.text()).then(text => { if (text !== 'OK') throw new Error(text); var newPath = folderPath + '/' + name; delete this.cache.readDir[folderPath]; delete this.cache.stats[path]; return { url: newPath.replace('/html', this.API_PREFIX || location.origin), path: newPath, name: name } }); }; AbsolFileSystem.prototype.move = function (oldPath, newPath) { var oldFolderPath = oldPath.split('/'); oldFolderPath.pop(); oldFolderPath = oldFolderPath.join('/'); var newFolderPath = newPath.split('/'); newFolderPath.pop(); newFolderPath = newFolderPath.join('/'); var form = new FormData(); form.append('action', 'move'); form.append('old_path', oldPath); form.append('new_path', newPath); return fetch(this.API_PREFIX + '/filesystem/writefile.php', { method: 'POST', body: form }).then(res => res.text()).then(text => { if (text !== 'OK') throw new Error(text); delete this.cache.readDir[oldFolderPath]; delete this.cache.readDir[newFolderPath]; delete this.cache.stats[oldPath]; }); }; /***/ }), /***/ 103: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1477); /*** * * @param {SelectionItem[]} arr * @constructor */ function ItemDictionary(arr, opt) { this.opt = Object.assign({ depth: true }, opt || {}); this.arr = arr; this.dict = {}; this.dupKeys = []; this.update(); } ItemDictionary.prototype.update = function () { this.dict = {}; var dict = this.dict; var depth = this.opt.depth; var dupKeyDict = {}; function scan(arr) { var item; var key; for (var i = 0; i < arr.length; ++i) { item = arr[i]; key = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.keyStringOf)(item.value); if (dict[key]) { dict[key].dupItems = dict[key].dupItems || []; dict[key].dupItems.push(item); dupKeyDict[key] = 1; } else { dict[key] = { idx: i, item: item }; } if (depth && item.items && item.items.length > 0) { scan(item.items); } } } scan(this.arr); this.dupKeys = Object.keys(dupKeyDict); }; /*** * * @param {String | Number} value * @returns {SelectionItem | null} */ ItemDictionary.prototype.getItemByValue = function (value) { var iDict = this.dict[(0,_utils__WEBPACK_IMPORTED_MODULE_0__.keyStringOf)(value)]; if (iDict) return iDict.item; return null; }; /*** * * @param {String | Number} value * @returns {Array<SelectionItem> } */ ItemDictionary.prototype.getAllItemByValue = function (value) { var key = (0,_utils__WEBPACK_IMPORTED_MODULE_0__.keyStringOf)(value); var iDict = this.dict[key]; if (iDict) return [iDict.item].concat(iDict.dupItems[key] || []); return []; }; ItemDictionary.prototype.getDuplicateKeys = function () { return this.dupKeys; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ItemDictionary); /***/ }), /***/ 4623: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ list_ListSearchMaster) }); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); // EXTERNAL MODULE: ./node_modules/absol/src/Network/Thread.js + 1 modules var Thread = __webpack_require__(6672); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/list/ListSearchFactor.js function ListSearchFactor(global) { /*** * @typedef SelectionItem2 * @property {String} text * @property {String} desc * @property {String} __text__ * @property {String} __nvnText__ * @property {Array<String>} __words__ * @property {Array<String>} __nvnWords__ * @property {object} __wordDict__ * @property {object} __nvnWordDict__ * @module SelectionItem2 */ function revokeResource(o) { if (!o) return; var oc, ocs; var keys, key; if (Array.isArray(o)) { while (o.length) { oc = o.pop(); try { revokeResource(oc); } catch (err) { } } } else if (o.removeResource) { o.removeResource(); } else if (typeof o === "object") { keys = []; ocs = []; for (key in o) { keys.push(key); } while (keys.length) { key = keys.pop(); ocs.push(o[keys]); try { delete o[key]; } catch (err) { } } while (ocs.length) { try { revokeResource(ocs.pop()); } catch (err) { } } } ocs = undefined; oc = undefined; keys = undefined; key = undefined; o = undefined; } function nonAccentVietnamese(s) { return s.replace(/à|á|ạ|ả|ã|â|ầ|ấ|ậ|ẩ|ẫ|ă|ằ|ắ|ặ|ẳ|ẵ/g, "a") .replace(/À|Á|Ạ|Ả|Ã|Â|Ầ|Ấ|Ậ|Ẩ|Ẫ|Ă|Ằ|Ắ|Ặ|Ẳ|Ẵ/g, "A") .replace(/è|é|ẹ|ẻ|ẽ|ê|ề|ế|ệ|ể|ễ/g, "e") .replace(/È|É|Ẹ|Ẻ|Ẽ|Ê|Ề|Ế|Ệ|Ể|Ễ/g, "E") .replace(/ì|í|ị|ỉ|ĩ/g, "i") .replace(/Ì|Í|Ị|Ỉ|Ĩ/g, "I") .replace(/ò|ó|ọ|ỏ|õ|ô|ồ|ố|ộ|ổ|ỗ|ơ|ờ|ớ|ợ|ở|ỡ/g, "o") .replace(/Ò|Ó|Ọ|Ỏ|Õ|Ô|Ồ|Ố|Ộ|Ổ|Ỗ|Ơ|Ờ|Ớ|Ợ|Ở|Ỡ/g, "O") .replace(/ù|ú|ụ|ủ|ũ|ư|ừ|ứ|ự|ử|ữ/g, "u") .replace(/Ù|Ú|Ụ|Ủ|Ũ|Ư|Ừ|Ứ|Ự|Ử|Ữ/g, "U") .replace(/ỳ|ý|ỵ|ỷ|ỹ/g, "y") .replace(/Ỳ|Ý|Ỵ|Ỷ|Ỹ/g, "Y") .replace(/đ/g, "d") .replace(/Đ/g, "D") .replace(/\u0300|\u0301|\u0303|\u0309|\u0323/g, "") .replace(/\u02C6|\u0306|\u031B/g, ""); } function harmonicMean(a, b) { return 2 / (1 / a + 1 / b); } function wordLike(a, b) { var m = a.length; var n = b.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) if (a.charAt(i) == b.charAt(j)) { if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + 1) Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); return Q[map(m, n)] / harmonicMean(m, n); } function wordsMatch(sq1, sq2, matchWordPow) { matchWordPow = matchWordPow === undefined ? 1 : matchWordPow; var m = sq1.length; var n = sq2.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); var e = 0.0; for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) { e = Math.pow(wordLike(sq1[i], sq2[j]), matchWordPow); if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + e) Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; e = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); if (e > Q[map(i + 1, j + 1)]) Q[map(i + 1, j + 1)] = e; } return Q[map(m, n)]; } var EXTRA_MATCH_SCORE = 9; var NVN_EXTRA_MATCH_SCORE = 8; var EQUAL_MATCH_SCORE = 10; var WORD_MATCH_SCORE = 3; var HAS_WORD_SCORE = 30; var HAS_NVN_WORD_SCORE = 29; /*** * * @param {SelectionItem2} item * @returns {*} */ function prepareSearchForItem(item) { if (!item.text || !item.text.charAt) item.text = item.text + ''; var splitter = /([_\s\b\-()\[\]"']| | | ")+/g; var text = item.text.replace(splitter, ' '); var __words__ = text.split(/\s+/).filter(w=>!!w).map(w=>w.toLowerCase()); var __text__ = __words__.join(' '); var __wordDict__ = __words__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); var __nvnText__ = nonAccentVietnamese(__text__); var __nvnWords__ = __words__.map(w=>nonAccentVietnamese(w)); var __nvnWordDict__ = __nvnWords__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); Object.defineProperties(item, { __text__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __words__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __wordDict__: { configurable: true, enumerable: false, writable: true, value: __wordDict__ }, __textNoneCase__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __wordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __nvnText__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWords__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ }, __nvnWordDict__: { configurable: true, enumerable: false, writable: true, value: __nvnWordDict__ }, __nvnTextNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ } }); return item; } function isItemMustIncluded(queryItem, item) { if (!queryItem) return true; if (item.__nvnText__.indexOf(queryItem.__nvnText__) >= 0) { return true; } var dict1 = queryItem.__nvnWordDict__; var dict2 = item.__nvnWordDict__; for (var i in dict1) { for (var j in dict2) { if (j.indexOf(i) < 0) return false; } } return true; } function calcItemMatchScore(queryItem, item) { var score = 0; if (!item.__text__) return 0; function calcByWordDict(queryWords, wordDict) { var hwScore = 0; var i; wordDict = Object.assign({}, wordDict); var bestWordMatched, bestWordMatchScore = 0; var word, wordScore; for (i = 0; i < queryWords.length; ++i) { bestWordMatchScore = 0; bestWordMatched = null; for (word in wordDict) { wordScore = wordLike(word, queryWords[i]) - 1e-3 * wordDict[word]; if (wordScore > bestWordMatchScore) { bestWordMatched = word; bestWordMatchScore = wordScore; } } if (bestWordMatchScore >0) { hwScore += bestWordMatchScore * WORD_MATCH_SCORE; delete wordDict[bestWordMatched]; } } return hwScore; } score += calcByWordDict(queryItem.__words__, item.__wordDict__); score += calcByWordDict(queryItem.__nvnWords__, item.__nvnWordDict__); if (item.__text__ === queryItem.__text__) { score += EQUAL_MATCH_SCORE; } var extraIndex = item.__text__.indexOf(queryItem.__text__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } extraIndex = item.__nvnText__.indexOf(queryItem.__nvnText__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } score += Math.max(wordsMatch(queryItem.__words__, item.__words__), wordsMatch(queryItem.__nvnWords__, item.__nvnWords__))/ Math.max(queryItem.__words__.length + 1, 1); return score; } function scoreCmp(a, b) { if (b.score === a.score) { if (b.item.__nvnText__ > a.item.__nvnText__) return -1; return 1; } return b.score - a.score; } function keyStringOf(o) { var type = typeof o; var keys; if (o && type === "object") { if (o.getTime) { return 'd(' + o.getTime() + ')'; } else if (o.length && o.map) { return 'a(' + o.map(val => keyStringOf(val)).join(',') + ')'; } else { keys = Object.keys(o); keys.sort(); return 'o(' + keys.map(key => key + ':' + keyStringOf(o[key])).join(',') + ')'; } } else { return type[0] + '(' + o + ')'; } } function matchFilter(item, filter) { if (!filter) return true; var keys = item.keys; if (!keys) return false; for (var i in filter) { if (!keyCmp(keys[i], filter[i])) return false; } return true; } function toComparable(x) { if (!x) return x; var type = typeof x; if (type === 'string') return x; if (type === "number") return x; if (type === "boolean") return x; if (type.getTime) return type.getTime(); return x; } function keyCmp(itemKey, filterKey) { if (itemKey === filterKey) return true; if (!itemKey !== !filterKey) return false; if (!itemKey || !filterKey) return false; var filterKeyString = keyStringOf(filterKey) function withFilter(x) { var xString = keyStringOf(x) var res = xString === filterKeyString; if (!res && (typeof filterKey === "object")) { if (filterKey.some) { res = filterKey.some(function (y) { return keyStringOf(y) === x; }); } else if (('min' in filterKey) || ('max' in filterKey)) { res = true; if ('min' in filterKey) { res = res && toComparable(x) >= toComparable(filterKey.min); } if ('max' in filterKey) { res = res && toComparable(x) <= toComparable(filterKey.max); } } } return res; } if (itemKey.some) { return itemKey.some(withFilter); } else return withFilter(itemKey); } function Slave() { this.items = []; } Slave.prototype.revokeResource = function () { revokeResource(this.items); this.items = undefined; } Slave.prototype.processItems = function (items) { this.items = items; this.items.forEach(function visit(item) { prepareSearchForItem(item); if (item.items) item.items.forEach(visit); }) }; Slave.prototype.callQuery = function (query) { prepareSearchForItem(query); var minScore = Infinity; var maxScore = -Infinity; var scoreHolders = this.items.map(function visit(item) { var res = {}; res.score = calcItemMatchScore(query, item); res.mustIncluded = isItemMustIncluded(query, item); res.value = item.value; res.maxChildScore = -Infinity; if (item.items) { res.child = item.items.map(visit); res.maxChildScore = res.child.reduce((ac, cr) => Math.max(ac, cr.maxChildScore, cr.score), res.maxChildScore); } minScore = Math.min(minScore, res.score); maxScore = Math.max(maxScore, res.score); return res; }); var threshold = maxScore - (maxScore - minScore) / 4; if (maxScore < 3) threshold = maxScore - (maxScore - minScore) / 8; var resDict = scoreHolders.reduce(function rValue(ac, cr) { if (Math.max(cr.maxChildScore, cr.score) >= threshold || cr.mustIncluded) ac[cr.value] = [cr.score, cr.maxChildScore]; if (cr.child) cr.child.reduce(rValue, ac); return ac; }, {}); return resDict; }; var slaves = {}; global.transferSearchItems = function (id, items) { if (!slaves[id]) slaves[id] = new Slave(); slaves[id].processItems(items); }; global.callQuery = function (id, query) { if (slaves[id]) return slaves[id].callQuery(query); return null; }; global.destroySlave = function (id) { revokeResource(slaves); delete slaves[id]; }; } // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/list/ListSearchMaster.js function ListSearchMaster() { this.prepare(); this.id = (0,stringGenerate.randomIdent)(8); this.cache = {}; this.share.instances.push(this.id); } ListSearchMaster.prototype.share = { worker: null, instances: [] }; ListSearchMaster.prototype.prepare = function () { if (this.share.worker) return; this.share.worker = new Thread/* default */.Z({ methods: { init: ListSearchFactor }, extendCode: 'init(this)' }); }; ListSearchMaster.prototype.transfer = function (items) { this.prepare(); this.cache = {}; return this.share.worker.invoke('transferSearchItems', this.id, items); }; ListSearchMaster.prototype.query = function (query) { var key = (0,utils.calcDTQueryHash)(query); if (!this.cache[key]) { this.cache[key] = this.share.worker.invoke('callQuery', this.id, query); } return this.cache[key]; }; ListSearchMaster.prototype.destroy = function () { // return; this.cache = {}; this.share.worker.invoke('destroySlave', this.id); var idx = this.share.instances.indexOf(this.id); this.destroy = noop/* default */.Z; if (idx >= 0) { this.share.instances.splice(idx, 1); } }; ListSearchMaster.prototype.revokeResource = function () { }; /* harmony default export */ const list_ListSearchMaster = (ListSearchMaster); /***/ }), /***/ 2551: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (/* binding */ prepareSearchForItem), /* harmony export */ "Lb": () => (/* binding */ prepareSearchForList), /* harmony export */ "lk": () => (/* binding */ calcItemMatchScore), /* harmony export */ "o": () => (/* binding */ searchListByText), /* harmony export */ "$l": () => (/* binding */ searchTreeListByText) /* harmony export */ }); /* unused harmony export searchCheckListByText */ /* harmony import */ var absol_src_String_stringFormat__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6382); /* harmony import */ var absol_src_String_stringMatching__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(991); var UNCASE_MATCH_SCORE = 4; var UVN_MATCH_SCORE = 3; var EXTRA_MATCH_SCORE = 9; var NVN_EXTRA_MATCH_SCORE = 8; var EQUAL_MATCH_SCORE = 10; var WORD_MATCH_SCORE = 3; var HAS_WORD_SCORE = 30; var HAS_NVN_WORD_SCORE = 29; /*** * * @param {SelectionItem} item * @returns {*} */ function prepareSearchForItem(item) { if (!item.text || !item.text.charAt) item.text = item.text + ''; var splitter = /([_\s\b\-()\[\]"']| | | ")+/g; var text = item.text.replace(splitter, ' '); var __words__ = text.split(/\s+/).filter(w=>!!w).map(w=>w.toLowerCase()); var __text__ = __words__.join(' '); var __wordDict__ = __words__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); var __nvnText__ = (0,absol_src_String_stringFormat__WEBPACK_IMPORTED_MODULE_0__.nonAccentVietnamese)(__text__); var __nvnWords__ = __words__.map(w=>(0,absol_src_String_stringFormat__WEBPACK_IMPORTED_MODULE_0__.nonAccentVietnamese)(w)); var __nvnWordDict__ = __nvnWords__.reduce((ac, cr, i) => { ac[cr] = ac[cr] || i + 1; return ac; }, {}); Object.defineProperties(item, { __text__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __words__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __wordDict__: { configurable: true, enumerable: false, writable: true, value: __wordDict__ }, __textNoneCase__: { configurable: true, enumerable: false, writable: true, value: __text__ }, __wordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __words__ }, __nvnText__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWords__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ }, __nvnWordDict__: { configurable: true, enumerable: false, writable: true, value: __nvnWordDict__ }, __nvnTextNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnText__ }, __nvnWordsNoneCase__: { configurable: true, enumerable: false, writable: true, value: __nvnWords__ } }); return item; } function prepareSearchForList(items) { var item; for (var i = 0; i < items.length; ++i) { if (typeof items[i] == 'string') { items[i] = { text: items[i], value: items[i] }; } item = items[i]; prepareSearchForItem(item); if (item.items) prepareSearchForList(item.items); } return items; } function calcItemMatchScore(queryItem, item) { var score = 0; if (!item.__text__) return 0; function calcByWordDict(queryWords, wordDict) { var hwScore = 0; var i; wordDict = Object.assign({}, wordDict); var bestWordMatched, bestWordMatchScore = 0; var word, wordScore; for (i = 0; i < queryWords.length; ++i) { bestWordMatchScore = 0; bestWordMatched = null; for (word in wordDict) { wordScore = (0,absol_src_String_stringMatching__WEBPACK_IMPORTED_MODULE_1__.wordLike)(word, queryWords[i]) - 1e-3 * wordDict[word]; if (wordScore > bestWordMatchScore) { bestWordMatched = word; bestWordMatchScore = wordScore; } } if (bestWordMatchScore >0) { hwScore += bestWordMatchScore * WORD_MATCH_SCORE; delete wordDict[bestWordMatched]; } } return hwScore; } score += calcByWordDict(queryItem.__words__, item.__wordDict__); score += calcByWordDict(queryItem.__nvnWords__, item.__nvnWordDict__); if (item.__text__ === queryItem.__text__) { score += EQUAL_MATCH_SCORE; } var extraIndex = item.__text__.indexOf(queryItem.__text__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } extraIndex = item.__nvnText__.indexOf(queryItem.__nvnText__); if (extraIndex >= 0) { score += EXTRA_MATCH_SCORE; } score += Math.max((0,absol_src_String_stringMatching__WEBPACK_IMPORTED_MODULE_1__.wordsMatch)(queryItem.__words__, item.__words__), (0,absol_src_String_stringMatching__WEBPACK_IMPORTED_MODULE_1__.wordsMatch)(queryItem.__nvnWords__, item.__nvnWords__))/ Math.max(queryItem.__words__.length + 1, 1); return score; } function isItemMustIncluded(queryItem, item) { if (!queryItem) return true; if (item.__nvnText__.indexOf(queryItem.__nvnText__) >= 0) { return true; } var dict1 = queryItem.__nvnWordDict__; var dict2 = item.__nvnWordDict__; for (var i in dict1) { for (var j in dict2) { if (j.indexOf(i) < 0) return false; } } return true; } /*** * * @param {String} query * @param {Array<SelectionItem>} items */ function searchListByText(query, items) { query = (query || '').trim(); if (query.length === 0 || items.length === 0) return items; var queryItem = prepareSearchForItem({ text: query }); var its = items.map(function (item) { if (!item.__text__) prepareSearchForItem(item); return { item: item, score: calcItemMatchScore(queryItem, item), mustIncluded: isItemMustIncluded(queryItem, item) } }); its.sort(function (a, b) { if (b.score - a.score == 0) { if (b.item.__nvnText__ > a.item.__nvnText__) return -1 return 1; } return b.score - a.score; }); var midValue = (its[0].score + its[its.length - 1].score) / 2; if (midValue === 0) midValue += 0.1; if (midValue < 1) midValue = 1; return its.filter(function (it) { return it.score >= midValue || it.mustIncluded; }).map(function (it) { return it.item; }); } /*** * * @param {String} query * @param {Array<SelectionItem>} items */ function searchTreeListByText(query, items) { query = (query || '').trim(); if (query.length == 0 || items.length == 0) return items; var queryItem = prepareSearchForItem({ text: query }); var gmaxScore = 0; var gminScore = 1000; function makeScoreRecursive(item) { var score = calcItemMatchScore(queryItem, item); var mustIncluded = isItemMustIncluded(queryItem, item); gmaxScore = Math.max(score, gmaxScore); gminScore = Math.min(score, gminScore); var children = (item.items || []).map(function (item) { return makeScoreRecursive(item); }); mustIncluded = mustIncluded || children.some(c => c.mustIncluded); var maxScore = children.reduce(function (ac, cr) { return Math.max(ac, cr.maxScore); }, score); return { score: score, maxScore: maxScore, item: item, children: children, mustIncluded: mustIncluded } } function sortcmp(a, b) { return b.maxScore - a.maxScore; } function filterItems(nodes, medScore) { nodes.sort(sortcmp); return nodes.filter(function (node) { return node.maxScore >= medScore || node.mustIncluded; }).map(function (node) { var res; if (typeof node.item == 'string') { res = node.item; } else { res = Object.assign({}, node.item); res.ref = node.item; if (node.children && node.children.length > 0) { res.items = filterItems(node.children, medScore); if (res.items.length == 0) delete res.items; } } return res; }); } var scoredItems = items.map(makeScoreRecursive); var medianScore = (gminScore + gmaxScore) / 2; items = filterItems(scoredItems, medianScore); return items; } /*** * checked is bestValue * @param {String} query * @param {Array<SelectionItem|{checked:boolean, text: string}>} items */ function searchCheckListByText(query, items) { var res = items.filter(it=> it.checked); var nItems = items.filter(it=> !it.checked); prepareSearchForList(items); nItems = searchListByText(query, nItems); return res.concat(nItems); } /***/ }), /***/ 4877: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "RD": () => (/* binding */ MessageQuote), "ZP": () => (/* binding */ messageinput_MessageInput), "kW": () => (/* binding */ parseMessage) }); // UNUSED EXPORTS: MODE_EDIT, MODE_NEW, prepareIcon // EXTERNAL MODULE: ./node_modules/absol-acomp/css/messageinput.css var messageinput = __webpack_require__(1813); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/EventEmitter.js var EventEmitter = __webpack_require__(863); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiAnims.js var EmojiAnims = __webpack_require__(4670); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiPicker.js var EmojiPicker = __webpack_require__(2948); // EXTERNAL MODULE: ./node_modules/absol/src/Detector/BrowserDetector.js var BrowserDetector = __webpack_require__(9399); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/CMDRunner.js var CMDRunner = __webpack_require__(2243); // EXTERNAL MODULE: ./node_modules/absol/src/Input/keyboard.js var keyboard = __webpack_require__(27); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/tokenizeiput/tiutils.js var tiutils = __webpack_require__(3421); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/messageinput/MessageInputPlugin.js /*** * @typedef MessageInputPluginOption * @property {string} [id] * @property {string|Object|AElement} icon * @property {function(_thisAdapter: MessageInputPlugin, _:Dom._, Dom.$):AElement} createContent * @property {function(_thisAdapter:MessageInputPlugin):void} onPressTrigger * @property {"left"|"right"} popupAlign * @property {boolean=} alwaysVisible */ /*** * * @param {MessageInput} inputElt * @param {MessageInputPluginOption} opt * @constructor */ function MessageInputPlugin(inputElt, opt) { this.opt = opt || {}; this.inputElt = inputElt; this.icon = opt.icon; this.id = opt.id || (0,stringGenerate.randomIdent)(16); this.alwaysVisible = !!opt.alwaysVisible; this.$icon = null; this.$triggerBtn = null; this.$content = null; this.$popup = null; if (opt.createContent) this.createContent = opt.createContent; if (opt.onPressTrigger) this.onPressTrigger = opt.onPressTrigger; this.autoClose = true; if ('autoClose' in opt) { this.autoClose = !!opt.autoClose; } this.popupAlign = opt.popupAlign || 'left'; this.ev_pressTrigger = this.ev_pressTrigger.bind(this); this.ev_pressOut = this.ev_pressOut.bind(this); } MessageInputPlugin.prototype.isMessagePlugin = true; MessageInputPlugin.prototype.ev_pressTrigger = function (event) { var value = this.inputElt.$preInput.value; this._lastInputSelectPosion = this.inputElt.$preInput.getSelectPosition() || { start: value.length, end: value.length }; if (this.onPressTrigger) { this.onPressTrigger(this); } else { if (this.isPopupOpened()) { this.closePopup(); } else { this.openPopup(); } } }; MessageInputPlugin.prototype.insertText = function (itext) { if (!this._lastInputSelectPosion) { throw new Error('Invalid call'); } var text = this.inputElt.$preInput.value; var newText = text.substr(0, this._lastInputSelectPosion.start) + itext + text.substr(this._lastInputSelectPosion.end); var selected = this._lastInputSelectPosion; var newOffset = selected.start + itext.length; this.inputElt.$preInput.focus(); this.inputElt.$preInput.applyData(newText, newOffset); this.inputElt.$preInput.commitChange(newText, newOffset); this.inputElt.notifySizeChange(); this.inputElt.$preInput.focus(); }; MessageInputPlugin.prototype.appendText = function (itext) { if (!this._lastInputSelectPosion) { throw new Error('Invalid call'); } var text = this.inputElt.$preInput.value; var newText = text + itext; var newOffset = newText.length; this.inputElt.$preInput.focus(); this.inputElt.$preInput.applyData(newText, newOffset); this.inputElt.$preInput.commitChange(newText, newOffset); this.inputElt.notifySizeChange(); this.inputElt.$preInput.focus(); } MessageInputPlugin.prototype.replaceText = function (itext) { if (!this._lastInputSelectPosion) { throw new Error('Invalid call'); } var newText = itext; var newOffset = newText.length; this.inputElt.$preInput.focus(); this.inputElt.$preInput.applyData(newText, newOffset); this.inputElt.$preInput.commitChange(newText, newOffset); this.inputElt.notifySizeChange(); this.inputElt.$preInput.focus(); } MessageInputPlugin.prototype.ev_pressOut = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this.getTriggerButton(), event)) return; if (EventEmitter/* default.hitElement */.ZP.hitElement(this.getPopup(), event)) return; if (!this.autoClose) return; this.closePopup(); }; MessageInputPlugin.prototype.getIconElt = function () { if (!this.$icon) this.$icon = (0,ACore._)(this.icon); return this.$icon; }; MessageInputPlugin.prototype.getTriggerButton = function () { if (!this.$triggerBtn) { this.$triggerBtn = (0,ACore._)({ tag: 'button', class: ['as-message-input-plugin-btn', 'as-message-input-plugin-' + this.id], child: this.getIconElt(), on: { click: this.ev_pressTrigger } }); if (this.alwaysVisible) { this.$triggerBtn.addClass('as-always-visible'); } } return this.$triggerBtn; }; MessageInputPlugin.prototype.createContent = function (_thisAdapter, _, $) { return _({ tag: 'div' }); }; /*** * * @type {null|function(_thisAdapter:MessageInputPlugin):void} */ MessageInputPlugin.prototype.onPressTrigger = null; MessageInputPlugin.prototype.getContent = function () { if (!this.$content) this.$content = this.createContent(this.inputElt, ACore._, ACore.$); return this.$content; }; MessageInputPlugin.prototype.getPopup = function () { if (!this.$popup) { this.$popup = (0,ACore._)({ class: ['as-message-input-external-tools-popup', 'as-align-' + this.popupAlign], child: this.getContent() }); } return this.$popup; }; MessageInputPlugin.prototype.openPopup = function () { if (this.isPopupOpened()) return; this.inputElt.appendChild(this.getPopup()); document.body.addEventListener('click', this.ev_pressOut); this.onOpen(); if (this.opt.onOpen) { this.opt.onOpen.call(this, this.inputElt, ACore._, ACore.$); } }; MessageInputPlugin.prototype.closePopup = function () { if (!this.isPopupOpened()) return; if (this.opt.onClose) { this.opt.onClose.call(this, this.inputElt, ACore._, ACore.$); } this.onClose(); this.getPopup().remove(); document.body.removeEventListener('click', this.ev_pressOut); }; MessageInputPlugin.prototype.isPopupOpened = function () { return !!this.getPopup().parentElement; }; MessageInputPlugin.prototype.onOpen = noop/* default */.Z; MessageInputPlugin.prototype.onClose = noop/* default */.Z; Object.defineProperty(MessageInputPlugin.prototype, 'contentElt', { get: function () { return this.getContent(); } }); /* harmony default export */ const messageinput_MessageInputPlugin = (MessageInputPlugin); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/messageinput/MIEmojiPlugin.js /**** * @extends MessageInputPlugin * @constructor */ function MIEmojiPlugin(inputElt) { messageinput_MessageInputPlugin.call(this, inputElt, { id: 'emoji_picker', icon: 'span.mdi.mdi-emoticon-happy-outline' }); for (var key in this) { if (key.startsWith('ev_')) { this[key] = this[key].bind(this); } } } OOP/* default.mixClass */.ZP.mixClass(MIEmojiPlugin, messageinput_MessageInputPlugin); MIEmojiPlugin.prototype.createContent = function () { return (0,ACore._)('emojipicker')//.addTo(this.$emojiPickerCtn) .on('pick', this.ev_PickEmoji); }; MIEmojiPlugin.prototype.ev_PickEmoji = function (event) { var text = this.inputElt.$preInput.value; var selected = this._lastInputSelectPosion; var newText = text.substr(0, selected.start) + event.key + text.substr(selected.end); var newOffset = selected.start + event.key.length; this._lastInputSelectPosion = { start: newOffset, end: newOffset }; this.inputElt.$preInput.focus(); this.inputElt.$preInput.applyData(newText, newOffset); this.inputElt.$preInput.commitChange(newText, newOffset); this.inputElt.notifySizeChange(); this.inputElt.$preInput.focus(); }; MIEmojiPlugin.prototype.onOpen = function (){ var value = this.inputElt.$preInput.value; this._lastInputSelectPosion = this.inputElt.$preInput.getSelectPosition() || { start: value.length, end: value.length }; this.inputElt.$preInput.focus(); } /* harmony default export */ const messageinput_MIEmojiPlugin = (MIEmojiPlugin); // EXTERNAL MODULE: ./node_modules/absol-acomp/assets/exticons/catalog.json var catalog = __webpack_require__(2398); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/messageinput/MessageInput.js var _ = ACore/* default._ */.Z._; var $ = ACore/* default.$ */.Z.$; var $$ = ACore/* default.$$ */.Z.$$; /*** * * @typedef {{text:string, desc: string, img?:string, file?:string}|string} MessageInputQuote */ var MODE_NEW = 0; var MODE_EDIT = 1; var isMobile = BrowserDetector/* default.isMobile */.Z.isMobile; /*** * @extends AElement * @constructor */ function MessageInput() { this._cmdRunner = new CMDRunner/* default */.Z(this); this._keyMaps = {}; this._plugins = []; this._mode = MODE_NEW;//edit this._editingText = ""; prepareIcon(); /** * @type {import('../PreInput').default} */ this.$preInput = $('.as-message-input-pre', this); this.$preInput.on('change', this.eventHandler.preInputChange) .on('keyup', this.eventHandler.preInputKeyUp) .on('keydown', this.eventHandler.preInputKeyDown) .on('pasteimg', this.eventHandler.preInputPasteImg) .on('focus', this.eventHandler.preInputFocus) .on('blur', this.eventHandler.preInputBlur); // //every can make size change this._imageFiles = []; this._files = []; this._latBound = {}; this.$quote = $('messagequote.as-message-input-quote', this) .on('pressremove', this.eventHandler.clickQuoteRemoveBtn); this.$left = $('.as-message-input-left', this); this.$right = $('.as-message-input-right', this); this.$attachmentCtn = $('.as-message-input-attachment-ctn', this); this.$fileBtn = $('.as-message-input-plugin-file', this) .on('click', this.openFileDialog.bind(this)); this.$attachmentAddBtn = $('.as-message-input-attachment-add-btn', this) .on('click', this.openFileDialog.bind(this)); this.$sendBtn = $('.as-message-input-plugin-send', this) .on('click', this.notifySend.bind(this)); this.$cancelBtn = $('.as-message-input-plugin-cancel', this) .on('click', this.notifyCancel.bind(this)); this.$attachhook = _('attachhook').addTo(this) .on('attached', this.notifySizeChange.bind(this)) .on('attached', this._updateSize.bind(this)); this.on('drop', this.eventHandler.drop) .on('dragover', this.eventHandler.dragover); OOP/* default.drillProperty */.ZP.drillProperty(this, this.$preInput, 'tagList'); this.autoSend = false; /*** * * @type {MessageInputQuote|null} */ this.quote = null; this.addPlugin(new messageinput_MIEmojiPlugin(this)); } MessageInput.MODE_EDIT = MODE_EDIT; MessageInput.MODE_NEW = MODE_NEW; MessageInput.iconAssetRoot = (function () { if (location.hostname.match(/^.*(\.?absol\.cf|absol\.ddns\.net)$/) || location.hostname === 'localhost') return 'https://absol.cf/exticons/vivid'; return '/vivid_exticons'; })(); MessageInput.tag = 'MessageInput'.toLowerCase(); MessageInput.render = function (data) { data = data || {}; data.iconAssetRoot = data.iconAssetRoot || MessageInput.iconAssetRoot; return _({ attr: { 'data-icon-asset-root': MessageInput.iconAssetRoot }, class: ['as-message-input'].concat(data.v2 ? ['as-v2'] : []), extendEvent: ['sendtext', 'sendimage', 'sendfile', 'sendquote', 'cancel', 'change', 'sizechange', 'send', 'useraddfile'], child: [ { class: 'as-message-input-right', child: [ { tag: 'button', class: ['as-message-input-plugin-btn', 'as-message-input-plugin-file'], child: 'span.mdi.mdi-attachment.mdi-rotate-90' }, { tag: 'button', class: ['as-message-input-plugin-btn', 'as-message-input-plugin-send'], child: 'span.mdi.mdi-send' }, { tag: 'button', class: ['as-message-input-plugin-btn', 'as-message-input-plugin-cancel'], child: 'span.mdi.mdi-close' } ] }, { class: 'as-message-input-pre-ctn', child: [ 'messagequote.as-message-input-quote.as-removable.as-shorten-text', { class: 'as-message-input-left' }, { class: ['as-message-input-attachment-ctn', 'as-bscroller'], child: [{ tag: 'button', class: 'as-message-input-attachment-add-btn', child: [ 'span.mdi.mdi-arrow-down-bold.as-message-input-attachment-add-btn-drop', { tag: 'span', class: 'as-message-input-attachment-add-btn-plus', child: { text: "+" } } ] }] }, (data.v2 ? 'tokenizehyperinput' : 'preinput') + '.as-message-input-pre.absol-bscroller' ] } ] }); }; MessageInput.prototype.notifyChange = function () { this.emit('change', { name: 'change', target: this }, this); if (this.autoSend) { if (this.files.length > 0 || this.images.length > 0) this.notifySend(); } }; MessageInput.prototype.notifySend = function () { var eventData = { imageRemovePrevented: false, fileRemovePrevented: false, textRemovePrevented: false, quoteRemovePrevented: false, target: this, files: this.files, images: this.images, text: this.text }; if (eventData.files.length > 0) { this.emit('sendfile', Object.assign(eventData, { type: 'sendfile', preventDefault: function () { this.fileRemovePrevented = true; } }), this); } if (eventData.images.length > 0) { this.emit('sendimage', Object.assign(eventData, { type: 'sendimage', preventDefault: function () { this.imageRemovePrevented = true; } }), this); } if ((typeof this.quote === "string") || this.quote) { this.emit('sendquote', Object.assign(eventData, { type: 'sendquote', preventDefault: function () { this.quoteRemovePrevented = true; } }), this); } if (this.files.length > 0 || eventData.images.length > 0 || eventData.text || ((typeof this.quote === "string") || this.quote)) { if (eventData.text) this.$preInput.focus(); this.emit('send', Object.assign(eventData, { type: 'send', preventDefault: function () { this.imageRemovePrevented = true; this.fileRemovePrevented = true; this.imageRemovePrevented = true; this.quoteRemovePrevented = true; } }), this); } if (!eventData.fileRemovePrevented) this.files = []; if (!eventData.imageRemovePrevented) this.images = []; if (!eventData.textRemovePrevented) this.text = ''; if (!eventData.quoteRemovePrevented) this.quote = null; }; MessageInput.prototype.notifyCancel = function () { this.emit('cancel', { type: 'cancel', name: 'send', target: this, clearAllContent: this.clearAllContent.bind(this) }, this); }; MessageInput.prototype.clearAllContent = function () { this.text = ''; this.quote = null; this.files = []; this.images = []; }; MessageInput.prototype.focus = function () { var value = this.$preInput.value; var range = this.$preInput.getSelectPosition() || { start: value.length, end: value.length }; this.$preInput.focus(); this.$preInput.applyData(value, range); }; MessageInput.prototype.blur = function () { this.$preInput.blur(); }; MessageInput.prototype._updateAttachmentClass = function () { if (this._imageFiles.length + this._files.length) { this.addClass("as-has-attachment"); } else { this.removeClass("as-has-attachment"); } this._updateSize(); }; MessageInput.prototype._updateSize = function () { var fs = this.getFontSize() || 14; this.addStyle('--right-width', this.$right.getBoundingClientRect().width / fs + 'em'); }; MessageInput.prototype.addImageFiles = function (imageFiles, urls) { var thisMi = this; Array.prototype.forEach.call(imageFiles, function (file, index) { thisMi._imageFiles.push(file); var src; if (urls) { src = urls[index]; } if (!src) { src = URL.createObjectURL(file); } var itemElt = _({ class: ['as-message-input-attach-preview', 'as-image'], attr: { title: file.name }, child: [ { class: 'as-message-input-attach-preview-image', style: { backgroundImage: 'url(' + src + ')' } }, { tag: 'button', class: 'as-message-input-attach-preview-close-btn', child: 'span.mdi.mdi-close', attr: { title: 'remove' }, on: { click: function () { thisMi._imageFiles = thisMi._imageFiles.filter(function (it) { return it !== file; }); itemElt.remove(); thisMi._updateAttachmentClass(); thisMi.notifySizeChange(); thisMi.notifyChange(); } } }, { class: 'as-message-input-attach-preview-info', child: [ { class: 'as-message-input-attach-preview-name', child: { text: file.name } }, { class: 'as-message-input-attach-preview-size', child: { text: (0,utils.fileSize2Text)(file.size) } } ] } ] }).addTo(thisMi.$attachmentCtn); thisMi.$attachmentCtn.addChildBefore(itemElt, thisMi.$attachmentAddBtn); }); this._updateAttachmentClass(); this.notifySizeChange(); }; MessageInput.prototype.addFiles = function (files) { var thisMi = this; Array.prototype.forEach.call(files, function (file, index) { thisMi._files.push(file); MessageInput.iconSupportAsync.then(function (ExtensionIcons) { var src; var ext = file.name.split('.').pop().toLowerCase(); if (ExtensionIcons.indexOf(ext) > 0) { src = MessageInput.iconAssetRoot + '/' + ext + '.svg' } else { src = MessageInput.iconAssetRoot + '/' + 'default' + '.svg' } var itemElt = _({ class: ['as-message-input-attach-preview', 'as-file'], attr: { title: file.name }, child: [ { tag: 'img', class: 'as-message-input-attach-preview-file', props: { src: src } }, { tag: 'button', class: 'as-message-input-attach-preview-close-btn', child: 'span.mdi.mdi-close', attr: { title: 'remove' }, on: { click: function () { thisMi._files = thisMi._files.filter(function (it) { return it !== file; }); itemElt.remove(); thisMi._updateAttachmentClass(); thisMi.notifySizeChange(); thisMi.notifyChange(); } } }, { class: 'as-message-input-attach-preview-info', child: [ { class: 'as-message-input-attach-preview-name', child: { text: file.name } }, { class: 'as-message-input-attach-preview-size', child: { text: (0,utils.fileSize2Text)(file.size) } } ] } ] }); thisMi.$attachmentCtn.addChildBefore(itemElt, thisMi.$attachmentAddBtn); }); }); this._updateAttachmentClass(); thisMi.notifySizeChange(); }; MessageInput.prototype.closeEmoji = function () { if (!this.hasClass('as-message-input-show-emoji')) return; this.removeClass('as-message-input-show-emoji'); this.removeChild(this.$emojiPickerCtn); $(document.body).off('mousedown', this.eventHandler.mousedownOutEmoji); }; MessageInput.prototype.notifyAddFiles = function (files) { var event = { resolvedAsync: Promise.resolve(files), files: files, resolve: function (result) { if (!result) { this.resolvedAsync = Promise.resolve(undefined); } else if (result.then) { this.resolvedAsync = result; } else { this.resolvedAsync = Promise.resolve(result); } } }; this.emit('useraddfile', event); return event.resolvedAsync; } MessageInput.prototype.openFileDialog = function () { var thisMi = this; (0,utils.openFileDialog)({ multiple: true }).then(function (files) { if (!thisMi.autoSend) thisMi.$preInput.focus(); thisMi.notifyAddFiles(files).then(function (files) { if (files && files.length > 0) thisMi.handleAddingFileByType(files); }); }); }; MessageInput.prototype.handleAddingFileByType = function (files) { if (files.length > 0) { var imageFiles = []; var otherFiles = []; var file; for (var i = 0; i < files.length; ++i) { file = files[i]; if (!!file.type && file.type.match && file.type.match(/^image\//)) { imageFiles.push(file); } else { otherFiles.push(file); } } this.addImageFiles(imageFiles); this.addFiles(otherFiles); this.notifyChange(); } }; MessageInput.prototype.notifySizeChange = function () { var bound = this.getBoundingClientRect(); if (this._latBound.width != bound.width || this._latBound.height != bound.height) { this._latBound.width = bound.width; this._latBound.height = bound.height; this.emit('sizechange', { name: 'sizechange', bound: bound, target: this }, this); } }; MessageInput.prototype.addPlugin = function (option) { var plugin; if (option.isMessagePlugin) { plugin = option; } else { plugin = new this.PluginConstructor(this, option); } plugin.idx = this._plugins.length + 1; this._plugins.push(plugin); this._plugins.sort(function (a, b) { var av = (typeof a.opt.order === "number") ? a.opt.order : a.idx * 1000; var bv = (typeof b.opt.order === "number") ? b.opt.order : b.idx * 1000; return av - bv; }); var plugins = this._plugins.slice(); plugins.forEach(pl => pl.getTriggerButton().remove()); this.$left.addChild(plugins.shift().getTriggerButton()); while (plugins.length > 0) { this.$right.addChildBefore(plugins.shift().getTriggerButton(), this.$right.firstChild); } return plugin; }; /*** * * @param {{name?:string, exec:function(_this:MessageInput):void, keyBiding?:string}} option */ MessageInput.prototype.addCommand = function (option) { option.name = option.name || (0,stringGenerate.randomIdent)(20); this._cmdRunner.add(option.name, option.exec); if (option.keyBiding && option.keyBiding.trim) { var keyBindingIdent = (0,keyboard/* normalizeKeyBindingIdent */.DB)(option.keyBiding); this._keyMaps[keyBindingIdent] = option.name; } }; MessageInput.prototype.exeCmd = function (name) { var args = Array.prototype.slice.call(arguments); args[0] = this; args.unshift(name); this._cmdRunner.invoke.apply(this._cmdRunner, args); }; MessageInput.prototype._updateQuote = function () { this.$quote.data = this._quote; if (this._quote) this.addClass('as-has-quote'); else this.removeClass('as-has-quote'); this._updateSize(); this.notifySizeChange(); }; /** * @type {MessageInput} */ MessageInput.eventHandler = {}; MessageInput.eventHandler.preInputChange = function (event) { var text = this.$preInput.value; if (text.length > 0) { this.addClass('as-has-text'); } else { this.removeClass('as-has-text'); } if (text === this._editingText) { this.removeClass('as-text-changed'); } else { this.addClass('as-text-changed'); } this._updateSize(); this.notifySizeChange(); this.notifyChange(); }; MessageInput.eventHandler.preInputKeyDown = function (event) { if (!(event.shiftKey || event.ctrlKey || event.altKey) && event.key === 'Enter') { this.notifySend(); event.preventDefault(); } else if ((event.shiftKey || event.ctrlKey || event.altKey) && event.key === 'Enter') { event.preventDefault(); var text = this.$preInput.value; var selectedPos = this.$preInput.getSelectPosition(); var newText = text.substr(0, selectedPos.start) + '\n' + text.substr(selectedPos.end); this.$preInput.applyData(newText, selectedPos.start + 1); this.notifySizeChange(); this.$preInput.commitChange(newText, selectedPos.start + 1); } else if (event.key === "Escape" && this._mode === MODE_EDIT) { this.notifyCancel(); event.preventDefault(); } var keyBindingIdent = (0,keyboard/* keyboardEventToKeyBindingIdent */.Ej)(event); if (this._keyMaps[keyBindingIdent]) { event.preventDefault(); this.exeCmd(this._keyMaps[keyBindingIdent]); } setTimeout(this.notifySizeChange.bind(this), 1); }; MessageInput.eventHandler.preInputKeyUp = function (event) { var value = this.$preInput.value; this._lastInputSelectPosion = this.$preInput.getSelectPosition() || { start: value.length, end: value.length }; this.notifySizeChange(); }; MessageInput.eventHandler.preInputPasteImg = function (event) { if (this._mode == 'edit') return; var files = Array.prototype.slice.call(event.imageFiles); var urls = event.urls && Array.prototype.slice.call(event.urls); this.notifyAddFiles(files).then(function (newFiles) { if (!newFiles || newFiles.length === 0) return; var newUrls = urls && newFiles.map(function (file) { return urls[files.indexOf(file)]; }); this.addImageFiles(newFiles, newUrls); this.notifyChange(); }.bind(this)); }; MessageInput.eventHandler.preInputFocus = function () { this.addClass('as-focus'); }; MessageInput.eventHandler.preInputBlur = function () { this.removeClass('as-focus'); }; MessageInput.eventHandler.clickEmojiBtn = function () { this.toggleEmoji(); }; MessageInput.eventHandler.mousedownOutEmoji = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this.$emojiPicker, event) || EventEmitter/* default.hitElement */.ZP.hitElement(this.$emojiBtn, event)) return; this.closeEmoji(); }; MessageInput.eventHandler.pickEmoji = function (event) { var text = this.$preInput.value; var newText = text.substr(0, this._lastInputSelectPosion.start) + event.key + text.substr(this._lastInputSelectPosion.end); var selected = this._lastInputSelectPosion; var newOffset = selected.start + event.key.length; this._lastInputSelectPosion = { start: newOffset, end: newOffset }; this.$preInput.focus(); this.$preInput.applyData(newText, newOffset); this.$preInput.commitChange(newText, newOffset); this.notifySizeChange(); this.$preInput.focus();//older firefox version will be lost focus // this.notifyChange();//not need }; MessageInput.eventHandler.dragover = function (event) { event.preventDefault(); this.addClass('as-drag-hover'); this.notifySizeChange(); if (this._hoverTimeout > 0) clearTimeout(this._hoverTimeout); var thisMi = this; this._hoverTimeout = setTimeout(function () { thisMi._hoverTimeout = -1; thisMi.removeClass('as-drag-hover'); thisMi.notifySizeChange(); }, 200); //todo: this._updateSize(); }; MessageInput.eventHandler.drop = function (event) { event.preventDefault(); var files = []; var file; if (event.dataTransfer.items) { for (var i = 0; i < event.dataTransfer.items.length; i++) { if (event.dataTransfer.items[i].kind === 'file') { file = event.dataTransfer.items[i].getAsFile(); if (!file.type && file.size % 4096 == 0) { //todo: folder } else { files.push(file); } } } } else { for (var i = 0; i < event.dataTransfer.files.length; i++) { file = event.dataTransfer.files[i]; if (!file.type && file.size % 4096 == 0) { } else { files.push(file); } } } this.notifyAddFiles(files).then(function (files) { this.handleAddingFileByType(files); }.bind(this)); }; MessageInput.eventHandler.clickQuoteRemoveBtn = function () { this.quote = null; this.notifyChange(); } MessageInput.property = {}; MessageInput.property.files = { set: function (value) { $$('.as-file', this.$attachmentCtn).forEach(function (elt) { elt.remove(); }); value = value || []; this._files = []; this.addFiles(value); }, get: function () { return this._files; } }; MessageInput.property.images = { set: function (value) { $$('.as-image', this.$attachmentCtn).forEach(function (elt) { elt.remove(); }); value = value || []; this._imageFiles = []; this.addImageFiles(value); }, get: function () { return this._imageFiles; } }; MessageInput.property.text = { set: function (text) { this.$preInput.value = '' + text; if (text.length > 0) { this.addClass('as-has-text'); } else { this.removeClass('as-has-text'); } if (this._mode === MODE_EDIT) { this._editingText = text; } this.removeClass('as-text-changed'); this._updateSize(); }, get: function () { return this.$preInput.value; } }; /** * @type {MessageInput} */ MessageInput.property.mode = { set: function (value) { value = value || MODE_NEW; if (value === MODE_EDIT || (value.toLowerCase && value.toLowerCase() === 'edit')) { this.addClass('as-mode-edit'); value = MODE_EDIT; this._editingText = this.$preInput.value; } else { value = MODE_NEW; this._editingText = ''; this.removeClass('as-mode-edit'); } this.removeClass('as-text-changed'); this._mode = value; this._updateSize(); }, get: function () { return this._mode === MODE_EDIT ? 'edit' : 'new'; } }; MessageInput.property.autoSend = { set: function (value) { if (value) { this.addClass('as-auto-send'); } else { this.removeClass('as-auto-send'); } }, get: function () { return this.hasClass('as-auto-send'); } }; MessageInput.property.quote = { set: function (quote) { this._quote = quote; this._updateQuote(); }, get: function () { return this._quote; } }; MessageInput.property.tagMap = { set: function (value) { this.$preInput.tagMap = value || {}; this.$quote.tagMap = value || {}; }, get: function () { return this.$preInput.tagMap; } } ACore/* default.install */.Z.install(MessageInput); /* harmony default export */ const messageinput_MessageInput = (MessageInput); var urlRex = /^(firefox|opera|chrome|https|http|wss|ws):\/\/[^\s]+$/; /*** * * @param {string}text * @param {{emojiAssetRoot?:string, staticSize?:number, animSize?:number, tagMap?:{}, lengthLimit?:number, inline?:boolean}=} data * @returns {Array} */ function parseMessage(text, data) { data = data || {}; data.emojiAssetRoot = data.emojiAssetRoot || EmojiPicker/* default.assetRoot */.Z.assetRoot; data.staticSize = data.staticSize || 20; data.animSize = data.animSize || 60; var tagMap = data.tagMap || {}; var tokens = (0,tiutils/* tokenizeMessageText */.Dx)(text).reduce((ac, token) => { if (token.type !== 'TEXT') { ac.push(token); return ac; } var urls = token.value.match(/(firefox|opera|chrome|https|http|wss|ws):\/\/[^\s]+/g); var splitter = Math.random() + ''; var normals = token.value.replace(/(firefox|opera|chrome|https|http|wss|ws):\/\/[^\s]+/, splitter).split(splitter); for (var i = 0; i < normals.length; ++i) { if (i > 0) { ac.push({ type: 'URL', value: urls[i - 1] }); } ac.push({ type: 'TEXT', value: normals[i] }); } return ac; }, []); if (data.lengthLimit > 0) { tokens = tokens.reduce((ac, token) => { if (ac.l >= data.lengthLimit) { return ac; } switch (token.type) { case 'TAG': ac.l += ('@' + (tagMap[token.value] ? tagMap[token.value] : '[id:' + token.value + ']')).length; break; case 'EMOJI': ac.l += 1; break; case 'NEW_LINE': ac.l += 1; break; default: ac.l += token.value.length; } if (ac.l > data.lengthLimit) { if (token.type === 'TEXT') { token.value = token.value.substring(0, Math.max(0, token.value.length - (ac.l - data.lengthLimit) - 3)) + '...'; ac.tokens.push(token); } } else { ac.tokens.push(token); } return ac; }, { l: 0, tokens: [] }).tokens; } var res = tokens.reduce((ac, token) => { switch (token.type) { case 'TAG': ac.push({ tag: 'span', class: 'as-tag-token', child: { text: '@' + (tagMap[token.value] ? tagMap[token.value] : '[id:' + token.value + ']') } }); break; case 'EMOJI': ac.push({ tag: 'span', class: 'as-emoji-text', child: { text: token.value } }); ac.push({ tag: 'img', class: 'as-emoji', props: { src: data.emojiAssetRoot + '/static/x' + data.staticSize + '/' + EmojiAnims/* EmojiAnimByIdent */.M[token.value][1] } }) break; case 'NEW_LINE': ac.push({ tag: 'br' }); break; case 'URL': ac.push({ tag: 'a', class: 'as-protocal-' + token.value.split(':').shift(), child: { text: token.value }, props: { href: token.value, target: '_blank' } }) break; case 'TEXT': default: ac.push({ tag: 'span', child: { text: token.value } }) break; } return ac; }, []); if (!data.inline && res.length === 2 && res[1].class === 'as-emoji') { res[1].tag = 'iconsprite'; res[1].props.fps = 30; res[1].props.src = res[1].props.src.replace('/static/x' + data.staticSize, '/anim/x' + data.animSize); } return res; } MessageInput.parseMessage = parseMessage; function prepareIcon() { if (!MessageInput.iconSupportAsync) { MessageInput.iconSupportAsync = Promise.resolve(catalog) } return MessageInput.iconSupportAsync; } function MessageQuote() { prepareIcon(); this._tagMap = {}; /*** * * @type {null|MessageInputQuote} * @private */ this._data = null; this.$img = $('.as-message-quote-img', this); this.$text = $('.as-message-quote-text', this); this.$desc = $('.as-message-quote-desc', this); this.$removeBtn = $('.as-message-quote-remove-btn', this) .on('click', this.eventHandler.clickRemoveBtn); Object.defineProperty(this, '$text', { set: function () { console.trace(); }, get: function () { return $('.as-message-quote-text', this); } }) } MessageQuote.tag = 'MessageQuote'.toLowerCase(); MessageQuote.render = function () { return _({ extendEvent: 'pressremove', class: 'as-message-quote-box', child: [ { class: 'as-message-quote-img' }, { class: 'as-message-quote-sym', child: 'span.mdi.mdi-format-quote-open-outline' }, { class: 'as-message-quote-content', child: [ { class: 'as-message-quote-text', child: { text: '' } }, { class: 'as-message-quote-desc', child: { text: '' } } ] }, { tag: 'button', class: 'as-message-quote-remove-btn', child: 'span.mdi.mdi-close' } ] }); }; MessageQuote.property = {}; MessageQuote.eventHandler = {}; MessageQuote.property.removable = { set: function (val) { if (val) { this.addClass('as-removable'); } else { this.removeClass('as-removable'); } }, get: function () { return this.hasClass('as-removable'); } }; MessageQuote.property.shortenText = { set: function (val) { if (val) { this.addClass('as-shorten-text'); } else { this.removeClass('as-shorten-text'); } }, get: function () { return this.hasClass('as-shorten-text'); } }; MessageQuote.property.data = { set: function (quote) { this._data = quote; var text, desc; var file, img; if (typeof quote === "string") { text = quote; desc = '' } else if (quote && (typeof quote === "object")) { text = quote.text; desc = quote.desc; file = quote.file; img = quote.img; } if (text === undefined) { this.$text.clearChild(); this.$desc.firstChild.data = ''; this.removeClass('as-has-file'); this.removeClass('as-has-img'); } else { if (file) { file = file.toLowerCase().split('.').pop(); MessageInput.iconSupportAsync.then(function (iconSupport) { if (iconSupport.indexOf(file) < 0) file = 'default'; this.$img.addStyle('background-image', 'url(' + MessageInput.iconAssetRoot + '/' + file + '.svg)'); }.bind(this)); this.addClass('as-has-file'); } else this.removeClass('as-has-file'); if (img) { this.$img.addStyle('background-image', 'url(' + img + ')'); this.addClass('as-has-img'); } else this.removeClass('as-has-img'); if (this.shortenText) text = text.split(/\r?\n/).shift(); var parsedText = parseMessage(text, { tagMap: this.tagMap }); var textEltChain = parsedText.map(function (c) { return _(c); }); this.$text.clearChild().addChild(textEltChain); this.$desc.firstChild.data = desc; } }, get: function () { return this._data; } }; MessageQuote.property.tagMap = { set: function (value) { this._tagMap = value || {}; this.data = this['data']; }, get: function () { return this._tagMap; } }; MessageQuote.eventHandler.clickRemoveBtn = function () { this.emit('pressremove', { target: this, type: 'pressclose' }, this); }; ACore/* default.install */.Z.install(MessageQuote); MessageInput.prototype.PluginConstructor = messageinput_MessageInputPlugin; /***/ }), /***/ 9277: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _css_mobileapp_css__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8789); /* harmony import */ var _css_mobileapp_css__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_css_mobileapp_css__WEBPACK_IMPORTED_MODULE_0__); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _QuickMenu__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1274); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1477); /* harmony import */ var absol_src_HTML5_DynamicCSS__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(488); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(863); /** * @exatends AElement * @constructor */ function MHeaderBar() { this._title = null; this._titleDesc = null; this._actionIcon = null; this._commands = []; this._quickmenuHolder = null; this._quickmenu = null; this.$right = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$)('.am-header-bar-right', this); this.$leftBtn = null; this.$titleCtn = null; this.$title = null; this.$titleDesc = null; this.$notificationActionBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$)(".as-header-bar-notification-action", this).on('click', (event) => { MHeaderBar.emit('clicknotification', { type: 'clicknotification', target: this }, this); }); this.$commands = []; } MHeaderBar.tag = 'MHeaderBar'.toLowerCase(); MHeaderBar.render = function () { return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ extendEvent: ['action', 'command'], class: 'am-header-bar', child: [ { class: 'am-header-bar-right', child: [ { tag: 'button', class: ['am-header-bar-command', 'as-header-bar-notification-action'], child: [ 'span.mdi.mdi-bell', '.as-header-bar-notification-action-count', ] } ] } ] }); }; MHeaderBar.prototype.notifyAction = function () { this.emit('action', { type: 'action', target: this }, this); }; MHeaderBar.prototype.notifyCommand = function (commandItem) { this.emit('command', { type: 'command', target: this, commandName: commandItem.name, commandItem }, this); }; MHeaderBar.prototype.showTitle = function (flag) { if (!this.$titleCtn && flag) { this.$titleCtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ class: 'am-header-bar-title-ctn', child: [ { class: 'am-header-bar-no-size-wrapper', child: { class: 'am-header-bar-title-wrapper', child: [ { class: 'am-header-bar-title', }, { class: 'am-header-bar-title-desc' } ] } } ] }); this.$title = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$)('.am-header-bar-title', this.$titleCtn); this.$titleDesc = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__.$)('.am-header-bar-title-desc', this.$titleCtn); } if (flag) { this.insertBefore(this.$titleCtn, this.$right); } else { if (this.$titleCtn) this.$titleCtn.remove(); } }; MHeaderBar.prototype.showActionBtn = function (flag) { if (!this.$leftBtn && flag) { this.$leftBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ tag: 'button', class: 'am-header-bar-left-btn', child: 'span.mdi.mdi-chevron-left', on: { click: this.notifyAction.bind(this) } }); } if (flag) { this.insertBefore(this.$leftBtn, this.firstChild); } else { if (this.$leftBtn) this.$leftBtn.remove(); } }; MHeaderBar.prototype.showQuickMenu = function (flag) { if (!this.$quickmenuBtn && flag) { this.$quickmenuBtn = (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ tag: 'button', class: ['am-header-bar-action', 'am-header-bar-quickmenu-btn'], child: { class: 'am-header-bar-quickmenu-btn-circle', child: ['span.mdi.mdi-dots-horizontal-circle-outline', 'span.mdi.mdi-dots-horizontal-circle'] }, }); } if (flag) { this.$right.addChildBefore(this.$quickmenuBtn, this.$notificationActionBtn); } else { if (this.$quickmenuBtn) this.$quickmenuBtn.remove(); } }; MHeaderBar.prototype._makeCommandBtn = function (item) { return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ tag: 'button', class: 'am-header-bar-command', child: item.icon || [], on: { click: this.notifyCommand.bind(this, item) } }); }; MHeaderBar.property = {}; /** * @type {MHeaderBar} */ MHeaderBar.property.quickmenu = { set: function (value) { if (this._quickmenuHolder) { this._quickmenuHolder.remove(); this._quickmenu = null; } if (value) { this.showQuickMenu(true); var button = this.$quickmenuBtn; var onClose = value.onClose; var onOpen = value.onOpen; value.onOpen = function () { button.addClass('am-status-active'); onOpen && onOpen.apply(this, arguments); }; value.onClose = function () { button.removeClass('am-status-active'); onClose && onClose.apply(this, arguments); }; if (!value.getAnchor) { value.getAnchor = function () { return [2]; } } if (!value.getMenuProps && value.props) { value.getMenuProps = function () { var res = Object.assign({}, value.props); if (typeof res.items === "function") { res.items = res.items(); } return res; } } this._quickmenuHolder = _QuickMenu__WEBPACK_IMPORTED_MODULE_2__/* ["default"].toggleWhenClick */ .Z.toggleWhenClick(this.$quickmenuBtn, value); } else { this.showQuickMenu(false); value = null; } this._quickmenu = value; }, get: function () { return this._quickmenu; } }; /** * @type {MHeaderBar} */ MHeaderBar.property.title = { set: function (value) { if (value) { this.showTitle(true); if (typeof value === 'string') { this.$title.innerHTML = value; } else { this.$title.clearChild().addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)(value)); } } else { this.showTitle(false); value = null; } this._title = value; }, get: function () { return this._title; } }; /** * @type {MHeaderBar} */ MHeaderBar.property.titleDesc = { set: function (value) { if (value) { value = value + ''; this.showTitle(true); this.$titleDesc.clearChild().addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ text: value })); } else { this.showTitle(false); if (this.$titleDesc) this.$titleDesc.clearChild(); value = null; } this._titleDesc = value; }, get: function () { return this._titleDesc; } }; /** * @type {MHeaderBar} */ MHeaderBar.property.actionIcon = { set: function (value) { if (value) { this.showActionBtn(true); this.$leftBtn.clearChild() .addChild((0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)(value)); } else { this.showActionBtn(false); value = null; } this._actionIcon = value; }, get: function () { return this._actionIcon; } }; /** * @type {MHeaderBar} */ MHeaderBar.property.commands = { set: function (value) { this.$commands.forEach(function (e) { e.selftRemove(); }); this.$commands = []; var commandBtn; var i; if (value) { var firstChild = this.$right.firstChild; if (firstChild) { for (i = 0; i < value.length; ++i) { commandBtn = this._makeCommandBtn(value[i]); this.$right.addChildBefore(commandBtn, firstChild) } } else { for (i = 0; i < value.length; ++i) { commandBtn = this._makeCommandBtn(value[i]); this.$right.addChild(commandBtn); } } } else { this._commands = []; } this._commands = value; }, get: function () { return this._commands; } }; _ACore__WEBPACK_IMPORTED_MODULE_1__/* ["default"].install */ .Z.install(MHeaderBar); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (MHeaderBar); var notyEmitter = new absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .ZP(); MHeaderBar.on = notyEmitter.on.bind(notyEmitter); MHeaderBar.once = notyEmitter.once.bind(notyEmitter); MHeaderBar.off = notyEmitter.off.bind(notyEmitter); MHeaderBar.emit = notyEmitter.emit.bind(notyEmitter); var notificationCount = 0; /** * * @type {null|DynamicCSS} */ var ncCSS = null; function updateNotificationCountText() { if (!ncCSS) ncCSS = new absol_src_HTML5_DynamicCSS__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z(); console.log("notificationCount", notificationCount); ncCSS.setRule("button .as-header-bar-notification-action-count::before", { display: notificationCount > 0 ? 'block' : 'none', content: `"${notificationCount > 9 ? "+9" : notificationCount}"`, }).commit(); } Object.defineProperty(MHeaderBar, 'notificationCount', { set: function (value) { value = Math.round(value); if (!(0,_utils__WEBPACK_IMPORTED_MODULE_3__.isNaturalNumber)(value)) value = 0; notificationCount = value; updateNotificationCountText(); }, get: function () { return notificationCount; } }); /***/ }), /***/ 1875: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "U": () => (/* binding */ EMPTY_2_SPACES), /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _EmojiAnims__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4670); /* harmony import */ var absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6628); /* harmony import */ var _EmojiPicker__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(2948); /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1477); /* harmony import */ var _tiutils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(3421); var EMPTY_2_SPACES = String.fromCharCode(0x2003); var emojiCSSLoaded = false; function loadEmojiCSS(){ if (emojiCSSLoaded) return; emojiCSSLoaded = true; absol_src_HTML5_Dom__WEBPACK_IMPORTED_MODULE_1__/* ["default"].documentReady.then */ .ZP.documentReady.then(() => { var styleSheet = {}; for (var name in _EmojiAnims__WEBPACK_IMPORTED_MODULE_0__/* .EmojiAnimByIdent */ .M) { styleSheet['.as-emoji-token[data-text="' + name + '"]'] = { 'background-image': 'url(' + _EmojiPicker__WEBPACK_IMPORTED_MODULE_2__/* ["default"].assetRoot */ .Z.assetRoot + '/static/x20/' + _EmojiAnims__WEBPACK_IMPORTED_MODULE_0__/* .EmojiAnimByIdent */ .M[name][1] + ')' } } (0,_utils__WEBPACK_IMPORTED_MODULE_3__.buildCss)(styleSheet) }); } /*** * * @param {TokenizeHyperInput} elt * @constructor */ function TITextController(elt) { loadEmojiCSS(); this.elt = elt; } TITextController.prototype.setText = function (text) { this.elt.clearChild(); this.elt.addChild((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .text2ContentElements */ .fw)(text, { tagMap: this.elt.tagMap })); this.elt.addChild(this.elt.$br); }; TITextController.prototype.getText = function () { var nodes = Array.prototype.slice.call(this.elt.childNodes); if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isNewLine */ .K0)(nodes[nodes.length - 1])) { nodes.pop(); } return nodes.map(node => { if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(node)) { return node.data; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isToken */ .hD)(node)) { return node.getAttribute('data-text') || ''; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isNewLine */ .K0)(node)) return '\n'; }).join(''); }; /*** * * @param {Range=} range default: previous selected range */ TITextController.prototype.getTextByRange = function (range) { range = range || this.elt.selectionCtrl.prevRange; if (!range) return this.getText(); var nodes = Array.prototype.slice.call(this.elt.childNodes); if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isNewLine */ .K0)(nodes[nodes.length - 1])) nodes.pop(); var startCtn = range.startContainer; var startOffset = range.startOffset; var endCtn = range.endContainer; var endOffset = range.endOffset; if (startCtn === this.elt) { startCtn = this.elt.childNodes[startOffset - 1]; startOffset = 0; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isTokenText */ .tk)(startCtn)) { startCtn = startCtn.parentElement; } if (endCtn === this.elt) { endCtn = this.elt.childNodes[endOffset]; endOffset = 0; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isTokenText */ .tk)(endCtn)) { endCtn = endCtn.parentElement; } if (startCtn === endCtn) { if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isToken */ .hD)(startCtn)) { return startCtn.getAttribute('data-text'); } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(startCtn)) { return startCtn.data.substring(startOffset, endOffset); } return ''; } var res = ''; var node; var started = false; for (var i = 0; i < nodes.length; ++i) { node = nodes[i]; if (started) { if (endCtn === node) { if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isToken */ .hD)(endCtn)) { res += node.getAttribute('data-text'); } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(node)) { res += node.data.substring(0, endOffset); } break; } else { if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isToken */ .hD)(node)) { res += node.getAttribute('data-text'); } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(node)) { res += node.data; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isNewLine */ .K0)(node)) { res += '\n'; } } } else { if (startCtn === node) { started = true; if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(node)) { res += node.data.substring(startOffset); } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isToken */ .hD)(node)) { if (startOffset === 0) { res += node.getAttribute('data-text'); } } } } } return res; } TITextController.prototype.applyData = function (text, offset) { this.setText(text); this.elt.selectionCtrl.setRangeByOffset(offset); }; TITextController.prototype.insertText = function (text) { var range = document.getSelection().getRangeAt(0); range.deleteContents(); this.elt.selectionCtrl.onSelect(); range = document.getSelection().getRangeAt(0); var eltChain = (0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .text2ContentElements */ .fw)(text, { tagMap: this.elt.tagMap }); var startCtn = range.startContainer; var at; if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isTokenText */ .tk)(startCtn)) { at = startCtn.parentElement; } else if (startCtn === this.elt) { at = this.elt.childNodes[range.startOffset - 1]; } var newNode; while (eltChain.length > 0) { newNode = eltChain.shift(); if (!at) { this.elt.addChildBefore(newNode, this.elt.firstChild); at = newNode; } else if ((0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(at) && (0,_tiutils__WEBPACK_IMPORTED_MODULE_4__/* .isText */ .Gs)(newNode)) { at.data += newNode.data; } else { this.elt.addChildAfter(newNode, at); at = newNode; } } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TITextController); /***/ }), /***/ 3421: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Dx": () => (/* binding */ tokenizeMessageText), /* harmony export */ "Gs": () => (/* binding */ isText), /* harmony export */ "K0": () => (/* binding */ isNewLine), /* harmony export */ "ot": () => (/* binding */ getFirstTextNode), /* harmony export */ "No": () => (/* binding */ getLastTextNode), /* harmony export */ "tk": () => (/* binding */ isTokenText), /* harmony export */ "hD": () => (/* binding */ isToken), /* harmony export */ "M4": () => (/* binding */ findNextTextNode), /* harmony export */ "LD": () => (/* binding */ findPrevTextNode), /* harmony export */ "fw": () => (/* binding */ text2ContentElements) /* harmony export */ }); /* harmony import */ var _EmojiAnims__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4670); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3855); /* harmony import */ var _TITextController__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1875); function tokenizeMessageText(text) { var emojis = _EmojiAnims__WEBPACK_IMPORTED_MODULE_0__/* .EmojiAnimByIdent */ .M; var splitter = Object.keys(_EmojiAnims__WEBPACK_IMPORTED_MODULE_0__/* .EmojiAnimByIdent */ .M).concat(['\n']); var tagTokens = text.match(/@\[id:\d+]/g) || []; var otherTokens = text.split(/@\[id:\d+]/g); var tokens = otherTokens.reduce((ac, cr, i) => { ac.push(cr); if (i < tagTokens.length) ac.push(tagTokens[i]); return ac; }, []); tokens = splitter.reduce((chain, splitter) => { return chain.reduce((ac, token) => { var subChain = token.split(splitter); for (var i = 0; i < subChain.length; ++i) { if (subChain[i]) { ac.push(subChain[i]); } if (i + 1 < subChain.length) { ac.push(splitter); } } return ac; }, []); }, tokens); tokens = tokens.map(text => { var tagId; if (text === '\n') { return { type: 'NEW_LINE' }; } else if (emojis[text]) { return { type: 'EMOJI', value: text }; } else if (text.match(/^@\[id:\d+]$/)) { tagId = text.substring(5, text.length - 1); return { type: "TAG", value: tagId }; } else return { type: 'TEXT', value: text }; }); return tokens; } var isText = node => { return node && node.nodeType === Node.TEXT_NODE; } var isNewLine = node => { return node && node.tagName === 'BR'; } /*** * * @param {Text|AElement}node * @returns {null|*} */ var getFirstTextNode = node => { if (node.nodeType === Node.TEXT_NODE || node.tagName === 'BR') return node; var nodes = node.childNodes; var res = null; for (var i = 0; i < nodes.length && !res; ++i) { res = res || getFirstTextNode(nodes[i]); } return res; }; var getLastTextNode = node => { if (node.nodeType === Node.TEXT_NODE || node.tagName === 'BR') return node; var nodes = node.childNodes; var res = null; for (var i = nodes.length - 1; i > 0 && !res; --i) { res = res || getLastTextNode(node); } return res; }; var isTokenText = node => { if (node.nodeType !== Node.TEXT_NODE) return false; return isToken(node.parentElement); } var isToken = node => { return node && node.classList && (node.classList.contains('as-emoji-token') || node.classList.contains('as-tag-token')); } function findNextTextNode(root, current) { var nextTextNode = node => { var res = null; var next = node.nextSibling; while (next && !res) { res = getFirstTextNode(next); next = next.nextSibling; } if (!res && node.parentElement !== root) { res = nextTextNode(node.parentElement); } return res; } return nextTextNode(current); } function findPrevTextNode(root, current) { var prevTextNode = node => { var res = null; var prev = node.previousSibling; while (prev && !res) { res = getLastTextNode(prev); prev = prev.previousSibling; } if (!res && node.parentElement !== root) { res = prevTextNode(node.parentElement); } return res; } return prevTextNode(current); } function text2ContentElements(text, opt) { return tokenizeMessageText(text).map((token) => { var textOfTag; switch (token.type) { case 'NEW_LINE': return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)('br'); case 'EMOJI': return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ tag: 'span', class: 'as-emoji-token', attr: { 'data-display': _TITextController__WEBPACK_IMPORTED_MODULE_2__/* .EMPTY_2_SPACES */ .U, 'data-text': token.value }, child: { text: _TITextController__WEBPACK_IMPORTED_MODULE_2__/* .EMPTY_2_SPACES */ .U } }) case 'TAG': textOfTag = opt.tagMap && opt.tagMap[token.value]; return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ tag: 'span', class: 'as-tag-token', attr: { 'data-text': '@[id:' + token.value + ']', 'data-display': textOfTag ? '@' + textOfTag : '@[id:' + token.value + ']' }, child: { text: textOfTag ? '@' + textOfTag : '@[id:' + token.value + ']' } }); case 'TEXT': default: return (0,_ACore__WEBPACK_IMPORTED_MODULE_1__._)({ text: token.value }); } }); } /***/ }), /***/ 9346: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(863); var STATE_INIT = 0; var STATE_ATTACHED = 1; var STATE_RELEASED = 2; var STATE_FIRED = 3; var STATE_DESTROYED = 4; /*** * * @param {AElement[]|AElement} eltList * @param {"click"|"mousedown"} eventType * @param {function} callback * @param {number=} initAfter * @param {number=} fireDelay * @param {*[]=} args * @constructor */ function BlurTrigger(eltList, eventType, callback, initAfter, fireDelay, args) { this.args = args || []; this.callback = callback; this.eltTargets = eltList || []; this.initAfter = initAfter || 0; this.fireDelay = fireDelay || 0; this.state = STATE_INIT; this.eventType = eventType; this['ev_mouse'] = this.ev_mouse.bind(this); this['ev_blur'] = this.ev_blur.bind(this); if (this.initAfter > 0) { setTimeout(this._attach.bind(this)); } else this._attach(); } BlurTrigger.prototype._attach = function () { if (this.state !== STATE_INIT) return; document.addEventListener(this.eventType, this.ev_mouse); window.addEventListener('blur', this.ev_blur); this.state = STATE_ATTACHED; }; BlurTrigger.prototype._fire = function () { if (this.state !== STATE_RELEASED) return; this.callback.apply(this, this.args); this.state = STATE_FIRED; }; BlurTrigger.prototype._release = function () { if (this.state !== STATE_ATTACHED) return; document.removeEventListener(this.eventType, this.ev_mouse); window.removeEventListener('blur', this.ev_blur); this.state = STATE_RELEASED; }; BlurTrigger.prototype.destroy = function () { if (this.state === 4) return; if (this.state === STATE_ATTACHED) this._release(); this.state = STATE_DESTROYED; }; BlurTrigger.prototype._prepareFire = function () { if (this.fireDelay > 0) { setTimeout(this._fire.bind(this), this.fireDelay); } else { this._fire(); } } BlurTrigger.prototype.ev_mouse = function (event) { var hit = false; if (this.eltTargets instanceof Array) { hit = this.eltTargets.some(function (elt) { return (0,absol_src_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* .hitElement */ .EY)(elt, event); }); } else if (typeof hit === "function") { hit = this.eltTargets.call(this, event.target); } if (!hit) { this._release(); this._prepareFire(); } }; BlurTrigger.prototype.ev_blur = function () { setTimeout(function () { if (this.state !== STATE_ATTACHED) return; var tagName = (document.activeElement && document.activeElement.tagName) || ''; tagName = tagName.toLowerCase(); if (tagName === 'iframe') { this._release(); this._prepareFire(); } }.bind(this), 0); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (BlurTrigger); /***/ }), /***/ 1866: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /** * @deprecated use TextMeasure instead * @param opts * @constructor */ function TextMeasurement(opts) { opts = opts || {}; this.chars = opts.chars || (" !\"$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ" + "[\\]^_abcdefghijklmnopqrstuvwxyz{|}" + "¥©ÀÁÂÃÈÉÊÌÍÒÓÔÕÙÚÝàáâãèéêìíñòóôõùúýĂăĐđĨĩŨũƠơƯưẠ̌̀́̃̉Р" + "ийксуẠạẢảẤấẦầẨẩẪẫẬậẮắẰằẲẳẴẵẶặẸẹẺẻẼẽẾếỀềỂểỄễỆệỈỉỊị" + "ỌọỎỏỐốỒồỔổỖỗỘộỚớỜờỞởỠỡỢợỤụỦủỨứỪừỬửỮữỰựỲỳỴỵỶỷỸỹ–’“”…₫€?").split(''); this.computed = Object.assign({}, opts.computed || {}); } TextMeasurement.prototype.compute = function (font) { if (this.computed[font]) return true; if (!('document' in window)) return false; if (!this.canvas) { this.canvas = document.createElement('canvas'); this.ctx = this.canvas.getContext('2d'); } var ctx = this.ctx; ctx.font = font; var data = {}; var charBoxes = {}; data.charBoxes = charBoxes; var c, d, i, j; var metrics; var n = this.chars.length; var chars = this.chars; for (i = 0; i < n; ++i) { c = chars[i]; metrics = ctx.measureText(c); charBoxes[c] = metrics.width; } var spacing = {}; data.spacing = spacing; var pair; for (i = 0; i < n; ++i) { c = chars[i]; for (j = 0; j < n; ++j) { d = chars[j]; pair = c + d; metrics = ctx.measureText(pair); spacing[pair] = metrics.width - charBoxes[c] - charBoxes[d]; } } this.computed[font] = data; return true; }; /*** * * @param {string} text * @param {string=} font * @return {number} */ TextMeasurement.prototype.measureTextWidth = function (text, font) { var l = text.length; if (l === 0) return 0; var width = 0; var data = this.computed[font]; var charBoxes = data.charBoxes; var spacing = data.spacing; var c, pc; pc = text[0]; width += charBoxes[pc] || charBoxes['0']; for (var i = 1; i < l; ++i) { c = text[i]; width += spacing[pc + c]; width += charBoxes[c] || charBoxes['0']; pc = c; } return width; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TextMeasurement); /***/ }), /***/ 1477: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "getSelectionRangeDirection": () => (/* binding */ getSelectionRangeDirection), /* harmony export */ "setSelectionRange": () => (/* binding */ setSelectionRange), /* harmony export */ "insertTextAtCursor": () => (/* binding */ insertTextAtCursor), /* harmony export */ "contenteditableTextOnly": () => (/* binding */ contenteditableTextOnly), /* harmony export */ "getSelectionText": () => (/* binding */ getSelectionText), /* harmony export */ "positiveIntMod": () => (/* binding */ positiveIntMod), /* harmony export */ "nearFloor": () => (/* binding */ nearFloor), /* harmony export */ "measureText": () => (/* binding */ measureText), /* harmony export */ "getCaretPosition": () => (/* binding */ getCaretPosition), /* harmony export */ "preventNotNumberInput": () => (/* binding */ preventNotNumberInput), /* harmony export */ "buildCss": () => (/* binding */ buildCss), /* harmony export */ "forwardEvent": () => (/* binding */ forwardEvent), /* harmony export */ "forwardMethod": () => (/* binding */ forwardMethod), /* harmony export */ "openFileDialog": () => (/* binding */ openFileDialog), /* harmony export */ "openYesNoQuestionDialog": () => (/* binding */ openYesNoQuestionDialog), /* harmony export */ "charWidth": () => (/* binding */ charWidth), /* harmony export */ "estimateWidth14": () => (/* binding */ estimateWidth14), /* harmony export */ "getTextNodeBounds": () => (/* binding */ getTextNodeBounds), /* harmony export */ "absCeil": () => (/* binding */ absCeil), /* harmony export */ "zeroPadding": () => (/* binding */ zeroPadding), /* harmony export */ "cleanMenuItemProperty": () => (/* binding */ cleanMenuItemProperty), /* harmony export */ "getTagListInTextMessage": () => (/* binding */ getTagListInTextMessage), /* harmony export */ "swapElt": () => (/* binding */ swapElt), /* harmony export */ "swapChildrenInElt": () => (/* binding */ swapChildrenInElt), /* harmony export */ "replaceChildrenInElt": () => (/* binding */ replaceChildrenInElt), /* harmony export */ "findVScrollContainer": () => (/* binding */ findVScrollContainer), /* harmony export */ "vScrollIntoView": () => (/* binding */ vScrollIntoView), /* harmony export */ "fileSize2Text": () => (/* binding */ fileSize2Text), /* harmony export */ "isDateTimeFormatToken": () => (/* binding */ isDateTimeFormatToken), /* harmony export */ "normalizeMinuteOfMillis": () => (/* binding */ normalizeMinuteOfMillis), /* harmony export */ "millisToClock": () => (/* binding */ millisToClock), /* harmony export */ "clockToMillis": () => (/* binding */ clockToMillis), /* harmony export */ "isRealNumber": () => (/* binding */ isRealNumber), /* harmony export */ "isNaturalNumber": () => (/* binding */ isNaturalNumber), /* harmony export */ "isInteger": () => (/* binding */ isInteger), /* harmony export */ "parseLocalFloat": () => (/* binding */ parseLocalFloat), /* harmony export */ "formatLocalFloat": () => (/* binding */ formatLocalFloat), /* harmony export */ "isURLAddress": () => (/* binding */ isURLAddress), /* harmony export */ "fileAccept": () => (/* binding */ fileAccept), /* harmony export */ "fileInfoOf": () => (/* binding */ fileInfoOf), /* harmony export */ "addElementsBefore": () => (/* binding */ addElementsBefore), /* harmony export */ "addElementAfter": () => (/* binding */ addElementAfter), /* harmony export */ "addElementClassName": () => (/* binding */ addElementClassName), /* harmony export */ "findMaxZIndex": () => (/* binding */ findMaxZIndex), /* harmony export */ "getAncestorElementOf": () => (/* binding */ getAncestorElementOf), /* harmony export */ "checkedValues2RootTreeValues": () => (/* binding */ checkedValues2RootTreeValues), /* harmony export */ "rootTreeValues2CheckedValues": () => (/* binding */ rootTreeValues2CheckedValues), /* harmony export */ "copySelectionItemArray": () => (/* binding */ copySelectionItemArray), /* harmony export */ "isScrolledToBottom": () => (/* binding */ isScrolledToBottom), /* harmony export */ "parseDMS": () => (/* binding */ parseDMS), /* harmony export */ "parseLatLng": () => (/* binding */ parseLatLng), /* harmony export */ "normalizeLatLngString": () => (/* binding */ normalizeLatLngString), /* harmony export */ "implicitLatLng": () => (/* binding */ implicitLatLng), /* harmony export */ "getMapZoomLevel": () => (/* binding */ getMapZoomLevel), /* harmony export */ "latLngDistance": () => (/* binding */ latLngDistance), /* harmony export */ "keyStringOf": () => (/* binding */ keyStringOf), /* harmony export */ "jsStringOf": () => (/* binding */ jsStringOf), /* harmony export */ "calcDTQueryHash": () => (/* binding */ calcDTQueryHash), /* harmony export */ "replaceInObject": () => (/* binding */ replaceInObject), /* harmony export */ "replaceFileInObject": () => (/* binding */ replaceFileInObject), /* harmony export */ "revokeResource": () => (/* reexport safe */ absol_src_DataStructure_Object__WEBPACK_IMPORTED_MODULE_9__.bU), /* harmony export */ "isNone": () => (/* binding */ isNone), /* harmony export */ "wrapWord": () => (/* binding */ wrapWord), /* harmony export */ "wrapText": () => (/* binding */ wrapText), /* harmony export */ "listenDomContentChange": () => (/* binding */ listenDomContentChange), /* harmony export */ "getMaterialDesignIconNames": () => (/* binding */ getMaterialDesignIconNames) /* harmony export */ }); /* harmony import */ var _ACore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3855); /* harmony import */ var absol_src_String_stringUtils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(2973); /* harmony import */ var _YesNoQuestionDialog__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(5466); /* harmony import */ var _Modal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9826); /* harmony import */ var absol_src_Converter_ext2MineType__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9691); /* harmony import */ var _tool_TextMeasurement__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(1866); /* harmony import */ var absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7807); /* harmony import */ var absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(2759); /* harmony import */ var absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7951); /* harmony import */ var absol_src_DataStructure_Object__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(2722); function getSelectionRangeDirection(range) { var sel = document.getSelection(); var direction = 'forward'; var cmpPosition = sel.anchorNode.compareDocumentPosition(sel.focusNode); if (cmpPosition === 4) { direction = 'forward'; } else if (cmpPosition === 2) { direction = 'backward' } else if (!cmpPosition && sel.anchorOffset > sel.focusOffset || cmpPosition === Node.DOCUMENT_POSITION_PRECEDING) { direction = 'backward'; } return direction; } /*** * * @param {Range} range * @param {boolean=} backward */ function setSelectionRange(range, backward) { var sel = document.getSelection(); if (backward) { if (typeof sel.extend != "undefined") { var endRange = range.cloneRange(); endRange.collapse(false); sel.removeAllRanges(); sel.addRange(endRange); sel.extend(range.startContainer, range.startOffset); } } else { sel.removeAllRanges(); sel.addRange(range); } } function insertTextAtCursor(text) { var sel, range; if (window.getSelection) { sel = window.getSelection(); if (sel.getRangeAt && sel.rangeCount) { range = sel.getRangeAt(0); range.deleteContents(); range.insertNode(document.createTextNode(text)); } } else if (document.selection && document.selection.createRange) { document.selection.createRange().text = text; } } function contenteditableTextOnly(element, processText) { if (element.__contenteditableTextOnly__) return; element.__contenteditableTextOnly__ = true; element.addEventListener("paste", function (e) { e.preventDefault(); if (e.clipboardData && e.clipboardData.getData) { var text = e.clipboardData.getData("text/plain"); if (processText) text = processText(text) document.execCommand("insertHTML", false, text); } else if (window.clipboardData && window.clipboardData.getData) { var text = window.clipboardData.getData("Text"); if (processText) text = processText(text) insertTextAtCursor(text); } }); } function getSelectionText() { var text = ""; var activeEl = document.activeElement; var activeElTagName = activeEl ? activeEl.tagName.toLowerCase() : null; if ( (activeElTagName == "textarea") || (activeElTagName == "input" && /^(?:text|search|password|tel|url)$/i.test(activeEl.type)) && (typeof activeEl.selectionStart == "number") ) { text = activeEl.value.slice(activeEl.selectionStart, activeEl.selectionEnd); } else if (window.getSelection) { text = window.getSelection().toString(); } return text; } /*** * * @param num * @param maxVal * @return {number} */ function positiveIntMod(num, maxVal) { if (maxVal <= 0) return 0; if (num >= 0 && num < maxVal) { return Math.floor(num); } else if (num === Infinity) { if (maxVal === Infinity) return Infinity; else return 0; } else if (num < 0) { return (num + (Math.ceil(-num / maxVal) * maxVal)) % maxVal; } else if (num >= maxVal) { return Math.floor(num) % maxVal } else return 0; } function nearFloor(x, epsilon) { var y = Math.floor(x); if (x - y + epsilon >= 1) y++; return y; } function measureText(text, font) { // re-use canvas object for better performance var canvas = measureText.canvas || (measureText.canvas = document.createElement("canvas")); var context = canvas.getContext("2d"); if (font) context.font = font; var metrics = context.measureText(text); return metrics; } function getCaretPosition(oField) { var iCaretPos = 0; if (document.selection) { oField.focus(); var oSel = document.selection.createRange(); oSel.moveStart('character', -oField.value.length); iCaretPos = oSel.text.length; } else if (oField.selectionStart || oField.selectionStart == '0') iCaretPos = oField.selectionDirection == 'backward' ? oField.selectionStart : oField.selectionEnd; return iCaretPos; } /** * * @param {AElement} elt */ function preventNotNumberInput(elt) { elt.addEventListener('keyup', function () { var lastValue = (elt.tagName === "DIV" || elt.tagName === "SPAN") ? elt.innerHTML : elt.attributes.value; var cValue = parseFloat(this.value); if (this.value != lastValue) { elt.attributes.value = cValue; elt.emit('change', cValue, elt); } }); elt.addEventListener("paste", function (e) { e.preventDefault(); var text = ""; if (e.clipboardData && e.clipboardData.getData) { text = e.clipboardData.getData("text/plain"); } else if (window.clipboardData && window.clipboardData.getData) { text = window.clipboardData.getData("Text"); } var matched = text.match(/[+-]?([0-9]*[.])?[0-9]+/); if (matched) { this.value = matched[0]; } }); elt.addEventListener('keydown', function (event) { var key = event.key; if (key && key.length == 1 && !event.ctrlKey && !event.altKey) { if (key.match(/[0-9.\-\+]/)) { if (key == '.' && this.value.indexOf('.') >= 0) event.preventDefault(); if ((key == '+' || key == '-') && (this.value.indexOf('+') >= 0 || this.value.indexOf('-') >= 0 || getCaretPosition(this) > 0)) event.preventDefault(); } else event.preventDefault(); } }); } function buildCss(StyleSheet) { return (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: 'style', props: { innerHTML: Object.keys(StyleSheet).map(function (key) { var style = StyleSheet[key]; return key + ' {\n' + Object.keys(style).map(function (propName) { return propName + ': ' + style[propName] + ';'; }).join('\n') + '}'; }).join('\n') } }).addTo(document.head); } function forwardEvent(elt, fromName, toName) { elt.defineEvent(toName); elt.on(fromName, function (event) { event = Object.assign({}, event); event.type = toName; this.emit.apply(this, [toName, event].concat(Array.prototype.slice.call(arguments, 1))); }); } function forwardMethod(elt, fromName, toName) { elt[fromName] = function () { this[toName].apply(this, arguments); } } /*** * * @param {"camera"|"microphone"|"camcorder"|{accept:("image/*"|"audio/*"|"video/*"|undefined), capture:boolean|undefined, multiple:boolean|undefined}|{}=} props * @param {boolean=}unSafe * @return {Promise<File[]>} */ function openFileDialog(props, unSafe) { return new Promise(function (resolve) { var input = _ACore__WEBPACK_IMPORTED_MODULE_0__/* ["default"]._ */ .Z._({ tag: 'input', style: { display: 'none' }, attr: { type: 'file' } }).addTo(document.body); props = props || {}; if (props === 'camera') { props = { accept: 'image/*', capture: 'camera' } } else if (props === 'microphone') { props = { accept: 'audio/*', capture: "microphone" } } else if (props === 'camcorder') { props = { accept: 'video/*', capture: 'camcorder' } } if (props.accept) { if (props.accept instanceof Array) input.attr('accept', props.accept.join(',')); else input.attr('accept', props.accept); } else { input.attr('accept', null); } if (props.capture) { input.attr('capture', props.capture); } if (props.multiple) { input.attr('multiple', 'true'); } else { input.attr('multiple'); } input.value = null; function focusHandler() { setTimeout(function () { window.removeEventListener('focus', focusHandler); if (unSafe) { input.off('change', changeHandler); input.remove(); resolve([]); } }, 1000); } function changeHandler() { input.off('change', changeHandler); window.removeEventListener('focus', focusHandler); var files = Array.prototype.slice.call(input.files) resolve(files); input.remove(); } input.on('change', changeHandler); input.click(); setTimeout(function () { window.addEventListener('focus', focusHandler); }, 10); }); } function openYesNoQuestionDialog(title, message) { return new Promise(resolve => { if (window.ModalElement && window.ModalElement.question) { window.ModalElement.question({ title: title, message: message, onclick: function (sel) { if (sel === 0) { resolve(true); } else { resolve(false); } } }); } else { var modal = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)({ tag: _Modal__WEBPACK_IMPORTED_MODULE_2__/* ["default"].tag */ .Z.tag, child: { tag: _YesNoQuestionDialog__WEBPACK_IMPORTED_MODULE_1__/* ["default"].tag */ .Z.tag, props: { textYes: 'Có', textNo: 'Không', message: message, dialogTitle: title }, on: { action: (event) => { modal.remove(); resolve(event.action.name === 'yes'); } } } }).addTo(document.body); } }); } var charWidth = { "A": 9.337890625, "Á": 9.337890625, "À": 9.337890625, "Ả": 9.337890625, "Ã": 9.337890625, "Ạ": 9.337890625, "a": 7.7861328125, "á": 7.7861328125, "à": 7.7861328125, "ả": 7.7861328125, "ã": 7.7861328125, "ạ": 7.7861328125, "Ă": 9.337890625, "Ắ": 9.337890625, "Ằ": 9.337890625, "Ẳ": 9.337890625, "Ẵ": 9.337890625, "Ặ": 9.337890625, "ă": 7.7861328125, "ắ": 7.7861328125, "ằ": 7.7861328125, "ẳ": 7.7861328125, "ẵ": 7.7861328125, "ặ": 7.7861328125, "Â": 9.337890625, "Ấ": 9.337890625, "Ầ": 9.337890625, "Ẩ": 9.337890625, "Ẫ": 9.337890625, "Ậ": 9.337890625, "â": 7.7861328125, "ấ": 7.7861328125, "ầ": 7.7861328125, "ẩ": 7.7861328125, "ẫ": 7.7861328125, "ậ": 7.7861328125, "B": 9.337890625, "b": 7.7861328125, "C": 10.1103515625, "c": 7, "D": 10.1103515625, "d": 7.7861328125, "Đ": 10.1103515625, "đ": 7.7861328125, "E": 9.337890625, "É": 9.337890625, "È": 9.337890625, "Ẻ": 9.337890625, "Ẽ": 9.337890625, "Ẹ": 9.337890625, "e": 7.7861328125, "é": 7.7861328125, "è": 7.7861328125, "ẻ": 7.7861328125, "ẽ": 7.7861328125, "ẹ": 7.7861328125, "Ê": 9.337890625, "Ế": 9.337890625, "Ề": 9.337890625, "Ể": 9.337890625, "Ễ": 9.337890625, "Ệ": 9.337890625, "ê": 7.7861328125, "ế": 7.7861328125, "ề": 7.7861328125, "ể": 7.7861328125, "ễ": 7.7861328125, "ệ": 7.7861328125, "G": 10.8896484375, "g": 7.7861328125, "H": 10.1103515625, "h": 7.7861328125, "I": 3.8896484375, "Í": 3.8896484375, "Ì": 3.8896484375, "Ỉ": 3.8896484375, "Ĩ": 3.8896484375, "Ị": 3.8896484375, "i": 3.1103515625, "í": 3.1103515625, "ì": 3.1103515625, "ỉ": 3.1103515625, "ĩ": 3.1103515625, "ị": 3.1103515625, "K": 9.337890625, "k": 7, "L": 7.7861328125, "l": 3.1103515625, "M": 11.662109375, "m": 11.662109375, "N": 10.1103515625, "n": 7.7861328125, "O": 10.8896484375, "Ó": 10.8896484375, "Ò": 10.8896484375, "Ỏ": 10.8896484375, "Õ": 10.8896484375, "Ọ": 10.8896484375, "o": 7.7861328125, "ó": 7.7861328125, "ò": 7.7861328125, "ỏ": 7.7861328125, "õ": 7.7861328125, "ọ": 7.7861328125, "Ô": 10.8896484375, "Ố": 10.8896484375, "Ồ": 10.8896484375, "Ổ": 10.8896484375, "Ỗ": 10.8896484375, "Ộ": 10.8896484375, "ô": 7.7861328125, "ố": 7.7861328125, "ồ": 7.7861328125, "ổ": 7.7861328125, "ỗ": 7.7861328125, "ộ": 7.7861328125, "Ơ": 12.00390625, "Ớ": 12.00390625, "Ờ": 12.00390625, "Ở": 12.00390625, "Ỡ": 12.00390625, "Ợ": 12.00390625, "ơ": 9.1806640625, "ớ": 9.1806640625, "ờ": 9.1806640625, "ở": 9.1806640625, "ỡ": 9.1806640625, "ợ": 9.1806640625, "P": 9.337890625, "p": 7.7861328125, "Q": 10.8896484375, "q": 7.7861328125, "R": 10.1103515625, "r": 4.662109375, "S": 9.337890625, "s": 7, "T": 8.5517578125, "t": 3.8896484375, "U": 10.1103515625, "Ú": 10.1103515625, "Ù": 10.1103515625, "Ủ": 10.1103515625, "Ũ": 10.1103515625, "Ụ": 10.1103515625, "u": 7.7861328125, "ú": 7.7861328125, "ù": 7.7861328125, "ủ": 7.7861328125, "ũ": 7.7861328125, "ụ": 7.7861328125, "Ư": 11.9560546875, "Ứ": 11.9560546875, "Ừ": 11.9560546875, "Ử": 11.9560546875, "Ữ": 11.9560546875, "Ự": 11.9560546875, "ư": 9.3720703125, "ứ": 9.3720703125, "ừ": 9.3720703125, "ử": 9.3720703125, "ữ": 9.3720703125, "ự": 9.3720703125, "V": 9.337890625, "v": 7, "X": 9.337890625, "x": 7, "Y": 9.337890625, "Ý": 9.337890625, "Ỳ": 9.337890625, "Ỷ": 9.337890625, "Ỹ": 9.337890625, "Ỵ": 9.337890625, "y": 7, "ý": 7, "ỳ": 7, "ỷ": 7, "ỹ": 7, "ỵ": 7, " ": 3.8896484375 }; function estimateWidth14(text) { // return absol.text.measureText(text, '14px arial').width var l = 0; for (var j = 0; j < text.length; ++j) { l += (charWidth[text.charAt(j)]) || 9.337890625; } return l; } /** *TODO: import from absol-acomp * @param {Text} text * @param {number=} startOffset * @param {number=} endOffset * @returns {*[]} */ function getTextNodeBounds(text, startOffset, endOffset) { if (!text || text.nodeType !== Node.TEXT_NODE || !text.parentElement) return null; var style = getComputedStyle(text.parentElement); var fontSize = parseFloat(style.getPropertyValue('font-size').replace('px', '')); var lineHeight = style.getPropertyValue('line-height'); if (lineHeight === 'normal') lineHeight = 1.2; else lineHeight = parseFloat(lineHeight.replace('px', '')) / fontSize; var txt = text.data; var y = -Infinity; var c; var range; var parts = []; var cPart; var j; var delta = lineHeight * fontSize / 3; var rect; var i = 0; if (isNaturalNumber(startOffset)) i = Math.max(startOffset, i); if (isNaturalNumber(endOffset)) endOffset = Math.min(txt.length, endOffset); else endOffset = txt.length while (i < endOffset) { c = txt[i]; j = i + 1; range = document.createRange(); range.setStart(text, i); range.setEnd(text, j); rect = absol_src_Math_Rectangle__WEBPACK_IMPORTED_MODULE_6__/* ["default"].fromClientRect */ .Z.fromClientRect(range.getBoundingClientRect()); if (Math.abs(rect.y - y) < delta) { cPart.end = j; cPart.rect = cPart.rect.merge(rect); } else { cPart = { start: i, end: j, rect: rect }; y = rect.y; parts.push(cPart); } i = j; } parts.forEach(part => { rect = part.rect; part.text = txt.substring(part.start, part.end); }); return parts; } /*** * * @param {number} v * @returns {number} */ function absCeil(v) { var a = Math.ceil(Math.abs(v)); return v < 0 ? -a : a; } /*** * * @param {number} x * @param {number} l * @returns {String} */ function zeroPadding(x, l) { var res = Math.abs(x) + ''; while (res.length < l) { res = '0' + res; } if (x < 0) res = '-' + res; return res; } var propertyFilter = ["$trigger", "$content", "_isShow", "defineEvent", "isSupportedEvent", "emit", "fire", "eventEmittorOnWithTime", "on", "once", "off", "init", "eventHandler", "super", "defineAttribute", "defineAttributes", "attr", "addStyle", "removeStyle", "addChild", "addTo", "selfRemove", "selfReplace", "clearChild", "containsClass", "addClass", "removeClass", "getComputedStyleValue", "getFontSize", "findChildAfter", "findChildBefore", "addChildBefore", "addChildAfter", "getBoundingRecursiveRect", "isDescendantOf", "getCSSRules", "afterAttached", "afterDisplayed", "_azar_extendEvents", "__azar_force", "_azar_extendAttributes", "_azar_extendTags", "findAvailablePosition", "$container", "autoFixParentSize", "sync", "$dropper", "$vmenu", "$button", "$text", "$key", "$arrow", "$iconCtn", "_textMarginRight", "_tabIndex", '$icon', '_icon', '$textNode', '$primaryBtn', '$extendBtn', '_menuHolder', '_items', 'hasClass'].reduce(function (ac, cr) { ac[cr] = true; return ac; }, {}); /** * This is a solution for menu, before a better one. * @param obj * @returns {{}} */ function cleanMenuItemProperty(obj) { var res = {}; var keys = Object.keys(obj); var key; for (var i = 0; i < keys.length; ++i) { key = keys[i]; if (!propertyFilter[key]) { res[key] = obj[key]; } } res.text = obj.text; if (obj.icon) { res.icon = obj.icon; } if (obj.items) { res.items = obj.items; } return res; } function getTagListInTextMessage(text) { var rg = /@\[id:(\d+)]/g; var matched = rg.exec(text); var dict = {}; var v; var res = []; while (matched) { v = parseInt(matched[1]); if (isNaN(v)) v = matched[1]; if (!dict[v]) { dict[v] = true; res.push(v); } matched = rg.exec(text); } return res; } /*** * * @param {AElement} e1 * @param {AElement} e2 */ function swapElt(e1, e2) { var temp = (0,_ACore__WEBPACK_IMPORTED_MODULE_0__._)('div'); e1.parentElement.replaceChild(temp, e1); e2.parentElement.replaceChild(e1, e2); temp.parentElement.replaceChild(e2, temp); } function swapChildrenInElt(e1, e2) { var c1 = Array.prototype.slice.call(e1.childNodes); var c2 = Array.prototype.slice.call(e2.childNodes); (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)(e1).clearChild(); (0,_ACore__WEBPACK_IMPORTED_MODULE_0__.$)(e2).clearChild(); while (c2.length > 0) { e1.appendChild(c2.shift()); } while (c1.length > 0) { e2.appendChild(c1.shift()); } } function replaceChildrenInElt(elt, childNodes) { var nChildren = childNodes.slice(); var cChildren = Array.prototype.slice.call(elt.childNodes); var cC, nC; while (cChildren.length > 0 && nChildren.length > 0) { cC = cChildren[0]; nC = nChildren[0]; if (cC === nC) { cChildren.shift(); nChildren.shift(); } else { break; } } cChildren.forEach((elt) => { elt.remove(); }); elt.addChild(nChildren); } function findVScrollContainer(elt) { if (!elt) return null; var parent = elt.parentElement; var overflowStyle; while (parent) { overflowStyle = window.getComputedStyle(parent)['overflow']; if ((overflowStyle === 'auto scroll' || overflowStyle === 'auto' || overflowStyle === 'hidden auto' || overflowStyle === 'scroll' || parent.tagName === 'HTML') && (parent.clientHeight < parent.scrollHeight)) { break; } parent = parent.parentElement; } if (!parent || parent === document || parent.tagName === "HTML" || parent.tagName === "html") { parent = document.body.parentElement; } return parent; } /** * * @param {HTMLElement} elt */ function vScrollIntoView(elt) { var parent = findVScrollContainer(elt); var eBound = elt.getBoundingClientRect(); var viewportBound = parent.getBoundingClientRect(); var currentScrollTop = parent.scrollTop; var newScrollTop = currentScrollTop; if (eBound.bottom > viewportBound.bottom) { newScrollTop = currentScrollTop + (eBound.bottom - viewportBound.bottom); } if (eBound.top < viewportBound.top) { newScrollTop = currentScrollTop - (viewportBound.top - eBound.top); } if (newScrollTop !== currentScrollTop) { parent.scrollTop = newScrollTop; } } function fileSize2Text(s) { if (typeof s !== "number" || isNaN(s)) return ''; var units = ['B', 'KB', 'MB', 'GB', 'TB']; var b = 1; for (var i = 0; i < units.length; ++i) { if (s <= b * 1024) { return Math.floor(s / b * 100) / 100 + units[i]; } b *= 1024; } return Math.floor(s / b * 10) / 100 + 'PB'; } function isDateTimeFormatToken(text) { //ND: like (Next day) return ['d', 'dd', 'M', 'MM', 'y', 'yyyy', 'h', 'hh', 'H', 'HH', 'm', 'mm', 'a', 'w', 'ww', 'Q', 'QQ', 'ND'].indexOf(text) >= 0; } var normalizeMinuteOfMillis = mil => { mil = mil >> 0; mil = Math.floor(mil / 6e4) * 6e4; if (mil === absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__.MILLIS_PER_DAY) return mil; mil = mil % absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__.MILLIS_PER_DAY; if (mil < 0) mil += absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__.MILLIS_PER_DAY; return mil; }; /** * * @param {number} mil * @returns {{hour: number, minute: number, isNextDate: boolean}} */ var millisToClock = mil => { var res = {}; res.minute = Math.floor(mil / 6e4) % 60; var hour = Math.floor(mil / 36e5); if (hour >= 24) { res.hour = hour % 24; res.isNextDate = true; } else { res.hour = hour; } return res; }; var clockToMillis = (hour, minute) => { var res = hour * absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__.MILLIS_PER_HOUR + minute * absol_src_Time_datetime__WEBPACK_IMPORTED_MODULE_5__.MILLIS_PER_MINUTE; if (isNaturalNumber(res)) return res; return null; }; function isRealNumber(value) { return (isFinite(value) && (typeof value === "number")); } function isNaturalNumber(value) { return (isInteger(value) && value >= 0); } function isInteger(value) { return (isFinite(value) && (typeof value === "number") && Math.floor(value) === value); } /**** * * @param {string} text * @param {{locales?:string}|string =} opt */ function parseLocalFloat(text, opt) { if (typeof opt === "string") opt = { locales: opt }; var locales = (opt && opt.locales) || (window.systemconfig && window.systemconfig.numberFormatLocales); var sample = locales ? (new Intl.NumberFormat(locales).format(123456.78)) : (123456.78.toLocaleString()); // decimal-separator, thousand-separator. var thousandSeparator = sample.match(/3(.?)4/)[1] || ''; var decimalSeparator = sample.match(/6(.?)7/)[1]; text = text.replace(new RegExp('[' + thousandSeparator + ']', 'g'), '') .replace(new RegExp('[' + decimalSeparator + ']', 'g'), '.'); return parseFloat(text); } function formatLocalFloat(value, opt) { if (typeof opt === "string") opt = { locales: opt }; var formatOpt = Object.assign({}, opt); delete formatOpt.locales; var locales = (opt && opt.locales) || (window.systemconfig && window.systemconfig.numberFormatLocales); var sample; var thousandSeparator; var decimalSeparator; if (!locales) { sample = (123456.78.toLocaleString()); thousandSeparator = sample.match(/3(.?)4/)[1] || ''; decimalSeparator = sample.match(/6(.?)7/)[1]; if (decimalSeparator === '.') locales = 'en-US'; else if (decimalSeparator === ',') { locales = 'vi-VN'; } } return new Intl.NumberFormat(locales, formatOpt).format(value); } /*** * * @param {String} text * @returns {Boolean} */ function isURLAddress(text) { if (typeof text != "string") return false; return text.startsWith('.') || text.startsWith('http://') || text.startsWith('https://') || text.startsWith('/'); } /*** * * @param {string | null} pattern * @param {string} typeString * @returns {boolean} */ function fileAccept(pattern, typeString) { if (!pattern) return true; var parts = pattern.split(',').map(function (x) { return x.trim().toLowerCase(); }); var ext = typeString.split('.').pop().toLowerCase(); var mineType = typeString.split('/').shift().toLowerCase(); return parts.some(function (part) { if (part === '*') return true; if (part === 'audio/*') { return mineType === 'audio' || ['.3gp', '.aa', '.aac', '.aax', '.act', '.aiff', '.alac', '.amr', '.ape', '.au', '.awb', '.dss', '.flac', '.gsm', '.m4a', '.m4b', '.m4p', '.mp3', '.mpc', '.ogg, .oga, .mogg' , '.opus', '.ra', '.rm', '.raw', '.rf64', '.sln', '.tta', '.voc', '.vox', '.wav', '.wma', '.wv', '.webm', '.8svx', '.cda'].indexOf(ext) >= 0; } else if (part === 'video/*') { return mineType === 'video' || ['.webm', '.mkv', '.flv', '.flv', '.vob', '.drc', '.gif', '.gifv', '.mng', '.avi', '.wmv', '.yuv', '.rm', '.rmvb', '.viv', '.asf', '.amv', '.m4v', '.svi', '.3gp', '.3g2', '.mxf', '.roq', '.nsv'].indexOf(ext) >= 0; } else if (part === 'image/*') { return mineType === 'video' || [ "ase", "art", "bmp", "blp", "cd5", "cit", "cpt", "cr2", "cut", "dds", "dib", "djvu", "egt", "exif", "gif", "gpl", "grf", "icns", "ico", "iff", "jng", "jpeg", "jpg", "jfif", "jp2", "jps", "lbm", "max", "miff", "mng", "msp", "nef", "nitf", "ota", "pbm", "pc1", "pc2", "pc3", "pcf", "pcx", "pdn", "pgm", "PI1", "PI2", "PI3", "pict", "pct", "pnm", "pns", "ppm", "psb", "psd", "pdd", "psp", "px", "pxm", "pxr", "qfx", "raw", "rle", "sct", "sgi", "rgb", "int", "bw", "tga", "tiff", "tif", "vtf", "xbm", "xcf", "xpm", "3dv", "amf", "ai", "awg", "cgm", "cdr", "cmx", "dxf", "e2d", "egt", "eps", "fs", "gbr", "odg", "svg", "stl", "vrml", "x3d", "sxd", "v2d", "vnd", "wmf", "emf", "art", "xar", "png", "webp", "jxr", "hdp", "wdp", "cur", "ecw", "iff", "lbm", "liff", "nrrd", "pam", "pcx", "pgf", "sgi", "rgb", "rgba", "bw", "int", "inta", "sid", "ras", "sun", "tga", "heic", "heif" ].indexOf(ext) >= 0; } else if (part.startsWith('.')) { return '.' + ext === part; } else { return part === ext || part === mineType; } }); } /*** * * @param {File|Blob|string|{url:string}} fi */ function fileInfoOf(fi) { var res = {}; var handle = o => { var parts; if (typeof o === "string") { res.name = res.name || (o.split('/').pop() || '').replace(/%([\dA-Fa-f][\dA-Fa-f])/g, (all, g1) => { var n = parseInt(g1, 16); if (typeof n === "number") { return String.fromCharCode(n); } return all; }).replace(/\?.+$/, ''); if (!res.url && isURLAddress(o)) res.url = o; parts = res.name.split('.'); if (!res.type && parts.length > 1) { res.type = parts.pop(); } else if (typeof res.url === 'string') { parts = res.url.split('.'); res.type = parts.pop(); } if (res.type === 'upload') res.type = parts.pop(); } else if ((typeof o === "object") && o) { if (o instanceof Blob) { res.mimeType = o.type; } if (!res.name && (typeof o.name === "string")) { res.name = o.name; } if (!res.size && (typeof o.size === "number")) { res.size = o.size; } if (typeof o.url === "string") { res.url = o.url; handle(o.url); } } }; handle(fi); if (res.name) { res.name = res.name.replace(/\.upload$/, '') } if (!res.type && res.name) { res.type = res.name.toLowerCase().split('.').slice(1).pop(); } if (!res.mimeType && res.type) { res.mimeType = absol_src_Converter_ext2MineType__WEBPACK_IMPORTED_MODULE_3__/* ["default"] */ .Z[res.type]; } for (var k in res) { if (res[k] === undefined) delete res[k]; } return res; } function addElementsBefore(inElement, elements, at) { for (var i = 0; i < elements.length; ++i) { (inElement.addChildBefore || inElement.insertBefore).call(inElement, elements[i], at); } } function addElementAfter(inElement, elements, at) { var atIdx; var before; var i; if (at) { atIdx = Array.prototype.indexOf.call(inElement.childNodes, at); if (at && atIdx < 0) throw new Error("The node before which the new node is to be inserted is not a child of this node."); before = inElement.childNodes[atIdx + 1]; if (before) { for (i = 0; i < elements.length; ++i) { (inElement.addChildBefore || inElement.insertBefore).call(inElement, elements[i], before); } } else { for (i = 0; i < elements.length; ++i) { (inElement.addChild || inElement.appendChild).call(inElement, elements[i]); } } } else { before = inElement.firstChild; for (i = 0; i < elements.length; ++i) { (inElement.addChildBefore || inElement.insertBefore).call(inElement, elements[i], before); } } } function addElementClassName(elt, className) { if (typeof className === "string") { className = className.trim().split(/\s+/); } if (className instanceof Array) { className.forEach(cls => elt.classList.add(cls)); } } function findMaxZIndex(elt) { var e = elt var style; var res = 0; while (e && e !== document.body) { style = getComputedStyle(e); res = Math.max(parseFloat(style.getPropertyValue('z-index')) || 0); e = e.parentElement; } return res; } function getAncestorElementOf(elt) { while (elt.parentElement) { elt = elt.parentElement; } return elt; } function checkedValues2RootTreeValues(items, values) { var keyOf = (x) => (typeof x) + x; var dict = values.reduce((ac, cr) => { ac[keyOf(cr)] = true; return ac; }, {}); var checkScan = item => { if (dict[keyOf(item.value)]) return true; if (item.items && item.items.length > 0) { item.items.forEach(sItem => checkScan(sItem)); dict[keyOf(item.value)] = item.items.every(sItem => dict[keyOf(sItem.value)]); } return dict[keyOf(item.value)]; } var res = []; var scan = item => { if (dict[keyOf(item.value)]) { res.push(item.value); } else if (item.items && item.items.length > 0) { item.items.forEach(sItem => scan(sItem)); } } items.forEach(sItem => scan(sItem)); return res; } function rootTreeValues2CheckedValues(items, values) { var keyOf = (x) => (typeof x) + x; var dict = values.reduce((ac, cr) => { ac[keyOf(cr)] = true; return ac; }, {}); var res = []; var visit = (item, checked) => { if (checked) res.push(item.value); if (item.items && item.items.length > 0) { item.items.forEach(cr => visit(cr, checked || dict[keyOf(cr.value)])); } } items.forEach(cr => visit(cr, dict[keyOf(cr.value)])) return res; } /*** * * @param {SelectionItem[]} items * @param {{removeNoView?: boolean, removeNewLine?:boolean}=} opt * @returns {SelectionItem[]} */ function copySelectionItemArray(items, opt) { opt = opt || {}; if (opt.removeNoView) { items = items.filter((item) => !item.noView); } if (opt.removeNewLine) { items.forEach(it => { if (it.text && it.text.indexOf && it.text.indexOf('\n') >= 0) { it.text = it.text.replace(/[\r\n]/g, ''); } }) } return items.map(item => { var newItem; if (typeof item === "object" && ('text' in item)) { newItem = Object.assign({}, item); } else { newItem = { text: item + '', value: item } } if (item.items) { newItem.items = copySelectionItemArray(item.items, opt); } return newItem; }); } function compareSelectionItemArray(a, b) { if (a === b) return true; var aEmpty = !a || !a.length; var bEmpty = !b || !b.length; if (!aEmpty && aEmpty === bEmpty) return true; if (aEmpty !== bEmpty) return false; if (a.length !== b.length) return false; var n = a.length; var ait, bit; for (var i = 0; i < n; ++i) { ait = a[i]; bit = b[i]; if (ait === bit) continue; if (ait.text !== bit.text) return false; if (ait.text !== bit.text) return false; if (!compareSelectionItemArray(ait.items, bit.items)) return false; } return true; } /*** * * @param {AElement|HTMLElement} element * @param {number} padding */ function isScrolledToBottom(element, padding) { if (!isRealNumber(padding)) padding = 0; return (element.scrollHeight - element.scrollTop - padding <= element.clientHeight); } /** * parse a DMS string into latitude and longitude from google maps * @param {string} input * @returns {{latitude: number, longitude: number}|null} */ function parseDMS(input) { input = input.trim(); var regex = /([+-]?\d+)°(\d+)'([\d.]+)"([NS])\s*,?\s*([+-]?\d+)°(\d+)'([\d.]+)"([EW])/; var match = input.match(regex); if (!match) { return null; } var [, latDeg, latMin, latSec, latDir, lngDeg, lngMin, lngSec, lngDir] = match; // Convert DMS to decimal var lat = (parseInt(latDeg) + parseInt(latMin) / 60 + parseFloat(latSec) / 3600) * (latDir === "N" ? 1 : -1); var lng = (parseInt(lngDeg) + parseInt(lngMin) / 60 + parseFloat(lngSec) / 3600) * (lngDir === "E" ? 1 : -1); return { latitude: lat, longitude: lng }; } function parseLatLng(value) { value = value.trim(); value = value.replace(/(^\(\s*)|(\s*\)*)/g, ''); var nums = value.split(/\s*,\s*/); if (nums.length !== 2) return null; nums = nums.map((t) => { return parseFloat(t); }); if (isRealNumber(nums[0]) && isRealNumber(nums[1])) { return { latitude: nums[0], longitude: nums[1] }; } return null; } function normalizeLatLngString(text) { var latLgn = parseDMS(text) || parseLatLng(text); var lat, lng; if (latLgn) { lat = latLgn.latitude; lng = latLgn.longitude; lat = Math.max(-90, Math.min(90, lat)); if (lng < 180 && lng > 180) lng = (lng + 180 + 360 * Math.ceil(Math.abs(lng) / 360 + 2)) % 360 - 180; return [lat, lng].join(', '); } else return ''; } function implicitLatLng(value) { var latlng = null; var nums; if (typeof value === "string") { latlng = parseDMS(value); if (latlng) { latlng = new google.maps.LatLng(latlng.latitude, latlng.longitude); } else { latlng = parseLatLng(value); if (latlng) { } nums = value.split(/\s*,\s*/).map(function (t) { return parseFloat(t); }); if (isRealNumber(nums[0]) && isRealNumber(nums[1])) { latlng = new google.maps.LatLng(nums[0], nums[1]); } } } else if (value instanceof google.maps.LatLng) { latlng = value; } else if (value && isRealNumber(value.latitude) && isRealNumber(value.longitude)) { latlng = new google.maps.LatLng(value.latitude, value.longitude); } else if (value && isRealNumber(value.lat) && isRealNumber(value.lng)) { latlng = new google.maps.LatLng(value.lat, value.lng); } else if ((value instanceof Array) && isRealNumber(value[0]) && isRealNumber(value[1])) { latlng = new google.maps.LatLng(value[0], value[1]); } return latlng; } function getMapZoomLevel(mapDim, bounds) { var WORLD_DIM = { height: 256, width: 256 }; var ZOOM_MAX = 21; function latRad(lat) { var sin = Math.sin(lat * Math.PI / 180); var radX2 = Math.log((1 + sin) / (1 - sin)) / 2; return Math.max(Math.min(radX2, Math.PI), -Math.PI) / 2; } function zoom(mapPx, worldPx, fraction) { return Math.floor(Math.log(mapPx / worldPx / fraction) / Math.LN2); } if (!bounds) return 17; if (!mapDim) return 17; var ne = bounds.getNorthEast(); var sw = bounds.getSouthWest(); if (!ne || !ne.lat) return 17; if (!sw || !sw.lat) return 17; var latFraction = (latRad(ne.lat()) - latRad(sw.lat())) / Math.PI; var lngDiff = ne.lng() - sw.lng(); var lngFraction = ((lngDiff < 0) ? (lngDiff + 360) : lngDiff) / 360; var latZoom = zoom(mapDim.height, WORLD_DIM.height, latFraction); var lngZoom = zoom(mapDim.width, WORLD_DIM.width, lngFraction); return Math.min(latZoom, lngZoom, ZOOM_MAX); } /*** * * @param p0 * @param p1 * @returns {number} */ function latLngDistance(p0, p1) { var lat0 = p0.lat(); var lat1 = p1.lat(); var lng0 = p0.lng(); var lng1 = p1.lng(); var toRad = function (value) { return value * Math.PI / 180; }; var R = 6371; var dLat = toRad(lat1 - lat0); var dLng = toRad(lng1 - lng0); lat0 = toRad(lat0); lat1 = toRad(lat1); var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.sin(dLng / 2) * Math.sin(dLng / 2) * Math.cos(lat0) * Math.cos(lat1); var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); var d = R * c; return d; } function keyStringOf(o) { var type = typeof o; var keys; if (o && type === "object") { if (typeof o.getTime === "function") { return 'd(' + o.getTime() + ')'; } else if (typeof o.map === "function") { return 'a(' + o.map(val => keyStringOf(val)).join(',') + ')'; } else { keys = Object.keys(o); keys.sort(); return 'o(' + keys.map(key => key + ':' + keyStringOf(o[key])).join(',') + ')'; } } else { return type[0] + '(' + o + ')'; } } function jsStringOf(x) { if (x === null) return 'null'; if (x === undefined) return 'undefined'; var type = typeof x; if (type === 'string' || type === 'number') return JSON.stringify(x); if (x instanceof Date) return 'new Date(' + x.getTime() + ')'; var keys; keys = Object.keys(x); keys.sort(); return '{' + keys.map(function (key) { return JSON.stringify(key) + ':' + jsStringOf(x[key]); }).join(',') + '}'; } function calcDTQueryHash(o) { var s = jsStringOf(o); return (0,absol_src_String_stringUtils__WEBPACK_IMPORTED_MODULE_8__/* .stringHashCode */ .$)(s); } function replaceInObject(o, replacer, test) { return new Promise((rs) => { var sync = []; function visit(so) { Object.keys(so).forEach((key) => { var newValue; if (test(so[key])) { newValue = replacer(so[key], key, so); if (newValue && newValue.then) { sync.push(newValue); newValue.then(newValue => so[key] = newValue); } else { so[key] = newValue; } } else if (typeof so[key] === "object" && so[key]) { visit(so[key]); } }); } visit(o); Promise.all(sync).then(() => { rs(o); }) }); } function replaceFileInObject(o, replacer) { return replaceInObject(o, replacer, (value, key, object) => { return (value instanceof File) || (value instanceof Blob); }); } function isNone(x) { return x === null || x === undefined; } var measureTool = new _tool_TextMeasurement__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z(); function wrapWord(text, width, font) { font = font || '14px arial'; measureTool.compute(font); var res = []; var i = 1; var prevText = ''; var curText; while (text.length > 0) { if (i > text.length && text) { res.push(text); break; } curText = text.substring(0, i); if (measureTool.measureTextWidth(curText, font) <= width || !prevText) { prevText = curText; } else { text = text.substring(prevText.length).trimStart(); res.push(prevText); prevText = ''; i = 1; continue; } ++i; } return res; } function wrapText(text, width, font) { font = font || '14px arial'; measureTool.compute(font); var res = []; var i = 1; var prevText = ''; var prevWidth = 0; var curText, curWidth; while (text.length > 0) { if (i > text.length && text) { prevText = text; prevWidth = measureTool.measureTextWidth(prevText, font); if (prevWidth <= width) { res.push(prevText); } else { res.push.apply(res, wrapWord(prevText, width, font)); } break; } if (!text[i - 1].match(/[\s\n]/) && (!text[i] || text[i].match(/[\s\n]/))) { curText = text.substring(0, i); curWidth = measureTool.measureTextWidth(curText, font); if (curWidth <= width || !prevText) { prevText = curText; prevWidth = curWidth; } else { if (prevWidth <= width) { res.push(prevText); } else { prevText = wrapWord(prevText, width, font).shift(); res.push(prevText); } text = text.substring(prevText.length).trimStart(); prevText = ''; i = 1; continue; } } ++i; } return res; } var listenMethodNames = ['appendChild', 'insertBefore', 'addStyle', 'removeStyle', 'removeChild', 'remove']; var originalMethodNames = listenMethodNames.map(x => 'original_' + x); function listenDomContentChange(elt, callback) { function emit(name, event) { if (!callback) return; if (name === 'change') { if (typeof callback === "function") callback(event); else if (callback.change) { callback.change(event); } } else if (typeof callback[name] === "function") callback[name](event); } var overrideMethods = listenMethodNames.map((name, i) => { if (i < 2) { return function (child) { var res = this[originalMethodNames[i]].apply(this, arguments); addHook(child); emit('change', { target: this, method: name, args: Array.prototype.slice.call(arguments) }) return res; } } else if (i < 4) { return function () { var res = this[originalMethodNames[i]].apply(this, arguments); if (arguments[0] === 'display') emit('change', { target: this, method: name, args: Array.prototype.slice.call(arguments) }); return res; } } else if (i < 5) { return function (child) { var res = this[originalMethodNames[i]].apply(this, arguments); removeHook(child); emit('change', { target: this, method: name, args: Array.prototype.slice.call(arguments) }); return res; } } else { return function () { var res = this[originalMethodNames[i]].apply(this, arguments); removeHook(this); emit('change', { target: this, method: name, args: Array.prototype.slice.call(arguments) }); return res; } } }); /** * * @param {HTMLElement|AElement|Node} child */ var addHook = (child) => { if (!child) return; if (child.nodeType !== Node.ELEMENT_NODE) return; if (child.domHooked) return; child.domHooked = true; var i; var ln; for (i = 0; i < listenMethodNames.length; ++i) { ln = listenMethodNames[i]; if (!absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_7__/* ["default"].prototype */ .Z.prototype[ln] || absol_src_HTML5_AElement__WEBPACK_IMPORTED_MODULE_7__/* ["default"].prototype */ .Z.prototype[ln] === child[ln]) { child[originalMethodNames[i]] = child[ln]; child[ln] = overrideMethods[i]; } } if (callback && callback.scrollIntoView) { child.scrollIntoView1 = child.scrollIntoView; child.scrollIntoView = function () { emit('scrollIntoView', { target: this, method: name, args: Array.prototype.slice.call(arguments) }); }; } if (!child._azar_extendTags || Object.keys(child._azar_extendTags).length === 0) { for (i = 0; i < child.childNodes.length; ++i) addHook(child.childNodes[i]); } } var removeHook = (child) => { if (!child) return; if (child.nodeType !== Node.ELEMENT_NODE) return; if (!child.domHooked) return; delete child.domHooked; var i; for (i = 0; i < listenMethodNames.length; ++i) { if (child[originalMethodNames[i]]) { child[listenMethodNames[i]] = child[originalMethodNames[i]]; delete child[originalMethodNames[i]]; } } if (child.scrollIntoView1) { child.scrollIntoView = child.scrollIntoView1; delete child.scrollIntoView1; } for (i = 0; i < child.childNodes.length; ++i) removeHook(child.childNodes[i]); } addHook(elt); } var mdiLoadSync; function getMaterialDesignIconNames() { if (mdiLoadSync) return mdiLoadSync; mdiLoadSync = fetch('https://absol.cf/vendor/materialdesignicons/materialdesignicons.css') .then(res => res.text()).then(text => { var regex = /\.mdi-([^:]+)::before/g; var iconNames = []; var iconNameMatch; do { iconNameMatch = regex.exec(text); if (iconNameMatch) iconNames.push(iconNameMatch[1]); } while (iconNameMatch); return iconNames; }).catch(err => { mdiLoadSync = null; }); return mdiLoadSync; } /***/ }), /***/ 2243: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function CMDRunner(_this, commands) { this._this = _this; this.commands = {}; this.assign(commands); } CMDRunner.prototype.has = function (cmdName) { return !!this.commands[cmdName]; }; CMDRunner.prototype.add = function (cmdName, handler) { this.commands[cmdName] = handler; return this; }; CMDRunner.prototype.remove = function (cmdName) { delete this.commands[cmdName]; return this; }; CMDRunner.prototype.assign = function (obj) { for (var cmdName in obj) { if (typeof obj[cmdName] == 'function') { this.add(cmdName, obj[cmdName]); } } }; CMDRunner.prototype.invoke = function () { if (this.commands[arguments[0]]) { var args = Array.prototype.slice.call(arguments, 1); return this.commands[arguments[0]].apply(this._this, args); } else { throw new Error('No command: ' + arguments[0]); } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (CMDRunner); /***/ }), /***/ 5721: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _Code_noop__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1432); function Context() { /**** * * @type {"CREATE"|"PAUSE"|"RUNNING"|"STANDBY"|"DIE"|"STOP"} */ this.state = "CREATE"; /** * @type {Context} */ this.parent = null; /*** * * @type {null|ContextManager} */ this.ctxMng = null; } /** * @returns {*} */ Context.prototype.getContext = function (key) { var ctx = this; var res; while (ctx && !res){ if (ctx.ctxMng) { res = ctx.ctxMng.get(key); } ctx = ctx.parent; } return res; }; /** * @param {string} key * @param {*} value * @returns {*} */ Context.prototype.setContext = function (key, value) { return this.getContextManager().set(key, value); }; /** * @returns {ContextManager} */ Context.prototype.getContextManager = function () { var ctx = this; var res; while (ctx && !res){ if (ctx.ctxMng) { res = ctx.ctxMng; } ctx = ctx.parent; } return res; }; /** * @param {Context} parent */ Context.prototype.attach = function (parent) { //stop before attach to new context this.stop(); /** * @type {Application} */ this.parent = parent; this.onAttached && this.onAttached(); }; Context.prototype.detach = function () { this.stop(); this.onDetached && this.onDetached(); this.parent = null; }; Context.prototype.pause = function () { if (this.state.match(/RUNNING|PAUSE/)) { if (this.state === "RUNNING"){ this.state = "PAUSE"; this.onPause && this.onPause(); } } else { // console.warn(this, "NOT RUNNING"); } }; Context.prototype.resume = function () { if (!this.state.match(/STANDBY|PAUSE|RUNNING/)) { // console.warn(this, 'NOT READY!', this.state); return; } if (this.state === "RUNNING") return; this.state = "RUNNING"; this.onResume && this.onResume(); }; /*** * @param {boolean=} standBy start but waiting for resume() */ Context.prototype.start = function (standBy) { if (this.state.match(/DIE/)) { // console.warn(this, 'DIED!'); return; } if (this.state.match(/RUNNING/)) return; if (this.state.match(/STOP|CREATE/)) { this.state = "STANDBY"; this.onStart && this.onStart(); } if (!standBy && this.state.match(/STANDBY|PAUSE/)) { this.resume(); } }; Context.prototype.stop = function () { if (this.state.match(/STOP|DIE|CREATE/)) return; if (this.state.match(/RUNNING/)) this.pause(); this.state = "STOP"; this.onStop && this.onStop(); }; Context.prototype.destroy = function () { if (this.state.match(/DIE/)) return; if (this.state.match(/RUNNING|PAUSE/)) this.stop(); this.state = "DIE"; this.onDestroy && this.onDestroy(); }; Context.prototype.onDestroy = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onStop = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onStart = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onResume = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onPause = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onDetached = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; Context.prototype.onAttached = _Code_noop__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Context); /***/ }), /***/ 6372: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function ContextManager(){ this.__contextData__ = {}; } /** * @param {String} key * @returns {*} */ ContextManager.prototype.get = function(key){ return this.__contextData__[key]; }; /** * @param {String} key * @param {*} value * @returns {Context} */ ContextManager.prototype.set = function(key, value){ this.__contextData__[key] = value; return this; }; ContextManager.prototype.assign = function(obj){ Object.assign(this.__contextData__, obj); return this; }; ContextManager.prototype.remove = function(key){ delete this.__contextData__[key]; return this; }; ContextManager.prototype.contains = function(key){ return (key in this.__contextData__); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ContextManager); /***/ }), /***/ 4861: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ AppPattern_Fragment) }); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/ContextManager.js var ContextManager = __webpack_require__(6372); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Context.js var Context = __webpack_require__(5721); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/GrandContext.js /*** * @extends Context * @constructor */ function GrandContext(){ Context/* default.call */.Z.call(this); this.ctxMng = new ContextManager/* default */.Z(); } OOP/* default.mixClass */.ZP.mixClass(GrandContext, Context/* default */.Z); /* harmony default export */ const AppPattern_GrandContext = (GrandContext); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/Fragment.js /*** * @extends GrandContext * @constructor */ function Fragment() { AppPattern_GrandContext.call(this); } OOP/* default.mixClass */.ZP.mixClass(Fragment, AppPattern_GrandContext); Fragment.prototype.createView = function () { throw new Error("Not implement!"); }; Fragment.prototype.getView = function () { if (this.$view) return this.$view; this.$view = this.createView() || this.$view; if (!this.$view) throw new Error("this.$view must be not null!"); if (this.onCreated) this.onCreated(); return this.$view; }; Fragment.prototype.onCreated = noop/* default */.Z; Fragment.prototype.revokeResource = function () { this.destroy(); }; /* harmony default export */ const AppPattern_Fragment = (Fragment); /***/ }), /***/ 4446: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /*** * * @param {T} value * @param {*=} type * @constructor * @template T */ function Ref(value, type) { this.type = type; this.value = value; } Ref.prototype.toString = function () { return this.value + ''; }; /*** * * @return {T} */ Ref.prototype.valueOf = function () { return this.value; }; /*** * * @param {T}value */ Ref.prototype.set = function (value) { this.value = value; }; /** * * @return {T} */ Ref.prototype.get = function () { return this.value; } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Ref); /***/ }), /***/ 1312: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function VarScope(parent) { this.parent = parent; this.data = {}; } VarScope.prototype.revoke = function (name) { delete this.data[name]; return this; }; VarScope.prototype.isDeclared = function (name) { return (name in this.data); }; /*** * * @param name * @param initValue * @param {boolean=} force * @return {VarScope} */ VarScope.prototype.declare = function (name, initValue, force) { if ((name in this.data) && !force) throw new Error(name + ' is already delared in this scope!'); this.data[name] = initValue; return this; }; VarScope.prototype.get = function (name) { var scope = this.findScope(name); if (!scope) throw new Error(name + ' is not declared!'); return scope.data[name]; }; VarScope.prototype.set = function (name, value) { var scope = this.findScope(name); if (!scope) throw new Error(name + ' is not declared!'); scope.data[name] = value; }; VarScope.prototype.findScope = function (name) { var currentScope = this; while (currentScope) { if (name in currentScope.data) break; currentScope = currentScope.parent; } return currentScope; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (VarScope); /***/ }), /***/ 1432: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (/* binding */ noop) /* harmony export */ }); function noop(){}; /***/ }), /***/ 5650: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (/* binding */ safeThrow) /* harmony export */ }); function safeThrow(error) { var func = function () { if (error.stack) { try { error.message += '\n' + error.stack; } catch (e){ //can not modify message } } throw error; } if (window.Thread && window.Thread.setTimeout) { window.Thread.setTimeout({ func: func, time: 1, type: 'background', args: [], stack: error.stack || "" }); } else { setTimeout(func, 1); } } /***/ }), /***/ 257: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _JSMaker_TemplateString__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(369); function Color(rgba) { this.rgba = rgba.slice(); } /*** * * @returns {string} */ Color.prototype.toHex6 = function () { return this.rgba.slice(0, 3).map(function (b) { b = b * 255 >> 0; return (b < 16 ? '0' : '') + b.toString(16); }).join(''); }; /*** * * @returns {string} */ Color.prototype.toHex8 = function () { return this.rgba.map(function (b) { b = b * 255 >> 0; return (b < 16 ? '0' : '') + b.toString(16); }).join(''); }; /*** * * @returns {string} */ Color.prototype.toHex3 = function () { return this.rgba.slice(0, 3).map(function (b) { b = b * 255 / 17 >> 0; return b.toString(16); }).join(''); }; /*** * * @returns {string} */ Color.prototype.toHex4 = function () { return this.rgba.map(function (b) { b = b * 255 / 17 >> 0; return b.toString(16); }).join(''); }; /*** * * @returns {number[]} */ Color.prototype.toHSLA = function () { return Color.rgbaToHSLA(this.rgba); }; /*** * * @returns {number[]} */ Color.prototype.toHSBA = function () { return Color.rgbaToHSBA(this.rgba); }; /*** * * @returns {number[]} */ Color.prototype.toHWBA = function () { return Color.rgbaToHWBA(this.rgba); }; /*** * * @returns {number[]} */ Color.prototype.toCMYK = function () { return Color.rgbToCMYK(this.rgba); }; /*** * * @returns {Color} */ Color.prototype.getHighContrastColor = function () { var hsba = this.toHSBA(); var h, s, b; h = hsba[0] > 0.5 ? hsba[0] - 0.5 : hsba[0] + 0.5; s = hsba[1] > 0.5 ? hsba[1] - 0.5 : hsba[1] + 0.5; b = hsba[2] > 0.5 ? hsba[2] - 0.5 : hsba[2] + 0.5; return Color.fromHSB(h, s, b); }; Color.prototype.getHightContrastColor = Color.prototype.getHighContrastColor; Color.prototype.getLuminance = function () { var a = this.rgba.slice(0, 3).map(function (v) { return v <= 0.03928 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4); }); return a[0] * 0.2126 + a[1] * 0.7152 + a[2] * 0.0722; }; /*** * * @param {Color} other * @returns {number} */ Color.prototype.getContrastWith = function (other) { var lum1 = this.getLuminance(); var lum2 = other.getLuminance(); var brightest = Math.max(lum1, lum2); var darkest = Math.min(lum1, lum2); return (brightest + 0.05) / (darkest + 0.05); }; /*** * * @returns {Color} */ Color.prototype.getContrastYIQ = function () { var r = this.rgba[0] * 255; var g = this.rgba[1] * 255; var b = this.rgba[2] * 255; var yiq = ((r * 299) + (g * 587) + (b * 114)) / 1000; return (yiq >= 128) ? new Color([0, 0, 0, 1]) : new Color([1, 1, 1, 1]); }; /** * * @returns {Color} */ Color.prototype.clone = function () { return new Color(this.rgba.slice()); }; /** * * ['rgba', 'rgba', 'rgba({{x[0]*255>>0}}, {{x[1]*255>>0}}, {{x[2]*255>>0}}, {{x[3]}})'], * ['rgb', 'rgba', 'rgb({{x[0]*255>>0}}, {{x[1]*255>>0}}, {{x[2]*255>>0}})'], * ['hsl', 'toHSLA()', 'hsl({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], * ['hsla', 'toHSLA()', 'hsla({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'], * ['hsb', 'toHSBA()', 'hsb({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], * ['hsba', 'toHSBA()', 'hsba({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'], * ['hex3', 'toHex3()', '#{{x}}'], * ['hex4', 'toHex4()', '#{{x}}'], * ['hex6', 'toHex6()', '#{{x}}'], * ['hex6', 'toHex8()', '#{{x}}'], * ['hwb', 'toHWBA()', 'hwb({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], * ['hwba', 'toHWBA()', 'hwba({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'] * ['cmyk', 'toCMYK()', 'hwba({{x[0] * 100%}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'] */ /**** * * @param {"rgba"|"rgb"|"hsl"|"hsla"|"hsb"|"hsba"|"hex3"|"hex4"|"hex6"|"hex6"|hex8|"hwb"|"hwba"} mode * @returns {string} */ Color.prototype.toString = function (mode) { mode = mode || 'rgba'; mode = mode.toLocaleLowerCase(); return Color.templates[mode](this); }; /*** * * @param notStandard * @param {number[]} hsbWeight * @returns {Color} */ Color.prototype.nearestNamedColor = function (notStandard, hsbWeight) { hsbWeight = hsbWeight || [5, 3, 1] var hsba = this.toHSBA(); var bestMatch = null; var dist = 1000; Object.keys(Color.namedColors).concat(notStandard ? Object.keys(Color.nonStandarNamedColors) : []).forEach(function (name) { var c = Color.parse(Color.namedColors[name] || Color.nonStandarNamedColors[name]); var cHSBA = c.toHSBA(); var cDist = Math.abs(hsba[0] - cHSBA[0]) * hsbWeight[0] + Math.abs(hsba[1] - cHSBA[1]) * hsbWeight[1] + Math.abs(hsba[2] - cHSBA[2]) * hsbWeight[2]; if (cDist < dist) { dist = cDist; bestMatch = name; } }); return bestMatch; }; Color.templates = [ ['rgba', 'rgba', 'rgba({{x[0]*255>>0}}, {{x[1]*255>>0}}, {{x[2]*255>>0}}, {{x[3]}})'], ['rgb', 'rgba', 'rgb({{x[0]*255>>0}}, {{x[1]*255>>0}}, {{x[2]*255>>0}})'], ['hsl', 'toHSLA()', 'hsl({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], ['hsla', 'toHSLA()', 'hsla({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'], ['hsb', 'toHSBA()', 'hsb({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], ['hsba', 'toHSBA()', 'hsba({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'], ['hex3', 'toHex3()', '#{{x}}'], ['hex4', 'toHex4()', '#{{x}}'], ['hex6', 'toHex6()', '#{{x}}'], ['hex8', 'toHex8()', '#{{x}}'], ['hwb', 'toHWBA()', 'hwb({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%)'], ['hwba', 'toHWBA()', 'hwba({{x[0] * 360}}, {{x[1] * 100}}%, {{x[2] * 100}}%, {{x[3]}})'], ['cmyk', 'toCMYK()', 'cmyk({{x[0] * 100}}%, {{x[1] * 100}}%, {{x[2] * 100}}%)'] ].reduce(function (ac, cr) { ac[cr[0]] = new Function('color', [ 'var x = color.' + cr[1] + ';', 'return ' + _JSMaker_TemplateString__WEBPACK_IMPORTED_MODULE_0__/* ["default"].parse */ .Z.parse(cr[2]).toJSCode() + ';' ].join('\n')); return ac; }, {}); Color.regexes = { whiteSpace: /\s*/, // Match zero or more whitespace characters. integer: /(\d{1,3})/, // Match integers: 79, 255, etc. decimal: /((?:\d+(?:\.\d+)?)|(?:\.\d+))/, // Match 129.6, 79, .9, etc. percent: /((?:\d+(?:\.\d+)?)|(?:\.\d+))%/, // Match 12.9%, 79%, .9%, etc. hex3: /^#([a-f0-9])([a-f0-9])([a-f0-9])$/i, // Match colors in format #XXXX, e.g. #5123. hex4: /^#([a-f0-9])([a-f0-9])([a-f0-9])([a-f0-9])$/i, // Match colors in format #XXXXXX, e.g. #b4d455. hex6: /^#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})$/i, // Match colors in format #XXXXXXXX, e.g. #b4d45535. hex8: /^#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})$/i }; Color.regexes.percent = new RegExp(Color.regexes.decimal.source + '%'); Color.regexes.rgb = new RegExp( [ '^rgb\\(', Color.regexes.integer.source, ',', Color.regexes.integer.source, ',', Color.regexes.integer.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); Color.regexes.rgbPercent = new RegExp( [ '^rgb\\(', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format rgb(R, G, B, A), e.g. rgb(255, 0, 128, 0.25). Color.regexes.rgba = new RegExp( [ '^rgba\\(', Color.regexes.integer.source, ',', Color.regexes.integer.source, ',', Color.regexes.integer.source, ',', Color.regexes.decimal.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format rgb(R%, G%, B%, A), e.g. rgb(100%, 0%, 28.9%, 0.5). Color.regexes.rgbaPercent = new RegExp( [ '^rgba\\(', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.decimal.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format hsla(H, S%, L%), e.g. hsl(100, 40%, 28.9%). Color.regexes.hsl = new RegExp( [ '^hsl\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format hsla(H, S%, L%, A), e.g. hsla(100, 40%, 28.9%, 0.5). Color.regexes.hsla = new RegExp( [ '^hsla\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.decimal.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format hsb(H, S%, B%), e.g. hsb(100, 40%, 28.9%). Color.regexes.hsb = new RegExp( [ '^hsb\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format hsba(H, S%, B%, A), e.g. hsba(100, 40%, 28.9%, 0.5). Color.regexes.hsba = new RegExp( [ '^hsba\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.decimal.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); Color.regexes.hwb = new RegExp( [ '^hwb\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); // Match colors in format hsba(H, S%, B%, A), e.g. hsba(100, 40%, 28.9%, 0.5). Color.regexes.hwba = new RegExp( [ '^hwba\\(', Color.regexes.integer.source, '[deg]*', ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.decimal.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); Color.regexes.cmyk = new RegExp( [ '^cmyk\\(', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, ',', Color.regexes.percent.source, '\\)$' ].join(Color.regexes.whiteSpace.source), 'i' ); /*** * * @param {number} code * @param {32|24|16|8} bits * @returns {Color} */ Color.fromInt = function (code, bits) { var r, g, b, a; if (bits == 32) { b = (code & 0xff) / 255; g = ((code & 0xff00) >> 8) / 255; r = ((code & 0xff0000) >> 16) / 255; a = (code >> 24) / 255; } else if (bits == 24) { b = (code & 0xff) / 255; g = ((code & 0xff00) >> 8) / 255; r = ((code & 0xff0000) >> 16) / 255; a = 1; } else if (bits == 16) { b = (code & 0x1f) / 0x1f; g = ((code & 0x7e0) >> 5) / 0x3f; b = (code >> 10) / 0x1f; a = 1; } else if (bits == 8) {//gray-scale b = (code & 0x3) / 0x3; g = ((code & 0x1c) >> 2) / 0x7; b = (code >> 5) / 0x7; a = 1; } return new Color([r, g, b, a]); }; /** * * @param {number} r * @param {number} g * @param {number} b * @returns {Color} */ Color.fromRGB = function (r, g, b) { return new Color([r, g, b, 1]); }; /** * * @param {number} r * @param {number} g * @param {number} b * @param {number} a * @returns {Color} */ Color.fromRGBA = function (r, g, b, a) { return new Color([r, g, b, a]); }; /*** * * @param {number} h * @param {number} s * @param {number} l * @returns {Color} */ Color.fromHSL = function (h, s, l) { var rgba = this.hslaToRGBA([h, s, l, 1]); return new Color(rgba); }; /*** * * @param {number} h * @param {number} s * @param {number} l * @param {number} a * @returns {Color} */ Color.fromHSLA = function (h, s, l, a) { var rgba = this.hslaToRGBA([h, s, l, a]); return new Color(rgba); }; /*** * * @param {number} h * @param {number} s * @param {number} b * @returns {Color} */ Color.fromHSB = function (h, s, b) { var rgba = this.hsbaToRGBA([h, s, b, 1]); return new Color(rgba); }; /*** * * @param {number} h * @param {number} s * @param {number} b * @param {number} a * @returns {Color} */ Color.fromHSBA = function (h, s, b, a) { var rgba = this.hsbaToRGBA([h, s, b, a]); return new Color(rgba); }; /*** * * @param {number} h * @param {number} s * @param {number} b * @returns {Color} */ Color.fromHWB = function (h, s, b) { var rgba = this.hwbaToRGBA([h, s, b, 1]); return new Color(rgba); }; /*** * * @param {number} h * @param {number} s * @param {number} b * @param {number} a * @returns {Color} */ Color.fromHWBA = function (h, s, b, a) { var rgba = this.hwbaToRGBA([h, s, b, a]); return new Color(rgba); }; Color.fromCMYK = function (c, m, y, k) { var rgba = this.cmykToRGB([c, m, y, k]).concat([0]); return new Color(rgba); }; /** * @param {String} text * @returns {Color} */ Color.parse = function (text) { if (this.namedColors[text]) text = this.namedColors[text]; if (this.nonStandarNamedColors[text]) text = this.nonStandarNamedColors[text]; if (this.regexes.hex8.test(text)) { return this.fromRGBA.apply(this, this.regexes.hex8.exec(text) .slice(1) .map(function (v) { return parseInt(v, 16) / 255; })); } else if (this.regexes.hex6.test(text)) { return this.fromRGB.apply(this, this.regexes.hex6.exec(text) .slice(1) .map(function (v) { return parseInt(v, 16) / 255; })); } else if (this.regexes.hex4.test(text)) { return this.fromRGBA.apply(this, this.regexes.hex4.exec(text) .slice(1) .map(function (v) { return parseInt(v + v, 16) / 255; })); } else if (this.regexes.hex3.test(text)) { return this.fromRGB.apply(this, this.regexes.hex3.exec(text) .slice(1) .map(function (v) { return parseInt(v + v, 16) / 255; })); } else if (this.regexes.rgba.test(text)) { return this.fromRGBA.apply(this, this.regexes.rgba.exec(text) .slice(1) .map(function (v, i) { return i < 3 ? parseFloat(v) / 255 : parseFloat(v); })); } else if (this.regexes.rgb.test(text)) { return this.fromRGB.apply(this, this.regexes.rgb.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / 255; })); } else if (this.regexes.rgbPercent.test(text)) { return this.fromRGB.apply(this, this.regexes.rgbPercent.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / 100; })); } else if (this.regexes.rgbaPercent.test(text)) { return this.fromRGBA.apply(this, this.regexes.rgbaPercent.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i < 3 ? 100 : 1); })); } else if (this.regexes.hsl.test(text)) { return this.fromHSL.apply(this, this.regexes.hsl.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : 100); })); } else if (this.regexes.hsla.test(text)) { return this.fromHSLA.apply(this, this.regexes.hsla.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : i < 3 ? 100 : 1); })); } else if (this.regexes.hsb.test(text)) { return this.fromHSB.apply(this, this.regexes.hsb.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : 100); })); } else if (this.regexes.hsba.test(text)) { return this.fromHSBA.apply(this, this.regexes.hsba.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : i < 3 ? 100 : 1); })); } else if (this.regexes.hwb.test(text)) { return this.fromHWB.apply(this, this.regexes.hwb.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : 100); })); } else if (this.regexes.hwba.test(text)) { return this.fromHWBA.apply(this, this.regexes.hwba.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) / (i == 0 ? 360 : i < 3 ? 100 : 1); })); } else if (this.regexes.cmyk.test(text)) { return this.fromCMYK.apply(this, this.regexes.cmyk.exec(text) .slice(1) .map(function (v, i) { return parseFloat(v) /100; })); } else { throw new Error("Fail to parse " + text); } }; /*** * @typedef {"aliceblue"|"antiquewhite"|"aqua"|"aquamarine"|"azure"|"beige"|"bisque"|"black"|"blanchedalmond"|"blue"|"blueviolet"|"brown"|"burlywood"|"cadetblue"|"chartreuse"|"chocolate"|"coral"|"cornflowerblue"|"cornsilk"|"crimson"|"cyan"|"darkblue"|"darkcyan"|"darkgoldenrod"|"darkgray"|"darkgreen"|"darkgrey"|"darkkhaki"|"darkmagenta"|"darkolivegreen"|"darkorange"|"darkorchid"|"darkred"|"darksalmon"|"darkseagreen"|"darkslateblue"|"darkslategray"|"darkslategrey"|"darkturquoise"|"darkviolet"|"deeppink"|"deepskyblue"|"dimgray"|"dimgrey"|"dodgerblue"|"firebrick"|"floralwhite"|"forestgreen"|"fuchsia"|"gainsboro"|"ghostwhite"|"gold"|"goldenrod"|"gray"|"green"|"greenyellow"|"grey"|"honeydew"|"hotpink"|"indianred"|"indigo"|"ivory"|"khaki"|"lavender"|"lavenderblush"|"lawngreen"|"lemonchiffon"|"lightblue"|"lightcoral"|"lightcyan"|"lightgoldenrodyellow"|"lightgray"|"lightgreen"|"lightgrey"|"lightpink"|"lightsalmon"|"lightseagreen"|"lightskyblue"|"lightslategray"|"lightslategrey"|"lightsteelblue"|"lightyellow"|"lime"|"limegreen"|"linen"|"magenta"|"maroon"|"mediumaquamarine"|"mediumblue"|"mediumorchid"|"mediumpurple"|"mediumseagreen"|"mediumslateblue"|"mediumspringgreen"|"mediumturquoise"|"mediumvioletred"|"midnightblue"|"mintcream"|"mistyrose"|"moccasin"|"navajowhite"|"navy"|"oldlace"|"olive"|"olivedrab"|"orange"|"orangered"|"orchid"|"palegoldenrod"|"palegreen"|"paleturquoise"|"palevioletred"|"papayawhip"|"peachpuff"|"peru"|"pink"|"plum"|"powderblue"|"purple"|"red"|"rosybrown"|"royalblue"|"saddlebrown"|"salmon"|"sandybrown"|"seagreen"|"seashell"|"sienna"|"silver"|"skyblue"|"slateblue"|"slategray"|"slategrey"|"snow"|"springgreen"|"steelblue"|"tan"|"teal"|"thistle"|"tomato"|"turquoise"|"violet"|"wheat"|"white"|"whitesmoke"|"yellow"|"yellowgreen"|"transparent"} NamedColor */ Color.namedColors = { aliceblue: '#f0f8ff', antiquewhite: '#faebd7', aqua: '#00ffff', aquamarine: '#7fffd4', azure: '#f0ffff', beige: '#f5f5dc', bisque: '#ffe4c4', black: '#000000', blanchedalmond: '#ffebcd', blue: '#0000ff', blueviolet: '#8a2be2', brown: '#a52a2a', burlywood: '#deb887', cadetblue: '#5f9ea0', chartreuse: '#7fff00', chocolate: '#d2691e', coral: '#ff7f50', cornflowerblue: '#6495ed', cornsilk: '#fff8dc', crimson: '#dc143c', cyan: '#00ffff', darkblue: '#00008b', darkcyan: '#008b8b', darkgoldenrod: '#b8860b', darkgray: '#a9a9a9', darkgreen: '#006400', darkgrey: '#a9a9a9', darkkhaki: '#bdb76b', darkmagenta: '#8b008b', darkolivegreen: '#556b2f', darkorange: '#ff8c00', darkorchid: '#9932cc', darkred: '#8b0000', darksalmon: '#e9967a', darkseagreen: '#8fbc8f', darkslateblue: '#483d8b', darkslategray: '#2f4f4f', darkslategrey: '#2f4f4f', darkturquoise: '#00ced1', darkviolet: '#9400d3', deeppink: '#ff1493', deepskyblue: '#00bfff', dimgray: '#696969', dimgrey: '#696969', dodgerblue: '#1e90ff', firebrick: '#b22222', floralwhite: '#fffaf0', forestgreen: '#228b22', fuchsia: '#ff00ff', gainsboro: '#dcdcdc', ghostwhite: '#f8f8ff', gold: '#ffd700', goldenrod: '#daa520', gray: '#808080', green: '#008000', greenyellow: '#adff2f', grey: '#808080', honeydew: '#f0fff0', hotpink: '#ff69b4', indianred: '#cd5c5c', indigo: '#4b0082', ivory: '#fffff0', khaki: '#f0e68c', lavender: '#e6e6fa', lavenderblush: '#fff0f5', lawngreen: '#7cfc00', lemonchiffon: '#fffacd', lightblue: '#add8e6', lightcoral: '#f08080', lightcyan: '#e0ffff', lightgoldenrodyellow: '#fafad2', lightgray: '#d3d3d3', lightgreen: '#90ee90', lightgrey: '#d3d3d3', lightpink: '#ffb6c1', lightsalmon: '#ffa07a', lightseagreen: '#20b2aa', lightskyblue: '#87cefa', lightslategray: '#778899', lightslategrey: '#778899', lightsteelblue: '#b0c4de', lightyellow: '#ffffe0', lime: '#00ff00', limegreen: '#32cd32', linen: '#faf0e6', magenta: '#ff00ff', maroon: '#800000', mediumaquamarine: '#66cdaa', mediumblue: '#0000cd', mediumorchid: '#ba55d3', mediumpurple: '#9370db', mediumseagreen: '#3cb371', mediumslateblue: '#7b68ee', mediumspringgreen: '#00fa9a', mediumturquoise: '#48d1cc', mediumvioletred: '#c71585', midnightblue: '#191970', mintcream: '#f5fffa', mistyrose: '#ffe4e1', moccasin: '#ffe4b5', navajowhite: '#ffdead', navy: '#000080', oldlace: '#fdf5e6', olive: '#808000', olivedrab: '#6b8e23', orange: '#ffa500', orangered: '#ff4500', orchid: '#da70d6', palegoldenrod: '#eee8aa', palegreen: '#98fb98', paleturquoise: '#afeeee', palevioletred: '#db7093', papayawhip: '#ffefd5', peachpuff: '#ffdab9', peru: '#cd853f', pink: '#ffc0cb', plum: '#dda0dd', powderblue: '#b0e0e6', purple: '#800080', red: '#ff0000', rosybrown: '#bc8f8f', royalblue: '#4169e1', saddlebrown: '#8b4513', salmon: '#fa8072', sandybrown: '#f4a460', seagreen: '#2e8b57', seashell: '#fff5ee', sienna: '#a0522d', silver: '#c0c0c0', skyblue: '#87ceeb', slateblue: '#6a5acd', slategray: '#708090', slategrey: '#708090', snow: '#fffafa', springgreen: '#00ff7f', steelblue: '#4682b4', tan: '#d2b48c', teal: '#008080', thistle: '#d8bfd8', tomato: '#ff6347', turquoise: '#40e0d0', violet: '#ee82ee', wheat: '#f5deb3', white: '#ffffff', whitesmoke: '#f5f5f5', yellow: '#ffff00', yellowgreen: '#9acd32', transparent: '#00000000' }; Color.nonStandarNamedColors = { night: '#0C090A', gunmetal: '#2C3539', midnight: '#2B1B17', charcoal: '#34282C', oil: '#3B3131', blackcat: '#413839', iridium: '#3D3C3A', blackeel: '#463E3F', blackcow: '#4C4646', graywolf: '#504A4B', vampiregray: '#565051', graydolphin: '#5C5858', carbongray: '#625D5D', ashgray: '#666362', cloudygray: '#6D6968', smokeygray: '#726E6D', granite: '#837E7C', battleshipgray: '#848482', graycloud: '#B6B6B4', graygoose: '#D1D0CE', platinum: '#E5E4E2', metallicsilver: '#BCC6CC', bluegray: '#98AFC7', raven: '#657383', jetgray: '#616D7E', mistblue: '#646D7E', marbleblue: '#566D7E', shipcove: '#737CA1', mariner: '#4863A0', bluejay: '#2B547E', biscay: '#2B3856', navyblue: '#000080', bluewhale: '#342D7E', lapisblue: '#15317E', denimdarkblue: '#151B8D', earthblue: '#0000A0', cobaltblue: '#0020C2', blueberryblue: '#0041C2', sapphireblue: '#2554C7', blueeyes: '#1569C7', blueorchid: '#1F45FC', bluelotus: '#6960EC', lightslateblue: '#736AFF', windowsblue: '#357EC7', glacialblueice: '#368BC1', silkblue: '#488AC7', blueivy: '#3090C7', bluekoi: '#659EC7', columbiablue: '#87AFC7', babyblue: '#95B9C7', oceanblue: '#2B65EC', blueribbon: '#306EFF', bluedress: '#157DEC', butterflyblue: '#38ACEC', iceberg: '#56A5EC', crystalblue: '#5CB3FF', denimblue: '#79BAEC', dayskyblue: '#82CAFF', jeansblue: '#A0CFEC', blueangel: '#B7CEEC', pastelblue: '#B4CFEC', seablue: '#C2DFFF', coralblue: '#AFDCEC', robineggblue: '#BDEDFF', palebluelily: '#CFECEC', water: '#EBF4FA', lightslate: '#CCFFFF', lightaquamarine: '#93FFE8', electricblue: '#9AFEFF', cyanoraqua: '#00FFFF', tronblue: '#7DFDFE', bluezircon: '#57FEFF', bluelagoon: '#8EEBEC', celeste: '#50EBEC', bluediamond: '#4EE2EC', tiffanyblue: '#81D8D0', cyanopaque: '#92C7C7', bluehosta: '#77BFC7', northernlightsblue: '#78C7C7', jellyfish: '#46C7C7', bluegreen: '#7BCCB5', macawbluegreen: '#43BFC7', seaturtlegreen: '#438D80', greenishblue: '#307D7E', grayishturquoise: '#5E7D7E', beetlegreen: '#4C787E', camouflagegreen: '#78866B', sagegreen: '#848b79', hazelgreen: '#617C58', venomgreen: '#728C00', ferngreen: '#667C26', darkforestgreen: '#254117', mediumforestgreen: '#347235', seaweedgreen: '#437C17', pinegreen: '#387C44', junglegreen: '#347C2C', shamrockgreen: '#347C17', greenonion: '#6AA121', clovergreen: '#3EA055', greensnake: '#6CBB3C', aliengreen: '#6CC417', greenapple: '#4CC417', kellygreen: '#4CC552', zombiegreen: '#54C571', froggreen: '#99C68E', greenpeas: '#89C35C', dollarbillgreen: '#85BB65', iguanagreen: '#9CB071', avocadogreen: '#B2C248', pistachiogreen: '#9DC209', saladgreen: '#A1C935', hummingbirdgreen: '#7FE817', nebulagreen: '#59E817', stoplightgogreen: '#57E964', algaegreen: '#64E986', jadegreen: '#5EFB6E', emeraldgreen: '#5FFB17', dragongreen: '#6AFB92', mintgreen: '#98FF98', greenthumb: '#B5EAAA', lightjade: '#C3FDB8', teagreen: '#CCFB5D', slimegreen: '#BCE954', harvestgold: '#EDE275', sunyellow: '#FFE87C', cornyellow: '#FFF380', parchment: '#FFFFC2', cream: '#FFFFCC', blonde: '#FBF6D9', champagne: '#F7E7CE', vanilla: '#F3E5AB', tanbrown: '#ECE5B6', peach: '#FFE5B4', mustard: '#FFDB58', rubberduckyyellow: '#FFD801', brightgold: '#FDD017', goldenbrown: '#EAC117', macaroniandcheese: '#F2BB66', saffron: '#FBB917', beer: '#FBB117', cantaloupe: '#FFA62F', beeyellow: '#E9AB17', brownsugar: '#E2A76F', deeppeach: '#FFCBA4', gingerbrown: '#C9BE62', schoolbusyellow: '#E8A317', fallleafbrown: '#C8B560', orangegold: '#D4A017', sand: '#C2B280', cookiebrown: '#C7A317', caramel: '#C68E17', brass: '#B5A642', camelbrown: '#C19A6B', bronze: '#CD7F32', tigerorange: '#C88141', cinnamon: '#C58917', bulletshell: '#AF9B60', copper: '#B87333', wood: '#966F33', oakbrown: '#806517', armybrown: '#827B60', sandstone: '#786D5F', mocha: '#493D26', taupe: '#483C32', coffee: '#6F4E37', brownbear: '#835C3B', reddirt: '#7F5217', sepia: '#7F462C', orangesalmon: '#C47451', rust: '#C36241', redfox: '#C35817', sedona: '#CC6600', papayaorange: '#E56717', halloweenorange: '#E66C2C', pumpkinorange: '#F87217', constructionconeorange: '#F87431', sunriseorange: '#E67451', mangoorange: '#FF8040', basketballorange: '#F88158', tangerine: '#E78A61', beanred: '#F75D59', valentinered: '#E55451', shockingorange: '#E55B3C', scarlet: '#FF2400', rubyred: '#F62217', ferrarired: '#F70D1A', fireenginered: '#F62817', lavared: '#E42217', lovered: '#E41B17', grapefruit: '#DC381F', chestnutred: '#C34A2C', cherryred: '#C24641', mahogany: '#C04000', chillipepper: '#C11B17', cranberry: '#9F000F', redwine: '#990012', burgundy: '#8C001A', chestnut: '#954535', bloodred: '#7E3517', sangria: '#7E3817', plumpie: '#7D0541', velvetmaroon: '#7E354D', plumvelvet: '#7D0552', rosyfinch: '#7F4E52', puce: '#7F5A58', dullpurple: '#7F525D', khakirose: '#C5908E', pinkbow: '#C48189', lipstickpink: '#C48793', rose: '#E8ADAA', rosegold: '#ECC5C0', desertsand: '#EDC9AF', pigpink: '#FDD7E4', cottoncandy: '#FCDFFF', pinkbubblegum: '#FFDFDD', flamingopink: '#F9A7B0', pinkrose: '#E7A1B0', pinkdaisy: '#E799A3', cadillacpink: '#E38AAE', carnationpink: '#F778A1', blushred: '#E56E94', watermelonpink: '#FC6C85', violetred: '#F6358A', pinkcupcake: '#E45E9D', pinklemonade: '#E4287C', neonpink: '#F535AA', dimorphothecamagenta: '#E3319D', brightneonpink: '#F433FF', tulippink: '#C25A7C', roguepink: '#C12869', burntpink: '#C12267', bashfulpink: '#C25283', darkcarnationpink: '#C12283', violapurple: '#7E587E', purpleiris: '#571B7E', plumpurple: '#583759', purplemonster: '#461B7E', purplehaze: '#4E387E', eggplant: '#614051', grape: '#5E5A80', purplejam: '#6A287E', purpleflower: '#A74AC7', purpleamethyst: '#6C2DC7', purplesagebush: '#7A5DC7', lovelypurple: '#7F38EC', aztechpurple: '#893BFF', jasminepurple: '#A23BEC', purpledaffodil: '#B041FF', tyrianpurple: '#C45AEC', crocuspurple: '#9172EC', purplemimosa: '#9E7BFF', heliotropepurple: '#D462FF', purpledragon: '#C38EC7', lilac: '#C8A2C8', blushpink: '#E6A9EC', mauve: '#E0B0FF', wisteriapurple: '#C6AEC7', blossompink: '#F9B7FF', periwinkle: '#E9CFEC', lavenderpinocchio: '#EBDDE2', lavenderblue: '#E3E4FA', pearl: '#FDEEF4', milkwhite: '#FEFCFF' }; /********************** COLOR CONVERTER *******************/ Color.rgbToHex = function (rgb) { return '#' + rgb.slice(0, 3).map(function (c) { var res = ((c * 255) >> 0).toString(16); if (res < 10) res = '0' + res; return res.toUpperCase(); }).join(''); }; Color.rgbaToHex = function (rgb) { return '#' + rgb.map(function (c) { var res = ((c * 255) >> 0).toString(16); if (res < 10) res = '0' + res; return res.toUpperCase(); }).join(''); }; Color.hsbaToText = function (hsba) { return 'hsba(' + (hsba[0] * 360 >> 0) + 'deg, ' + (hsba[1] * 100 >> 0) + '%, ' + (hsba[2] * 100 >> 0) + '%, ' + (hsba[3].toFixed(3)) + ')'; }; Color.hslaToText = function (hsla) { return 'hsla(' + (hsla[0] * 360 >> 0) + 'deg, ' + (hsla[1] * 100 >> 0) + '%, ' + (hsla[2] * 100 >> 0) + '%, ' + (hsla[3].toFixed(3)) + ')'; }; Color.rgbaToText = function (rgba) { return 'rgba(' + (rgba[0] * 255 >> 0) + ', ' + (rgba[1] * 255 >> 0) + ', ' + (rgba[2] * 255 >> 0) + ', ' + (rgba[3].toFixed(3)) + ')'; }; Color.hsbToText = function (hsba) { return 'hsb(' + (hsba[0] * 360 >> 0) + 'deg, ' + (hsba[1] * 100 >> 0) + '%, ' + (hsba[2] * 100 >> 0) + '%)'; }; Color.hslToText = function (hsl) { return 'hsl(' + (hsl[0] * 360 >> 0) + 'deg, ' + (hsl[1] * 100 >> 0) + '%, ' + (hsl[2] * 100 >> 0) + '%)'; }; Color.rgbToText = function (rgba) { return 'rgb(' + (rgba[0] * 255 >> 0) + ', ' + (rgba[1] * 255 >> 0) + ', ' + (rgba[2] * 255 >> 0) + ')'; }; Color.cmykToText = function (cmyk) { return 'cmyk(' + cmyk.map(function (x) { return x * 100 + '%' }).join(', ') + ')'; }; Color.hsbaToHSLA = function (hsba) { var hue = hsba[0]; var sat = hsba[1]; var val = hsba[2]; // Calculate lightness. var li = (2 - sat) * val / 2; // Convert saturation. if (li !== 0) { if (li === 1) { sat = 0; } else if (li < 0.5) { sat = sat / (2 - sat); } else { sat = sat * val / (2 - li * 2); } } // Hue and alpha stay the same. return [hue, sat, li, hsba[3]]; }; Color.hsbaToRGBA = function (hsba) { var hue = hsba[0] * 6; // We will split hue into 6 sectors. var sat = hsba[1]; var val = hsba[2]; var RGBA = []; if (sat === 0) { RGBA = [val, val, val, hsba[3]]; // Return early if grayscale. } else { var sector = Math.floor(hue); var tint1 = val * (1 - sat); var tint2 = val * (1 - sat * (hue - sector)); var tint3 = val * (1 - sat * (1 + sector - hue)); var red, green, blue; if (sector === 1) { // Yellow to green. red = tint2; green = val; blue = tint1; } else if (sector === 2) { // Green to cyan. red = tint1; green = val; blue = tint3; } else if (sector === 3) { // Cyan to blue. red = tint1; green = tint2; blue = val; } else if (sector === 4) { // Blue to magenta. red = tint3; green = tint1; blue = val; } else if (sector === 5) { // Magenta to red. red = val; green = tint1; blue = tint2; } else { // Red to yellow (sector could be 0 or 6). red = val; green = tint3; blue = tint1; } RGBA = [red, green, blue, hsba[3]]; } return RGBA; }; Color.hslaToHSBA = function (hsla) { var hue = hsla[0]; var sat = hsla[1]; var li = hsla[2]; // Calculate brightness. var val; if (li < 0.5) { val = (1 + sat) * li; } else { val = li + sat - li * sat; } // Convert saturation. sat = 2 * (val - li) / val; // Hue and alpha stay the same. return [hue, sat, val, hsla[3]]; }; Color.hslaToRGBA = function (hsla) { var hue = hsla[0] * 6; // We will split hue into 6 sectors. var sat = hsla[1]; var li = hsla[2]; var RGBA = []; if (sat === 0) { RGBA = [li, li, li, hsla[3]]; // Return early if grayscale. } else { // Calculate brightness. var val; if (li < 0.5) { val = (1 + sat) * li; } else { val = li + sat - li * sat; } // Define zest. var zest = 2 * li - val; // Implement projection (project onto green by default). var hzvToRGB = function (hue, zest, val) { if (hue < 0) { // Hue must wrap to allow projection onto red and blue. hue += 6; } else if (hue >= 6) { hue -= 6; } if (hue < 1) { // Red to yellow (increasing green). return zest + (val - zest) * hue; } else if (hue < 3) { // Yellow to cyan (greatest green). return val; } else if (hue < 4) { // Cyan to blue (decreasing green). return zest + (val - zest) * (4 - hue); } else { // Blue to red (least green). return zest; } }; // Perform projections, offsetting hue as necessary. RGBA = [ hzvToRGB(hue + 2, zest, val), hzvToRGB(hue, zest, val), hzvToRGB(hue - 2, zest, val), hsla[3] ]; } return RGBA; }; Color.rgbaToHSBA = function (rgba) { var red = rgba[0]; var green = rgba[1]; var blue = rgba[2]; var val = Math.max(red, green, blue); var chroma = val - Math.min(red, green, blue); var hue, sat; if (chroma === 0) { // Return early if grayscale. hue = 0; sat = 0; } else { sat = chroma / val; if (red === val) { // Magenta to yellow. hue = (green - blue) / chroma; } else if (green === val) { // Yellow to cyan. hue = 2 + (blue - red) / chroma; } else if (blue === val) { // Cyan to magenta. hue = 4 + (red - green) / chroma; } if (hue < 0) { // Confine hue to the interval [0, 1). hue += 6; } else if (hue >= 6) { hue -= 6; } } return [hue / 6, sat, val, rgba[3]]; }; Color.rgbaToHSLA = function (rgba) { var red = rgba[0]; var green = rgba[1]; var blue = rgba[2]; var val = Math.max(red, green, blue); var min = Math.min(red, green, blue); var li = val + min; // We will halve this later. var chroma = val - min; var hue, sat; if (chroma === 0) { // Return early if grayscale. hue = 0; sat = 0; } else { if (li < 1) { sat = chroma / li; } else { sat = chroma / (2 - li); } if (red === val) { // Magenta to yellow. hue = (green - blue) / chroma; } else if (green === val) { // Yellow to cyan. hue = 2 + (blue - red) / chroma; } else if (blue === val) { // Cyan to magenta. hue = 4 + (red - green) / chroma; } if (hue < 0) { // Confine hue to the interval [0, 1). hue += 6; } else if (hue >= 6) { hue -= 6; } } return [hue / 6, sat, li / 2, rgba[3]]; }; Color.hwbaToHSBA = function (hwba) { return [hwba[0], 1 - hwba[1] / (1 - hwba[2]), 1 - hwba[2], hwba[3]]; }; Color.hsbaToHWBA = function (hsla) { return [hsla[0], (1 - hsla[1]) * hsla[2], 1 - hsla[2], hsla[3]]; }; Color.rgbaToHWBA = function (rgba) { return this.hsbaToHWBA(this.rgbaToHSBA(rgba)); }; Color.hwbaToRGBA = function (hwba) { return this.hsbaToRGBA(this.hwbaToHSBA(hwba)); }; Color.cmykToRGB = function (cmyk) { var c = cmyk[0]; var m = cmyk[1]; var y = cmyk[2]; var k = cmyk[3]; c = c * (1 - k) + k; m = m * (1 - k) + k; y = y * (1 - k) + k; var r = 1 - c; var g = 1 - m; var b = 1 - y; return [r, g, b]; }; Color.rgbToCMYK = function (rgb) { var r = rgb[0]; var g = rgb[1]; var b = rgb[2]; var c = 1 - r; var m = 1 - g; var y = 1 - b; var k = Math.min(c, Math.min(m, y)); c = (c - k) / (1 - k); m = (m - k) / (1 - k); y = (y - k) / (1 - k); c = isNaN(c) ? 0 : c; m = isNaN(m) ? 0 : m; y = isNaN(y) ? 0 : y; k = isNaN(k) ? 0 : k; return [c, m, y, k]; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Color); /***/ }), /***/ 9959: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "base64EncodeUnicode": () => (/* binding */ base64EncodeUnicode), /* harmony export */ "base64DecodeUnicode": () => (/* binding */ base64DecodeUnicode), /* harmony export */ "UnicodeBase64Converter": () => (/* binding */ UnicodeBase64Converter) /* harmony export */ }); function base64EncodeUnicode(str) { return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function toSolidBytes(match, p1) { return String.fromCharCode('0x' + p1); })); }; function base64DecodeUnicode(str) { return decodeURIComponent(atob(str).split('').map(function (c) { return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2); }).join('')); } var UnicodeBase64Converter = { encode: base64EncodeUnicode, decode: base64DecodeUnicode }; /***/ }), /***/ 9691: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); var ext2MineType = { "323": "text/h323", "*": "application/octet-stream", "3g2": "video/3gpp2", "3gp": "video/3gpp", "7z": "application/x-7z-compressed", aac: "audio/aac", abw: "application/x-abiword", acx: "application/internet-property-stream", ai: "application/postscript", aif: "audio/x-aiff", aifc: "audio/x-aiff", aiff: "audio/x-aiff", arc: "application/x-freearc", asf: "video/x-ms-asf", asr: "video/x-ms-asf", asx: "video/x-ms-asf", au: "audio/basic", avi: "video/x-msvideo", axs: "application/olescript", azw: "application/vnd.amazon.ebook", bas: "text/plain", bcpio: "application/x-bcpio", bin: "application/octet-stream", bmp: "image/bmp", bz: "application/x-bzip", bz2: "application/x-bzip2", c: "text/plain", cat: "application/vnd.ms-pkiseccat", cda: "application/x-cdf", cdf: "application/x-netcdf", cer: "application/x-x509-ca-cert", class: "application/octet-stream", clp: "application/x-msclip", cmx: "image/x-cmx", cod: "image/cis-cod", cpio: "application/x-cpio", crd: "application/x-mscardfile", crl: "application/pkix-crl", crt: "application/x-x509-ca-cert", csh: "application/x-csh", css: "text/css", csv: "text/csv", dcr: "application/x-director", der: "application/x-x509-ca-cert", dir: "application/x-director", dll: "application/x-msdownload", dms: "application/octet-stream", doc: "application/msword", docx: "application/vnd.openxmlformats-officedocument.wordprocessingml.document", dot: "application/msword", dvi: "application/x-dvi", dxr: "application/x-director", eot: "application/vnd.ms-fontobject", eps: "application/postscript", epub: "application/epub+zip", etx: "text/x-setext", evy: "application/envoy", exe: "application/octet-stream", fif: "application/fractals", flr: "x-world/x-vrml", gif: "image/gif", gtar: "application/x-gtar", gz: "application/gzip", h: "text/plain", hdf: "application/x-hdf", hlp: "application/winhlp", hqx: "application/mac-binhex40", hta: "application/hta", htc: "text/x-component", htm: "text/html", html: "text/html", htt: "text/webviewhtml", ico: "image/vnd.microsoft.icon", ics: "text/calendar", ief: "image/ief", iii: "application/x-iphone", ins: "application/x-internet-signup", isp: "application/x-internet-signup", jar: "application/java-archive", jfif: "image/pipeg", jpe: "image/jpeg", jpeg: "image/jpeg", jpg: "image/jpeg", js: "text/javascript", json: "application/json", jsonld: "application/ld+json", latex: "application/x-latex", lha: "application/octet-stream", lsf: "video/x-la-asf", lsx: "video/x-la-asf", lzh: "application/octet-stream", m13: "application/x-msmediaview", m14: "application/x-msmediaview", m3u: "audio/x-mpegurl", man: "application/x-troff-man", mdb: "application/x-msaccess", me: "application/x-troff-me", mht: "message/rfc822", mhtml: "message/rfc822", mid: "audio/midi", midi: "audio/midi", mjs: "text/javascript", mny: "application/x-msmoney", mov: "video/quicktime", movie: "video/x-sgi-movie", mp2: "video/mpeg", mp3: "audio/mpeg", mp4: "video/mp4", mpa: "video/mpeg", mpe: "video/mpeg", mpeg: "video/mpeg", mpg: "video/mpeg", mpkg: "application/vnd.apple.installer+xml", mpp: "application/vnd.ms-project", mpv2: "video/mpeg", ms: "application/x-troff-ms", msg: "application/vnd.ms-outlook", mvb: "application/x-msmediaview", nc: "application/x-netcdf", nws: "message/rfc822", oda: "application/oda", odp: "application/vnd.oasis.opendocument.presentation", ods: "application/vnd.oasis.opendocument.spreadsheet", odt: "application/vnd.oasis.opendocument.text", oga: "audio/ogg", ogv: "video/ogg", ogx: "application/ogg", opus: "audio/opus", otf: "font/otf", p10: "application/pkcs10", p12: "application/x-pkcs12", p7b: "application/x-pkcs7-certificates", p7c: "application/x-pkcs7-mime", p7m: "application/x-pkcs7-mime", p7r: "application/x-pkcs7-certreqresp", p7s: "application/x-pkcs7-signature", pbm: "image/x-portable-bitmap", pdf: "application/pdf", pfx: "application/x-pkcs12", pgm: "image/x-portable-graymap", php: "application/x-httpd-php", pko: "application/ynd.ms-pkipko", pma: "application/x-perfmon", pmc: "application/x-perfmon", pml: "application/x-perfmon", pmr: "application/x-perfmon", pmw: "application/x-perfmon", png: "image/png", pnm: "image/x-portable-anymap", pot: "application/vnd.ms-powerpoint", ppm: "image/x-portable-pixmap", pps: "application/vnd.ms-powerpoint", ppt: "application/vnd.ms-powerpoint", pptx: "application/vnd.openxmlformats-officedocument.presentationml.presentation", prf: "application/pics-rules", ps: "application/postscript", pub: "application/x-mspublisher", qt: "video/quicktime", ra: "audio/x-pn-realaudio", ram: "audio/x-pn-realaudio", rar: "application/vnd.rar", ras: "image/x-cmu-raster", rgb: "image/x-rgb", rmi: "audio/mid", roff: "application/x-troff", rtf: "application/rtf", rtx: "text/richtext", scd: "application/x-msschedule", sct: "text/scriptlet", setpay: "application/set-payment-initiation", setreg: "application/set-registration-initiation", sh: "application/x-sh", shar: "application/x-shar", sit: "application/x-stuffit", snd: "audio/basic", spc: "application/x-pkcs7-certificates", spl: "application/futuresplash", src: "application/x-wais-source", sst: "application/vnd.ms-pkicertstore", stl: "application/vnd.ms-pkistl", stm: "text/html", sv4cpio: "application/x-sv4cpio", sv4crc: "application/x-sv4crc", svg: "image/svg+xml", swf: "application/x-shockwave-flash", t: "application/x-troff", tar: "application/x-tar", tcl: "application/x-tcl", tex: "application/x-tex", texi: "application/x-texinfo", texinfo: "application/x-texinfo", tgz: "application/x-compressed", tif: "image/tiff", tiff: "image/tiff", tr: "application/x-troff", trm: "application/x-msterminal", ts: "video/mp2t", tsv: "text/tab-separated-values", ttf: "font/ttf", txt: "text/plain", uls: "text/iuls", ustar: "application/x-ustar", vcf: "text/x-vcard", vrml: "x-world/x-vrml", vsd: "application/vnd.visio", wav: "audio/wav", wcm: "application/vnd.ms-works", wdb: "application/vnd.ms-works", weba: "audio/webm", webm: "video/webm", webp: "image/webp", wks: "application/vnd.ms-works", wmf: "application/x-msmetafile", woff: "font/woff", woff2: "font/woff2", wps: "application/vnd.ms-works", wri: "application/x-mswrite", wrl: "x-world/x-vrml", wrz: "x-world/x-vrml", xaf: "x-world/x-vrml", xbm: "image/x-xbitmap", xhtml: "application/xhtml+xml", xla: "application/vnd.ms-excel", xlc: "application/vnd.ms-excel", xlm: "application/vnd.ms-excel", xls: "application/vnd.ms-excel", xlsx: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", xlt: "application/vnd.ms-excel", xlw: "application/vnd.ms-excel", xml: "application/xml", xof: "x-world/x-vrml", xpm: "image/x-xpixmap", xul: "application/vnd.mozilla.xul+xml", xwd: "image/x-xwindowdump", z: "application/x-compress", zip: "application/zip" }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ext2MineType); /***/ }), /***/ 4574: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "blobToFile": () => (/* binding */ blobToFile), /* harmony export */ "dataURItoBlob": () => (/* binding */ dataURItoBlob), /* harmony export */ "blobToArrayBuffer": () => (/* binding */ blobToArrayBuffer), /* harmony export */ "stringToBlob": () => (/* binding */ stringToBlob) /* harmony export */ }); /* harmony import */ var _ext2MineType__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9691); function blobToFile(theBlob, fileName) { return new File([theBlob], fileName); } function dataURItoBlob(dataURI) { var byteString = atob(dataURI.split(',')[1]); var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]; var ab = new ArrayBuffer(byteString.length); var ia = new Uint8Array(ab); for (var i = 0; i < byteString.length; i++) { ia[i] = byteString.charCodeAt(i); } var blob = new Blob([ab], { type: mimeString }); return blob; } function blobToArrayBuffer(blob) { var fileReader = new FileReader(); return new Promise(function (rs) { fileReader.onload = function (event) { var arrayBuffer = event.target.result; rs(arrayBuffer); }; fileReader.readAsArrayBuffer(blob); }); } function stringToBlob(text, type) { type = type || 'text/plain'; var mineTye = type.split('/').length === 2 ? type : (_ext2MineType__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z[type] || 'text/plain'); return new Blob([text], { type: mineTye }); } /***/ }), /***/ 7835: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "arrayUnique": () => (/* binding */ arrayUnique), /* harmony export */ "arrayRemoveNone": () => (/* binding */ arrayRemoveNone), /* harmony export */ "arrayIntersection": () => (/* binding */ arrayIntersection), /* harmony export */ "arrayIsSubset": () => (/* binding */ arrayIsSubset), /* harmony export */ "arrayCompare": () => (/* binding */ arrayCompare), /* harmony export */ "arrayLexicographicalCompare": () => (/* binding */ arrayLexicographicalCompare), /* harmony export */ "arrayShuffle": () => (/* binding */ arrayShuffle) /* harmony export */ }); /*** * * @param {(string|number|boolean|null)[]} arr * @returns {(string|number|boolean|null)[]} */ function arrayUnique(arr) { var dict = {}; return arr.reduce(function (ac, cr) { var key = (typeof cr) + '//' + cr; if (key in dict) return ac; ac.push(cr); dict[key] = true; return ac; }, []); } /*** * * @param {[]}arr * @return {[]} */ function arrayRemoveNone(arr) { return arr.filter(function (c) { return c !== null && c !== undefined; }); } function arrayIntersection(a1, a2) { var dict1 = a1.reduce((ac, cr) => { ac[(typeof cr) + cr] = true; return ac; }, {}); var dict2 = a2.reduce((ac, cr) => { ac[(typeof cr) + cr] = true; return ac; }, {}); var dictAdded = {}; var res = []; var i, k, x; for (i = 0; i < a1.length; ++i) { x = a1[i]; k = (typeof x) + x; if (dict1[k] && dict2[k] && !dictAdded[k]) { res.push(x); dictAdded[k] = true; } } for (i = 0; i < a2.length; ++i) { x = a2[i]; k = (typeof x) + x; if (dict1[k] && dict2[k] && !dictAdded[k]) { res.push(x); dictAdded[k] = true; } } return res; } function arrayIsSubset(childArr, parentArr) { if (!(childArr instanceof Array) || !(parentArr instanceof Array)) return false; var dict2 = parentArr.reduce((ac, cr) => { ac[(typeof cr) + cr] = true; return ac; }, {}); var res = true; var n = childArr.length; var k; for (var i = 0; i < n; ++i) { k = (typeof childArr[i]) + childArr[i]; if (!dict2[k]) { res = false; break; } } return res; } /*** * * @param {[]}a1 * @param {[]}a2 * @param {boolean=} order * @returns {boolean} */ function arrayCompare(a1, a2, order) { if (a1 === a2) return true; if (!a1 || !a2) return false; if (a1.length !== a2.length) return false; if (!a1.sort || !a2.sort) return false; if (!order) { a1.sort(); a2.sort(); } var n = a1.length; for (var i = 0; i < n; ++i) { if (a1[i] !== a2[i]) return false; } return true; } /** * * @param {number[]} a1 * @param {number[]} a2 * @returns {number} */ function arrayLexicographicalCompare(a1, a2) { var minLength = Math.min(a1.length, a2.length); for (var i = 0; i < minLength; i++) { if (a1[i] < a2[i]) { return -1; // array1 nhỏ hơn array2 } else if (a1[i] > a2[i]) { return 1; // array1 lớn hơn array2 } } if (a1.length < a2.length) { return -1; } else if (a1.length > a2.length) { return 1; } else { return 0; } } /*** * * @param {Array} arr */ function arrayShuffle(arr) { var temp; var j; for (var i = 0; i < arr.length; ++i) { j = Math.floor(Math.random() * arr.length); if (i !== j) { temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } } /***/ }), /***/ 5491: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports defaultCmp, heapDown, heapUp, heapify, heapPop, heapPush */ function defaultCmp(x, y) { if (x < y) { return -1; } if (x > y) { return 1; } return 0; }; /** * * @param {Array} arr * @param {Number} pos * @param {Function} cmp */ function heapDown(arr, pos, cmp) { if (!cmp) cmp = defaultCmp; var item = arr[pos]; var endPos = arr.length; var childPos = (pos << 1) | 1; var childRightPos; while (childPos < endPos) { childRightPos = childPos + 1; if (childPos + 1 < endPos && cmp(arr[childPos], arr[childRightPos]) > 0) { childPos = childRightPos; } if (cmp(arr[childPos], item) < 0) { arr[pos] = arr[childPos]; arr[childPos] = item; pos = childPos; childPos = (pos << 1) | 1; } else break; } } /** * * @param {Array} arr * @param {Number} pos * @param {Function} cmp */ function heapUp(arr, pos, cmp) { if (!cmp) cmp = defaultCmp; var item = arr[pos]; var parPos; while (pos > 0) { parPos = (pos - 1) >> 1; if (cmp(arr[parPos], item) > 0) { arr[pos] = arr[parPos]; arr[parPos] = item; pos = parPos; } else break; } } /** * * @param {Array} arr * @param {Function} cmp */ function heapify(arr, cmp) { if (!cmp) cmp = defaultCmp; var endPos = arr.length; for (var i = 0; i < endPos; ++i) heapUp(arr, i, cmp); } /** * * @param {Array} arr * @param {Function} cmp */ function heapPop(arr, cmp) { if (!cmp) cmp = defaultCmp; var item = arr[0]; var lastItem = arr.pop(); if (arr.length > 0) { arr[0] = lastItem; heapDown(arr, 0, cmp); } return item; } /** * * @param {Array} arr * @param {*} item * @param {Function} cmp */ function heapPush(arr, item, cmp) { if (!cmp) cmp = defaultCmp; arr.push(item); heapUp(arr, arr.length - 1, cmp); } function Heap(cmd) { this.cmp = cmd || defaultCmp; this.arr = []; } /** * @param {Array} arr * @param {Function} cmp * @returns {Heap} */ Heap.fromArray = function (arr, cmp) { var heap = new Heap(cmp); heapify(arr); heap.arr = arr; return heap; }; Heap.prototype.push = function (x) { heapPush(this.arr, x, this.cmp); return this; }; Heap.prototype.pop = function () { return heapPop(this.arr, this.cmp); }; Heap.prototype.peek = function () { return this.arr[0]; }; Heap.prototype.contains = function (x) { return this.arr.indexOf(x) !== -1; }; Heap.prototype.clear = function () { this.arr.splice(0, this.arr.length); return this; }; Heap.prototype.empty = function () { return this.arr.length === 0; }; Heap.prototype.size = function () { return this.arr.length; }; Heap.prototype.clone = function () { var heap; heap = new Heap(this.cmp); heap.arr = this.arr.slice(0); return heap; }; Heap.prototype.toArray = function () { return this.arr.slice(0); }; Heap.prototype.toSortedArray = function () { var res = []; var heap = this.clone(); while (!heap.empty()) res.push(heap.pop()); return res; }; Heap.prototype.insert = Heap.prototype.push; Heap.prototype.top = Heap.prototype.peek; Heap.prototype.front = Heap.prototype.peek; Heap.prototype.has = Heap.prototype.contains; Heap.prototype.copy = Heap.prototype.clone; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Heap); /***/ }), /***/ 2722: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "bU": () => (/* binding */ revokeResource), /* harmony export */ "U": () => (/* binding */ observePropertyChanges), /* harmony export */ "i3": () => (/* binding */ unobservePropertyChanges) /* harmony export */ }); function revokeResource(o) { if (!o) return; var oc, ocs; var keys, key; if (Array.isArray(o)) { while (o.length) { oc = o.pop(); try { revokeResource(oc); } catch (err) { } } } else if (o.revokeResource) { o.revokeResource(); } else if (o.nodeType === 1 || o.nodeType === 3) { if (o.revokeResource) o.revokeResource(); else { while (o.lastChild) { oc = o.lastChild; revokeResource(oc); // if (oc.selfRemove) { // oc.selfRemove(); // } // else { oc.remove(); // } } } } else if (typeof o === "object") { keys = []; ocs = []; for (key in o) { keys.push(key); } while (keys.length) { key = keys.pop(); ocs.push(o[keys]); try { delete o[key]; } catch (err) { } } while (ocs.length) { try { revokeResource(ocs.pop()); } catch (err) { } } } ocs = undefined; oc = undefined; keys = undefined; key = undefined; o = undefined; } /** * * @param obj * @param {string|Array<string>} keys * @param {function} callback */ function observePropertyChanges(obj, keys, callback) { var value; if (Array.isArray(keys)) { keys.forEach(key => { observePropertyChanges(obj, key, callback); }); } else { value = obj[keys]; Object.defineProperty(obj, keys, { get: function () { return value; }, set: function (newValue) { value = newValue; callback(keys, newValue); }, configurable: true, enumerable: true }); } } /** * * @param obj * @param {string|Array<string>} keys */ function unobservePropertyChanges(obj, keys) { var value; if (Array.isArray(keys)) { keys.forEach(key=>{ unobservePropertyChanges(obj, key); }) } else { value = obj[keys]; delete obj[keys]; obj[keys] = value; } } /***/ }), /***/ 9399: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony export calcBenchmark */ /* harmony import */ var _BrowserRules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2777); /* harmony import */ var _BrowserRules__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_BrowserRules__WEBPACK_IMPORTED_MODULE_0__); /** * * @param rulesheet * @param {string=} userAgent */ function BrowserDetector(rulesheet, userAgent) { this.au = userAgent || (__webpack_require__.g.navigator ? (navigator.userAgent || '') : ''); this.rulesheet = rulesheet; this.os = this.detectByRules(this.rulesheet.os); this.device = this.detectByRules(this.rulesheet.device); this.engine = this.detectByRules(this.rulesheet.engine); this.browser = this.detectByRules(this.rulesheet.browser); this.isFirefox = this.au.toLowerCase().indexOf('firefox') > -1; this.isCococ = this.au.toLowerCase().indexOf('coc_coc_browser') >= 1; this.isSafari = this.browser.type === 'safari' || (!this.isCococ && this.au.toLowerCase().indexOf('safari') > -1 && this.au.toLowerCase().indexOf('win') < 0 && this.au.toLowerCase().indexOf('android') < 0); // this.isSafari = /constructor/i.test(window.HTMLElement) || window.safari; var isMobile = this.au.indexOf('KFFOWI') > -1 || this.au.toLowerCase().indexOf('mobile') > -1 || this.device.type === 'iphone' || this.device.type === 'ipad' || this.device.type === 'android'; Object.defineProperty(this, 'isMobile', { get: function () { return isMobile || window.isMobile || !!window['mobileHost']; }, set: v => { //do nothing } }); this.isMacOSWebView = /Macintosh/.test(this.au) && /AppWebkit/.test(this.au) && !/Safari/.test(this.au); this.isChromeIOS = /CriOS\/[\d]+/.test(this.au); this.hasTouch = 'ontouchstart' in __webpack_require__.g || __webpack_require__.g.DocumentTouch && document instanceof __webpack_require__.g.DocumentTouch || (__webpack_require__.g.navigator && (navigator.maxTouchPoints > 0 || __webpack_require__.g.navigator.msMaxTouchPoints > 0)); this.isTouchDevice = this.isMobile && this.hasTouch; this.supportPassiveEvent = (function () { var supportsPassiveOption = false; try { var opts = Object.defineProperty({}, 'passive', { get: function () { supportsPassiveOption = true; } }); __webpack_require__.g.addEventListener('test', null, opts); __webpack_require__.g.removeEventListener('test', null, opts); } catch (e) { } return supportsPassiveOption; })(); this.supportGridLayout = __webpack_require__.g.document && (typeof document.createElement('div').style.grid === 'string'); Object.defineProperty(this, 'zoom', { get: function () { return this.getZoom(); }, enumerable: true, configurable: false }); } BrowserDetector.prototype.detectByRules = function (rules) { var result = {}; for (var i = 0; i < rules.length; ++i) { var rule = rules[i]; var type = rule[0]; var rgx = rule[1]; if (typeof (rgx) == 'function') { rgx = rgx(this.au.toLowerCase()); } if (Object.prototype.toString.call(rgx).indexOf('RegExp') >= 0) { var matched = this.au.toLowerCase().match(rgx); if (matched) { result.type = type; if (matched[1]) { result.version = matched[1].replace(/_/g, '.'); } break; } } else if (typeof (rgx) == 'string') { if (this.au.toLowerCase().indexOf(rgx) >= 0) { result.type = type; } } } result.type = result.type || 'unknow'; result.version = result.version || '0'; return result; }; BrowserDetector.prototype.getZoom = function () { //todo: wrong on chrome var type; if ('chrome' in __webpack_require__.g) { type = "chrome"; } else if (this.isSafari) { type = 'safari'; } else if ('orientation' in __webpack_require__.g && 'webkitRequestAnimationFrame' in __webpack_require__.g) { type = 'webkitMobile'; } else if ('webkitRequestAnimationFrame' in __webpack_require__.g) { type = 'webkit'; } switch (type) { case 'chrome': return Math.round(((__webpack_require__.g.outerWidth) / __webpack_require__.g.innerWidth) * 100) / 100; case 'safari': return Math.round(((document.documentElement.clientWidth) / __webpack_require__.g.innerWidth) * 100) / 100; case 'webkitMobile': return ((Math.abs(__webpack_require__.g.orientation) == 90) ? screen.height : screen.width) / __webpack_require__.g.innerWidth; case 'webkit': return (() => { var important = (str) => { return str.replace(/;/g, " !important;"); }; var div = document.createElement('div'); div.innerHTML = "1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>0"; div.setAttribute('style', important('font: 100px/1em sans-serif; -webkit-text-size-adjust: none; text-size-adjust: none; height: auto; width: 1em; padding: 0; overflow: visible;')); var container = document.createElement('div'); container.setAttribute('style', important('width:0; height:0; overflow:hidden; visibility:hidden; position: absolute;')); container.appendChild(div); document.body.appendChild(container); var zoom = 1000 / div.clientHeight; zoom = Math.round(zoom * 100) / 100; document.body.removeChild(container); return zoom; })(); default: return 1; } return 1; }; function calcBenchmark() { var now = new Date().getTime(); var i = 0; while (now === new Date().getTime()) { } now++; while (now === new Date().getTime()) { ++i } return i; } BrowserDetector.prototype.calcBenchmark = calcBenchmark; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (new BrowserDetector((_BrowserRules__WEBPACK_IMPORTED_MODULE_0___default()))); /***/ }), /***/ 2777: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; const external = __webpack_require__.g.external; const re_msie = /\b(?:msie |ie |trident\/[0-9].*rv[ :])([0-9.]+)/; const re_blackberry_10 = /\bbb10\b.+?\bversion\/([\d.]+)/; const re_blackberry_6_7 = /\bblackberry\b.+\bversion\/([\d.]+)/; const re_blackberry_4_5 = /\bblackberry\d+\/([\d.]+)/; const NA_VERSION = "-1"; const DEVICES = [ ["nokia", function (ua) { // nokia/-1 if (ua.indexOf("nokia ") !== -1) { return /\bnokia ([0-9]+)?/; } else { return /\bnokia([a-z0-9]+)?/; } }], //Android WP ["samsung", function (ua) { if (ua.indexOf("samsung") !== -1) { return /\bsamsung(?:[ \-](?:sgh|gt|sm))?-([a-z0-9]+)/; } else { return /\b(?:sgh|sch|gt|sm)-([a-z0-9]+)/; } }], ["wp", function (ua) { return ua.indexOf("windows phone ") !== -1 || ua.indexOf("xblwp") !== -1 || ua.indexOf("zunewp") !== -1 || ua.indexOf("windows ce") !== -1; }], ["pc", "windows"], ["ipad", "ipad"], // ipod iphone ["ipod", "ipod"], ["iphone", /\biphone\b|\biph(\d)/], ["mac", "macintosh"], ["mi", /\bmi[ \-]?([a-z0-9 ]+(?= build|\)))/], ["hongmi", /\bhm[ \-]?([a-z0-9]+)/], ["aliyun", /\baliyunos\b(?:[\-](\d+))?/], ["meizu", function (ua) { return ua.indexOf("meizu") >= 0 ? /\bmeizu[\/ ]([a-z0-9]+)\b/ : /\bm([0-9cx]{1,4})\b/; }], ["nexus", /\bnexus ([0-9s.]+)/], ["huawei", function (ua) { const re_mediapad = /\bmediapad (.+?)(?= build\/huaweimediapad\b)/; if (ua.indexOf("huawei-huawei") !== -1) { return /\bhuawei\-huawei\-([a-z0-9\-]+)/; } else if (re_mediapad.test(ua)) { return re_mediapad; } else { return /\bhuawei[ _\-]?([a-z0-9]+)/; } }], ["lenovo", function (ua) { if (ua.indexOf("lenovo-lenovo") !== -1) { return /\blenovo\-lenovo[ \-]([a-z0-9]+)/; } else { return /\blenovo[ \-]?([a-z0-9]+)/; } }], ["zte", function (ua) { if (/\bzte\-[tu]/.test(ua)) { return /\bzte-[tu][ _\-]?([a-su-z0-9\+]+)/; } else { return /\bzte[ _\-]?([a-su-z0-9\+]+)/; } }], ["vivo", /\bvivo(?: ([a-z0-9]+))?/], ["htc", function (ua) { if (/\bhtc[a-z0-9 _\-]+(?= build\b)/.test(ua)) { return /\bhtc[ _\-]?([a-z0-9 ]+(?= build))/; } else { return /\bhtc[ _\-]?([a-z0-9 ]+)/; } }], ["oppo", /\boppo[_ ]([a-z0-9]+)/], ["konka", /\bkonka[_\-]([a-z0-9]+)/], ["sonyericsson", /\bmt([a-z0-9]+)/], ["coolpad", /\bcoolpad[_ ]?([a-z0-9]+)/], ["lg", /\blg[\-]([a-z0-9]+)/], ["android", /\bandroid\b|\badr\b/], ["blackberry", function (ua) { if (ua.indexOf("blackberry") >= 0) { return /\bblackberry\s?(\d+)/; } return "bb10"; }], ]; const OS = [ ["wp", function (ua) { if (ua.indexOf("windows phone ") !== -1) { return /\bwindows phone (?:os )?([0-9.]+)/; } else if (ua.indexOf("xblwp") !== -1) { return /\bxblwp([0-9.]+)/; } else if (ua.indexOf("zunewp") !== -1) { return /\bzunewp([0-9.]+)/; } return "windows phone"; }], ["windows", /\bwindows nt ([0-9.]+)/], ["macosx", /\bmac os x ([0-9._]+)/], ["ios", function (ua) { if (/\bcpu(?: iphone)? os /.test(ua)) { return /\bcpu(?: iphone)? os ([0-9._]+)/; } else if (ua.indexOf("iph os ") !== -1) { return /\biph os ([0-9_]+)/; } else { return /\bios\b/; } }], ["yunos", /\baliyunos ([0-9.]+)/], ["android", function (ua) { if (ua.indexOf("android") >= 0) { return /\bandroid[ \/-]?([0-9.x]+)?/; } else if (ua.indexOf("adr") >= 0) { if (ua.indexOf("mqqbrowser") >= 0) { return /\badr[ ]\(linux; u; ([0-9.]+)?/; } else { return /\badr(?:[ ]([0-9.]+))?/; } } return "android"; //return /\b(?:android|\badr)(?:[\/\- ](?:\(linux; u; )?)?([0-9.x]+)?/; }], ["chromeos", /\bcros i686 ([0-9.]+)/], ["linux", "linux"], ["linux", /\blinux\s(?:[xi][0-9_]+;)\srv:([0-9.]+)/],//Linux x86_64; rv:34.0 ["windowsce", /\bwindows ce(?: ([0-9.]+))?/], ["cros", /\bcros armv7l ([0-9.]+)/],//CrOS armv7l 7077.134.0 ["symbian", /\bsymbian(?:os)?\/([0-9.]+)/], ["blackberry", function (ua) { const m = ua.match(re_blackberry_10) || ua.match(re_blackberry_6_7) || ua.match(re_blackberry_4_5); return m ? { version: m[1] } : "blackberry"; }], ['ie', /\rv\:\/([0-9.]+)/] ]; const ENGINE = [ ["edgehtml", /edge\/([0-9.]+)/], ["trident", re_msie], ["blink", function () { return "chrome" in __webpack_require__.g && "CSS" in __webpack_require__.g && /\bapplewebkit[\/]?([0-9.+]+)/; }], ["webkit", /\bapplewebkit[\/]?([0-9.+]+)/], ["gecko", function (ua) { const match = ua.match(/\brv:([\d\w.]+).*\bgecko\/(\d+)/); if (match) { return { version: match[1] + "." + match[2], }; } }], ["presto", /\bpresto\/([0-9.]+)/], ["androidwebkit", /\bandroidwebkit\/([0-9.]+)/], ["coolpadwebkit", /\bcoolpadwebkit\/([0-9.]+)/], ["u2", /\bu2\/([0-9.]+)/], ["u3", /\bu3\/([0-9.]+)/], ]; const BROWSER = [ ['coccoc', /coc_coc_browser\/([0-9.]+)/], // Microsoft Edge Browser, Default browser in Windows 10. ["edge", /edge\/([0-9.]+)/], ["chrome-edge", /chrome.+edg\/([0-9.]+)/], // Sogou. ["sogou", function (ua) { if (ua.indexOf("sogoumobilebrowser") >= 0) { return /sogoumobilebrowser\/([0-9.]+)/; } else if (ua.indexOf("sogoumse") >= 0) { return true; } return / se ([0-9.x]+)/; }], // Maxthon ["maxthon", function () { try { if (external && (external.mxVersion || external.max_version)) { return { version: external.mxVersion || external.max_version, }; } } catch (ex) { /* */ } return /\b(?:maxthon|mxbrowser)(?:[ \/]([0-9.]+))?/; }], ["micromessenger", /\bmicromessenger\/([\d.]+)/], ["qq", /\bm?qqbrowser\/([0-9.]+)/], ["green", "greenbrowser"], ["tt", /\btencenttraveler ([0-9.]+)/], ["liebao", function (ua) { if (ua.indexOf("liebaofast") >= 0) { return /\bliebaofast\/([0-9.]+)/; } if (ua.indexOf("lbbrowser") === -1) { return false; } var version; try { if (external && external.LiebaoGetVersion) { version = external.LiebaoGetVersion(); } } catch (ex) { /* */ } return { version: version || NA_VERSION, }; }], ["tao", /\btaobrowser\/([0-9.]+)/], ["coolnovo", /\bcoolnovo\/([0-9.]+)/], ["saayaa", "saayaa"], ["baidu", /\b(?:ba?idubrowser|baiduhd)[ \/]([0-9.x]+)/], ["ie", re_msie], ["mi", /\bmiuibrowser\/([0-9.]+)/], ["opera", function (ua) { const re_opera_old = /\bopera.+version\/([0-9.ab]+)/; const re_opera_new = /\bopr\/([0-9.]+)/; return re_opera_old.test(ua) ? re_opera_old : re_opera_new; }], ["oupeng", /\boupeng\/([0-9.]+)/], ["yandex", /yabrowser\/([0-9.]+)/], ["ali-ap", function (ua) { if (ua.indexOf("aliapp") > 0) { return /\baliapp\(ap\/([0-9.]+)\)/; } else { return /\balipayclient\/([0-9.]+)\b/; } }], ["ali-ap-pd", /\baliapp\(ap-pd\/([0-9.]+)\)/], ["ali-am", /\baliapp\(am\/([0-9.]+)\)/], ["ali-tb", /\baliapp\(tb\/([0-9.]+)\)/], ["ali-tb-pd", /\baliapp\(tb-pd\/([0-9.]+)\)/], ["ali-tm", /\baliapp\(tm\/([0-9.]+)\)/], ["ali-tm-pd", /\baliapp\(tm-pd\/([0-9.]+)\)/], ["uc", function (ua) { if (ua.indexOf("ucbrowser/") >= 0) { return /\bucbrowser\/([0-9.]+)/; } else if (ua.indexOf("ubrowser/") >= 0) { return /\bubrowser\/([0-9.]+)/; } else if (/\buc\/[0-9]/.test(ua)) { return /\buc\/([0-9.]+)/; } else if (ua.indexOf("ucweb") >= 0) { // `ucweb/2.0` is compony info. // `UCWEB8.7.2.214/145/800` is browser info. return /\bucweb([0-9.]+)?/; } else { return /\b(?:ucbrowser|uc)\b/; } }], ["baiduboxapp", function (ua) { var back = 0; var a; if (/ baiduboxapp\//i.test(ua)) { a = /([\d+.]+)_(?:diordna|enohpi)_/.exec(ua); if (a) { a = a[1].split("."); back = a.reverse().join("."); } else if ((a = /baiduboxapp\/([\d+.]+)/.exec(ua))) { back = a[1]; } return { version: back, }; } return false; }, ], ["oppobrowser", /\boppobrowser\/([0-9.]+)/], ["edge-android",/ (?:edga)\/([0-9.]+)/], ["chrome", / (?:chrome|crios|crmo)\/([0-9.]+)/], // Android safari ["android", function (ua) { if (ua.indexOf("android") === -1) { return; } return /\bversion\/([0-9.]+(?: beta)?)/; }], ["blackberry", function (ua) { const m = ua.match(re_blackberry_10) || ua.match(re_blackberry_6_7) || ua.match(re_blackberry_4_5); return m ? { version: m[1] } : "blackberry"; }], ["safari", /\bversion\/([0-9.]+(?: beta)?)(?: mobile(?:\/[a-z0-9]+)?)? safari\//], // Safari, WebView ["webview", /\bcpu(?: iphone)? os (?:[0-9._]+).+\bapplewebkit\/([0-9.]+)\b/], ["webview", /os x (?:[0-9._]+).+\bapplewebkit\/([0-9.]+)\b/], ["firefox", /\bfirefox\/([0-9.ab]+)/], ["nokia", /\bnokiabrowser\/([0-9.]+)/] ]; module.exports = { device: DEVICES, os: OS, browser: BROWSER, engine: ENGINE, re_msie: re_msie, }; /***/ }), /***/ 7951: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _EventEmitter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(863); /* harmony import */ var _Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9399); /* harmony import */ var _OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /*** * @augments Node * @augments ChildNode * @augments ParentNode * @augments Element * @augments HTMLElement * @augments EventEmitter * @augments ElementCSSInlineStyle * @constructor */ function AElement() { _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .ZP.call(this); this._azar_extendAttributes = this._azar_extendAttributes || {}; this._azar_extendTags = {}; this.eventHandler = {}; } _OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].mixClass */ .ZP.mixClass(AElement, _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP); AElement.prototype.init = function (props) { Object.assign(this, props || {}); }; AElement.prototype.eventHandler = {}; /*** * run super-class method */ AElement.prototype.super = function () {/* nope */ }; /** * @typedef {Object} AttributeDefiner * @property {Function} set * @property {Function} get * @property {Function} remove * * @param {String} key * @param {AttributeDefiner} def */ AElement.prototype.defineAttribute = function (key, def) { this._azar_extendAttributes[key] = def; }; AElement.prototype.defineAttributes = function (defs) { for (var key in defs) { this.defineAttribute(key, defs[key]); } }; AElement.prototype.attr = function () { if (arguments.length === 1) { if (typeof (arguments[0]) == 'string') { if (this._azar_extendAttributes[arguments[0]]) { return this._azar_extendAttributes[arguments[0]].get.call(this); } else return this.getAttribute(arguments[0]); } else { for (var key in arguments[0]) { this.attr(key, arguments[0][key]); } } } else { if (arguments.length == 2) { if (arguments[1] === null || arguments[1] === undefined) { if (this._azar_extendAttributes[arguments[0]]) { this._azar_extendAttributes[arguments[0]].remove.call(this, arguments[1]); } else this.removeAttribute(arguments[0]); } else { if (this._azar_extendAttributes[arguments[0]]) { this._azar_extendAttributes[arguments[0]].set.call(this, arguments[1]); } else { this.setAttribute(arguments[0], arguments[1]); } } } } return this; }; /*** * add style * @param {CSSStyleDeclaration|string|{}} arg0 * @param {string} arg1 * @returns {this} */ /** * add style * @param {CSSStyleDeclaration|string|{}} arg0 * @param {string|[]=} arg1 * @returns {this} */ AElement.prototype.addStyle = function (arg0, arg1) { if (typeof arg0 == 'string') if (arg0.indexOf('-') >= 0) { if (arg1 && arg1.forEach) { this.style.setProperty.apply(this.style, [arg0].concat(arg1)); } else { this.style.setProperty(arg0, arg1); } } else { this.style[arg0] = arg1; } else { for (var key in arg0) this.addStyle(key, arg0[key]); } return this; }; /*** * * @param {string|string[]|CSSStyleDeclaration} arg0 * @returns {this} */ AElement.prototype.removeStyle = function (arg0) { var key; if (arg0.charAt) { if (arg0.indexOf('-') >= 0) { this.style.removeProperty(arg0); } else { this.style[arg0] = null; delete this.style[arg0]; } } else { if (arg0.map && arg0.forEach) { for (var i = 0; i < arg0.length; ++i) this.removeStyle(arg0[i]); } else { for (key in arg0) this.removeStyle(key); } } return this; }; AElement.prototype.addChild = function (child) { if (child.indexOf && child.map && child.forEach) { for (var i = 0; i < child.length; ++i) this.appendChild(child[i]); } else this.appendChild(child); return this; }; AElement.prototype.addTo = function (parent) { if (parent && parent.appendChild) { if (parent.addChild) parent.addChild(this); else parent.appendChild(this); } else throw Error("Can not append to " + parent + "!"); return this; }; AElement.prototype.selfRemove = function () { if (this.parentElement) this.parentElement.removeChild(this); return this; }; AElement.prototype.selfReplace = function (newNode) { if (this.parentElement) this.parentElement.replaceChild(newNode, this); return this; }; AElement.prototype.clearChild = function () { while (this.lastChild) { this.removeChild(this.lastChild); } return this; }; /** * * @param {string|Array} className * @returns {Boolean} */ AElement.prototype.hasClass = function (className) { return this.classList.contains(className); }; /** * * @param {string|Array} className * @returns {this} */ AElement.prototype.addClass = function (className) { if (className && className.forEach && className.map) { for (var i = 0; i < className.length; ++i) this.classList.add(className[i]); } else this.classList.add(className); return this; }; /** * * @param {string|Array} className * @returns {this} */ AElement.prototype.removeClass = function (className) { if (className && className.forEach && className.map) { for (var i = 0; i < className.length; ++i) this.classList.remove(className[i]); } else this.classList.remove(className); return this; }; AElement.prototype.getComputedStyleValue = function (key) { return window.getComputedStyle(this).getPropertyValue(key); }; AElement.prototype.getFontSize = function () { return parseFloat(this.getComputedStyleValue('font-size').replace('px', '')); }; AElement.prototype.findChildAfter = function (obj) { var r = 0; for (var i = 0; i < this.childNodes.length; ++i) { if (obj == this.childNodes[i]) { r = i + 1; break; } } if (this.childNodes[r]) return this.childNodes[r]; return undefined; }; AElement.prototype.findChildBefore = function (obj) { var r = 0; for (var i = 0; i < this.childNodes.length; ++i) { if (obj == this.childNodes[i]) { r = i - 1; break; } } if (this.childNodes[r]) return this.childNodes[r]; return undefined; }; AElement.prototype.addChildBefore = function (newItem, bf) { this.insertBefore(newItem, bf); return this; }; AElement.prototype.addChildAfter = function (newItem, at) { var atIdx; if (at) { atIdx = Array.prototype.indexOf.call(this.childNodes, at); if (atIdx >= 0) { this.insertBefore(newItem, this.childNodes[atIdx + 1]); } else { throw new Error("Failed to execute 'addChildAfter' on 'Node': The node before which the new node is to be inserted is not a child of this node."); } } else { this.insertBefore(newItem, this.firstChild); } return this; }; /** * @returns {DOMRect} */ AElement.prototype.getBoundingRecursiveRect = function (depth) { if (depth === undefined) depth = 10000; var current, next; var oo = 1000000; var ac = { left: oo, right: -oo, top: oo, bottom: -oo, width: 0, height: 0 }; var stacks = [{ e: this, d: 0 }]; while (stacks.length > 0) { current = stacks.pop(); if (current.e.getBoundingClientRect) { var cRect = current.e.getBoundingClientRect(); if (!cRect || !(cRect.width || cRect.height || cRect.left || cRect.right)) continue; ac.left = Math.min(ac.left, cRect.left); ac.top = Math.min(ac.top, cRect.top); ac.bottom = Math.max(ac.bottom, cRect.bottom); ac.right = Math.max(ac.right, cRect.right); ac.height = ac.bottom - ac.top; ac.width = ac.right - ac.left; var childNodes = current.e.childNodes; if (childNodes && childNodes.length > 0 && current.d < depth) { for (var i = 0; i < childNodes.length; ++i) { next = { e: childNodes[i], d: current.d + 1 }; stacks.push(next); } } } } return ac; }; /*** * * @param parent * @returns {boolean} */ AElement.prototype.isDescendantOf = function (parent) { if (!parent || !parent.childNodes || !parent.childNodes.length) return false; var child = this; while (child) { if (child === parent) return true; child = child.parentNode; } return false; }; /*************************** **********************/ AElement.prototype.getCSSRules = function () { var sheets = document.styleSheets; var ret = []; this.matches = this.matches || this.webkitMatchesSelector || this.mozMatchesSelector || this.msMatchesSelector || this.oMatchesSelector; for (var i in sheets) { if (sheets[i].href) continue;//because can not access, you must clone link node instead var rules = sheets[i].rules || sheets[i].cssRules; for (var r in rules) { if (this.matches(rules[r].selectorText)) { ret.push(rules[r]); } } } return ret; }; /*** * @returns {Promise} */ /*** * WARNING: this function may be unsafe */ AElement.prototype.afterDisplayed = function (requestTimesOut) { if (!requestTimesOut) requestTimesOut = 24 * 3600 * 33; // var tracer = new Error(); var current = this; return new Promise(function (resolve, reject) { function trace() { if (requestTimesOut < 0) { // reject(tracer); // if (absol.BUILD && absol.BUILD.version == "DEBUG") // console.warn("Element not displayed", trace); } else { requestTimesOut--; var bound = current.getBoundingClientRect(); if (bound.width > 0 || bound.height > 0) { resolve(); } else { setTimeout(trace, 33); return; } } } trace(); }); }; !(function () { var origin = AElement.prototype.on; if (_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_1__/* ["default"].isSafari */ .Z.isSafari && !_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_1__/* ["default"].isMobile */ .Z.isMobile && false) {} if (_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_1__/* ["default"].isFirefox */ .Z.isFirefox && false) {} }()); AElement.eventProperties = ["altKey", "bubbles", "button", "buttons", "cancelBubble", "cancelable", "clientX", "clientY", "composed", "ctrlKey", "currentTarget", "defaultPrevented", "deltaMode", "deltaX", "deltaY", "deltaZ", "detail", "eventPhase", "explicitOriginalTarget", "isTrusted", "layerX", "layerY", "metaKey", "movementX", "movementY", "mozInputSource", "mozPressure", "offsetX", "offsetY", "originalTarget", "pageX", "pageY", "rangeOffset", "rangeParent", "region", "relatedTarget", "returnValue", "screenX", "screenY", "shiftKey", "srcElement", "target", "timeStamp", "type", "deltaMode", "deltaX", "deltaY", "deltaZ"]; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (AElement); /***/ }), /***/ 2510: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7951); /* harmony import */ var _OOP__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3349); /*** * @augments AElement * @augments SVGGraphicsElement * @constructor */ function AElementNS() { _AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .Z.call(this); } _AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.afterAttached */ .Z.prototype.afterAttached = function () { if (this.isDescendantOf(document.body)) return Promise.resolve(); var attachHookElt = this.$attachhook || this.querySelector('.absol-attachhook'); if (!attachHookElt) { var constructor; if (this.tagName.toLowerCase() === 'svg' || this.getBBox) { attachHookElt = document.createElementNS('http://www.w3.org/2000/svg', 'image'); attachHookElt.setAttributeNS(null, 'href',''); constructor = AElementNS; } else { attachHookElt = document.createElement('img'); attachHookElt.src = ''; constructor = AElementNS; } attachHookElt.classList.add('absol-attachhook'); Object.assign(attachHookElt, constructor.prototype); constructor.call(attachHookElt); attachHookElt.defineEvent('attached'); this.$attachhook = attachHookElt; this.$attachhook.on('error', function (event) { if (this.isDescendantOf(document.body)) this.emit('attached', event, this); }); this.appendChild(attachHookElt); } return new Promise(function (rs) { attachHookElt.once('attached', rs); }); }; _OOP__WEBPACK_IMPORTED_MODULE_1__/* ["default"].mixClass */ .ZP.mixClass(AElementNS, _AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z); AElementNS.prototype.attr = function () { if (arguments.length == 1) { if (typeof (arguments[0]) == 'string') { if (this._azar_extendAttributes[arguments[0]]) { return this._azar_extendAttributes[arguments[0]].get.call(this); } else return this.getAttributeNS(null, arguments[0]); } else { for (var key in arguments[0]) { this.attr(key, arguments[0][key]); } } } else { if (arguments.length == 2) { if (arguments[1] === null || arguments[1] === undefined) { if (this._azar_extendAttributes[arguments[0]]) { this._azar_extendAttributes[arguments[0]].remove.call(this, arguments[1]); } else this.removeAttributeNS(null, arguments[0]); } else { if (this._azar_extendAttributes[arguments[0]]) { this._azar_extendAttributes[arguments[0]].set.call(this, arguments[1]); } else { this.setAttributeNS(null, arguments[0], arguments[1]); } } } } return this; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (AElementNS); /***/ }), /***/ 5675: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony export AttachHook */ /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7951); /* harmony import */ var _EventEmitter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(863); window.pendingAttachHooks = {}; var pendingId = 0; /*** * @extends AElement * @constructor */ function AttachHook() { this._attached = false; this._canceled = false; this._pendingId = ++pendingId; this._eventAdded = false; this.counter = 0; this.delayTime = 0; } AttachHook.prototype._addAttachedEvent = function () { if (this._eventAdded) return; this.addEventListener('error', function (event) { if (!this._attached && this.isDescendantOf(document.body)) { this._attached = true; if (this.waitTimeout > 0) clearTimeout(this.waitTimeout); delete pendingAttachHooks[this._pendingId]; if (this._canceled) return; this.emit('attached', event, this); } }); this._eventAdded = true; if (!this._canceled) { pendingAttachHooks[this._pendingId] = this; this.waitAttaching(); } }; AttachHook.prototype.eventEmittorOnWithTime = function (isOnce, arg0, arg1, arg2) { if (arg0 === 'attached') { this._addAttachedEvent(); return _AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.eventEmittorOnWithTime.apply */ .Z.prototype.eventEmittorOnWithTime.apply(this, arguments); } else { return _AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.eventEmittorOnWithTime.apply */ .Z.prototype.eventEmittorOnWithTime.apply(this, arguments); } }; /* AttachHook.prototype.on = function () { if (arguments[0] === 'attached') { this._addAttachedEvent(); AElement.prototype.on.apply(this, arguments); } else { AElement.prototype.on.apply(this, arguments); } return this; }; AttachHook.prototype.once = function () { if (arguments[0] === 'attached') { this._addAttachedEvent(); AElement.prototype.once.apply(this, arguments); } else { AElement.prototype.once.apply(this, arguments); } return this; };*/ AttachHook.render = function (data, option, domInstance) { var attributes = {}; var tag; if (domInstance.defaultTag === 'div') { attributes.src = ''; tag = 'img'; } else { tag = 'image'; attributes.href = ''; } return domInstance._({ tag: tag, class: 'absol-attachhook', extendEvent: ['attached'], style: { display: 'none' }, attr: attributes, props: { domInstance: domInstance } }); }; AttachHook.prototype.waitAttaching = function () { if (this._canceled) return; var self = this; // if (BrowserDetector.browser.type.startsWith('chrome') && parseInt((BrowserDetector.browser.version || '').split('.').shift()) >= 113) { if (this.waitTimeout > 0) clearTimeout(this.waitTimeout); this.waitTimeout = setTimeout(function wait() { self.waitTimeout = -1; self.counter++; if (self.counter === 1) self.delayTime = 10; else if (self.counter === 5) self.delayTime = 30; else if (self.counter === 50) self.delayTime = 60; else if (self.counter === 100) self.delayTime = 100; else if (self.counter === 500) self.delayTime = 1000; if (!self._attached && self.isDescendantOf(document.body)) { self._attached = true; delete pendingAttachHooks[self._pendingId]; if (self._canceled) return; self.emit('attached', { target: this }, self); } else if (!self._attached && !self._canceled) { self.waitTimeout = setTimeout(wait, self.delayTime); } }, this.delayTime); // } }; AttachHook.prototype.cancelWaiting = function () { if (this.waitTimeout > 0) clearTimeout(this.waitTimeout); this._canceled = true; delete pendingAttachHooks[this._pendingId]; } AttachHook.prototype.resetState = function () { if (this.waitTimeout > 0) clearTimeout(this.waitTimeout); this._attached = false; this._canceled = false; this.counter = 0; this.delayTime = 1; if (this.tagName.toLowerCase() === 'img') { this.attr('src', ''); } else { this.attr('href', ''); } pendingAttachHooks[this._pendingId] = this; this.waitAttaching(); }; AttachHook.property = { attached: { get: function () { return !!this._attached; } }, canceled: { get: function () { return !!this._canceled; } } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (AttachHook); /***/ }), /***/ 5164: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "copyImage": () => (/* binding */ copyImage), /* harmony export */ "copyText": () => (/* binding */ copyText), /* harmony export */ "pasteText": () => (/* binding */ pasteText) /* harmony export */ }); function copyImage(src) { var ranges, sel; if (window.getSelection) { sel = window.getSelection(); //backup ranges = []; for (var i = 0; i < sel.rangeCount; ++i) { ranges.push(sel.getRangeAt(i)); } //copy var contentdiv = document.createElement('div'); var image = document.createElement('img'); contentdiv.appendChild(image); image.src = src; contentdiv.contentEditable = true; // contentdiv.style.display = 'none'; document.body.appendChild(contentdiv); var range = document.createRange(); range.selectNodeContents(image); sel.removeAllRanges(); sel.addRange(range); document.execCommand('copy'); // contentdiv.remove(); //recover sel.removeAllRanges(); for (var i = 0; i < sel.rangeCount; ++i) { sel.addRange(ranges[i]); } } else { console.error("Not support copy!") //not support IE } } function fallbackCopyTextToClipboard(text) { return new Promise(function (resolve, reject) { var textArea = document.createElement("textarea"); textArea.value = text; // Avoid scrolling to bottom textArea.style.top = "0"; textArea.style.left = "0"; textArea.style.position = "fixed"; document.body.appendChild(textArea); textArea.focus(); textArea.select(); try { var successful = document.execCommand('copy'); if (successful) { resolve(); } else { reject(); } } catch (err) { reject(err); } document.body.removeChild(textArea); }); } function copyText(text) { if (!navigator.clipboard) { return fallbackCopyTextToClipboard(text); } return navigator.clipboard.writeText(text); } function fallbackReadTextFromClipboard() { return new Promise(function (resolve, reject) { var textArea = document.createElement("textarea"); // Avoid scrolling to bottom textArea.style.top = "0"; textArea.style.left = "0"; textArea.style.position = "fixed"; document.body.appendChild(textArea); textArea.focus(); try { var successful = document.execCommand('paste'); if (successful) { resolve(textArea.value); } else { reject(); } } catch (err) { reject(err); } document.body.removeChild(textArea); }); } function pasteText() { if (navigator.clipboard) { return navigator.clipboard.readText(); } else { return fallbackReadTextFromClipboard(); } } /***/ }), /***/ 8098: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _EventEmitter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(863); /* harmony import */ var _OOP__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3349); /** * @extends EventEmitter * @constructor */ function DelaySignal() { _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .ZP.call(this); this.signals = {}; this.to = this.NO_WAIT; this.execSignal = this.execSignal.bind(this); } (0,_OOP__WEBPACK_IMPORTED_MODULE_1__/* .mixClass */ .Jx)(DelaySignal, _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP); DelaySignal.NO_WAIT = -1; DelaySignal.prototype.NO_WAIT = DelaySignal.NO_WAIT; DelaySignal.prototype.delay = 4; DelaySignal.prototype.execSignal = function () { this.to = this.NO_WAIT; var signals = this.signals; this.signals = {}; for (var name in signals) { this.fire.apply(this, [name].concat(signals[name])); } }; DelaySignal.prototype.emit = function (name) { this.signals[name] = Array.prototype.slice.call(arguments, 1); if (this.to === this.NO_WAIT) { if (window.Thread && window.Thread.setTimeout) { this.to = window.Thread.setTimeout({ func: this.execSignal, time: this.delay, type: 'background', args: [] }); } else { this.to = setTimeout(this.execSignal, this.delay); } } return this; }; DelaySignal.prototype.revokeResource = function () { if (this.to !== this.NO_WAIT) { clearTimeout(this.to); } delete this.signals; delete this.execSignal; } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DelaySignal); /***/ }), /***/ 6628: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "E7": () => (/* binding */ copyStyleRule), "ZP": () => (/* binding */ HTML5_Dom), "qE": () => (/* binding */ depthClone), "tE": () => (/* binding */ getScreenSize), "Z4": () => (/* binding */ getSystemFontSize), "m1": () => (/* binding */ getTextNodeBound), "mV": () => (/* binding */ isDomNode), "DI": () => (/* binding */ traceOutBoundingClientRect), "Lp": () => (/* binding */ waitImageLoaded) }); // UNUSED EXPORTS: FeatureClass, activeFullScreen, deactiveFullScreen, depthCloneWithStyle, fontFaceIsLoaded, getConstructDescriptor, getScrollSize, imageToCanvas, inactiveFullScreen, isFullScreen, isVisibilityOnScreen, waitIFrameLoaded // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/JSPath.js var JSPath = __webpack_require__(8706); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); ;// CONCATENATED MODULE: ./node_modules/absol/src/String/getFunctionName.js /** * * @param {Function} func */ function getFunctionName(func) { var ret = func.toString(); ret = ret.substr('function '.length); ret = ret.substr(0, ret.indexOf('(')); return ret; } // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ElementNS.js var ElementNS = __webpack_require__(1321); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElement.js var AElement = __webpack_require__(7951); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ResizeSystem.js var ResizeSystem = __webpack_require__(6700); // EXTERNAL MODULE: ./node_modules/absol/src/JSX/attribute.js + 1 modules var attribute = __webpack_require__(2953); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AttachHook.js var AttachHook = __webpack_require__(5675); ;// CONCATENATED MODULE: ./node_modules/absol/src/HTML5/Dom.js /*** * @typedef {{"accept-charset":string, "http-equiv": string, accept : string, accesskey : string, action : string, align : string, allow : string, alt : string, async : string, autocapitalize : string, autocomplete : string, autofocus : string, autoplay : string, background : string, bgcolor : string, border : string, buffered : string, capture : string, challenge : string, charset : string, checked : string, cite : string, class : string, code : string, codebase : string, color : string, cols : string, colspan : string, content : string, contenteditable : string, contextmenu : string, controls : string, coords : string, crossorigin : string, csp : string, data : string, "data-*" : string, datetime : string, decoding : string, default : string, defer : string, dir : string, dirname : string, disabled : string, download : string, draggable : string, dropzone : string, enctype : string, enterkeyhint : string, for : string, form : string, formaction : string, formenctype : string, formmethod : string, formnovalidate : string, formtarget : string, headers : string, height : string, hidden : string, high : string, href : string, hreflang : string, icon : string, id : string, importance : string, integrity : string, intrinsicsize : string, inputmode : string, ismap : string, itemprop : string, keytype : string, kind : string, label : string, lang : string, language : string, loading : string, list : string, loop : string, low : string, manifest : string, max : string, maxlength : string, minlength : string, media : string, method : string, min : string, multiple : string, muted : string, name : string, novalidate : string, open : string, optimum : string, pattern : string, ping : string, placeholder : string, poster : string, preload : string, radiogroup : string, readonly : string, referrerpolicy : string, rel : string, required : string, reversed : string, rows : string, rowspan : string, sandbox : string, scope : string, scoped : string, selected : string, shape : string, size : string, sizes : string, slot : string, span : string, spellcheck : string, src : string, srcdoc : string, srclang : string, srcset : string, start : string, step : string, style : string, summary : string, tabindex : string, target : string, title : string, translate : string, type : string, usemap : string, value : string, width : string, wrap : string, }} AElementAttributeDescriptor */ /** * @typedef {{"arabic-form":string,"baseline-shift": string, "accent-height": string, "alignment-baseline": string, "cap-height": string, "clip-path": string, "clip-rule": string, "color-dinterpolation": string, "color-interpolation-filters": string, "color-profile": string, "color-rendering": string, "dominant-baseline": string, "enable-background": string, "fill-opacity": string, "fill-rule": string, "flood-color": string, "flood-opacity": string, "font-family": string, "font-size": string, "font-size-adjust": string, "font-stretch": string, "font-style": string, "font-variant": string, "font-weight": string, "glyph-name": string, "glyph-orientation-horizontal": string, "glyph-orientation-vertical": string, "horiz-adv-x": string, "horiz-origin-x": string, "image-rendering": string, "letter-spacing": string, "lighting-color": string, "marker-end": string, "marker-mid": string, "marker-start": string, "overline-position": string, "overline-thickness": string, "panose-1": string, "paint-order": string, "pointer-events": string, "rendering-intent": string, "shape-rendering": string, "stop-color": string, "stop-opacity": string, "strikethrough-position": string, "strikethrough-thickness": string, "stroke-dasharray": string, "stroke-dashoffset": string, "stroke-linecap": string, "stroke-linejoin": string, "stroke-miterlimit": string, "stroke-opacity": string, "stroke-width": string, "text-anchor": string, "text-decoration": string, "text-rendering": string, "transform-origin": string, "underline-position": string, "underline-thickness": string, "unicode-bidi": string, "unicode-range": string, "units-per-em": string, "v-alphabetic": string, "v-hanging": string, "v-ideographic": string, "v-mathematical": string, "vector-effect": string, "vert-adv-y": string, "vert-origin-x": string, "vert-origin-y": string, "word-spacing": string, "writing-mode": string, "x-height": string, "xlink:actuate": string, "xlink:arcrole": string, "xlink:href": string, "xlink:role": string, "xlink:show": string, "xlink:title": string, "xlink:type": string, "xml:base": string, "xml:lang": string, "xml:space": string, accumulate:string, additive:string, allowReorder:string, alphabetic:string, amplitude:string, ascent:string, attributeName:string, attributeType:string, autoReverse:string, azimuth:string, baseFrequency:string, baseProfile:string, bbox:string, begin:string, bias:string, by:string, calcMode:string, class:string, clip:string, clipPathUnits:string, color:string, contentScriptType:string, contentStyleType:string, cursor:string, cx:string, cy:string, d:string, decelerate:string, descent:string, diffuseConstant:string, direction:string, display:string, divisor:string, dur:string, dx:string, dy:string, edgeMode:string, elevation:string, end:string, exponent:string, externalResourcesRequired:string, fill:NamedColor|Color|string, filter:string, filterRes:string, filterUnits:string, format:string, from:string, fr:string, fx:string, fy:string, g1:string, g2:string, glyphRef:string, gradientTransform:string, gradientUnits:string, hanging:string, height:string, href:string, hreflang:string, id:string, ideographic:string, in:string, in2:string, intercept:string, k:string, k1:string, k2:string, k3:string, k4:string, kernelMatrix:string, kernelUnitLength:string, kerning:string, keyPoints:string, keySplines:string, keyTimes:string, lang:string, lengthAdjust:string, limitingConeAngle:string, local:string, markerHeight:string, markerUnits:string, markerWidth:string, mask:string, maskContentUnits:string, maskUnits:string, mathematical:string, max:string, media:string, method:string, min:string, mode:string, name:string, numOctaves:string, offset:string, opacity:string, operator:string, order:string, orient:string, orientation:string, origin:string, overflow:string, path:string, pathLength:string, patternContentUnits:string, patternTransform:string, patternUnits:string, ping:string, points:string, pointsAtX:string, pointsAtY:string, pointsAtZ:string, preserveAlpha:string, preserveAspectRatio:string, primitiveUnits:string, r:string, radius:string, referrerPolicy:string, refX:string, refY:string, rel:string, repeatCount:string, repeatDur:string, requiredExtensions:string, requiredFeatures:string, restart:string, result:string, rotate:string, rx:string, ry:string, scale:string, seed:string, slope:string, spacing:string, specularConstant:string, specularExponent:string, speed:string, spreadMethod:string, startOffset:string, stdDeviation:string, stemh:string, stemv:string, stitchTiles:string, string:string, stroke:string, style:string, surfaceScale:string, systemLanguage:string, tabindex:string, tableValues:string, target:string, targetX:string, targetY:string, textLength:string, to:string, transform:string, type:string, u1:string, u2:string, unicode:string, values:string, version:string, viewBox:string, viewTarget:string, visibility:string, width:string, widths:string, x:string, x1:string, x2:string, xChannelSelector:string, y:string, y1:string, y2:string, yChannelSelector:string, z:string, zoomAndPan:string, }} AElementNSAttributeDescriptor */ /*** * @typedef {{abort:function(event:(UiEvent|Event)):void,afterprint:function(event:Event):void,animationend:function(event:AnimationEvent):void,animationiteration:function(event:AnimationEvent):void,animationstart:function(event:AnimationEvent):void,beforeprint:function(event:Event):void,beforeunload:function(event:(UiEvent|Event)):void,blur:function(event:FocusEvent):void,canplay:function(event:Event):void,canplaythrough:function(event:Event):void,change:function(event:Event):void,click:function(event:MouseEvent):void,contextmenu:function(event:MouseEvent):void,copy:function(event:ClipboardEvent):void,cut:function(event:ClipboardEvent):void,dblclick:function(event:MouseEvent):void,drag:function(event:DragEvent):void,dragend:function(event:DragEvent):void,dragenter:function(event:DragEvent):void,dragleave:function(event:DragEvent):void,dragover:function(event:DragEvent):void,dragstart:function(event:DragEvent):void,drop:function(event:DragEvent):void,durationchange:function(event:Event):void,ended:function(event:Event):void,error:function(event:(ProgressEvent|UiEvent|Event)):void,focus:function(event:FocusEvent):void,focusin:function(event:FocusEvent):void,focusout:function(event:FocusEvent):void,fullscreenchange:function(event:Event):void,fullscreenerror:function(event:Event):void,hashchange:function(event:HashChangeEvent):void,input:function(event:(InputEvent|Event)):void,invalid:function(event:Event):void,keydown:function(event:KeyboardEvent):void,keypress:function(event:KeyboardEvent):void,keyup:function(event:KeyboardEvent):void,load:function(event:(UiEvent|Event)):void,loadeddata:function(event:Event):void,loadedmetadata:function(event:Event):void,loadstart:function(event:ProgressEvent):void,message:function(event:Event):void,mousedown:function(event:MouseEvent):void,mouseenter:function(event:MouseEvent):void,mouseleave:function(event:MouseEvent):void,mousemove:function(event:MouseEvent):void,mouseover:function(event:MouseEvent):void,mouseout:function(event:MouseEvent):void,mouseup:function(event:MouseEvent):void,mousewheel:function(event:WheelEvent):void,offline:function(event:Event):void,online:function(event:Event):void,open:function(event:Event):void,pagehide:function(event:PageTransitionEvent):void,pageshow:function(event:PageTransitionEvent):void,paste:function(event:ClipboardEvent):void,pause:function(event:Event):void,play:function(event:Event):void,playing:function(event:Event):void,popstate:function(event:PopStateEvent):void,progress:function(event:Event):void,ratechange:function(event:Event):void,resize:function(event:(UiEvent|Event)):void,reset:function(event:Event):void,scroll:function(event:(UiEvent|Event)):void,search:function(event:Event):void,seeked:function(event:Event):void,seeking:function(event:Event):void,select:function(event:(UiEvent|Event)):void,show:function(event:Event):void,stalled:function(event:Event):void,storage:function(event:StorageEvent):void,submit:function(event:Event):void,suspend:function(event:Event):void,timeupdate:function(event:Event):void,toggle:function(event:Event):void,touchcancel:function(event:TouchEvent):void,touchend:function(event:TouchEvent):void,touchmove:function(event:TouchEvent):void,touchstart:function(event:TouchEvent):void,transitionend:function(event:TransitionEvent):void,unload:function(event:(UiEvent|Event)):void,volumechange:function(event:Event):void,waiting:function(event:Event):void,wheel:function(event:WheelEvent):void}} AElementEventDescriptor */ /*** * @typedef AbsolConstructDescriptor * @property {string | function |null} tag * @property {CSSStyleDeclaration} style * @property {Array | string} extendEvent * @property {Array | string} class * @property {Object} data * @property {AElementAttributeDescriptor|AElementNSAttributeDescriptor} attr * @property {string|AElement | AElementNS | AbsolConstructDescriptor | string[] |AElement[] | AElementNS[] | AbsolConstructDescriptor[]} child * @property {string} text to create a TextNode, not Element * @property {AElement} elt * @property {AElementEventDescriptor|{}} on * @property {Object} props * */ var svgCreator = function () { var temp = document.createElement('div'); temp.innerHTML = '<svg version="1.1" xmlns="http://www.w3.org/2000/svg"></svg>'; var element = temp.childNodes[0]; var prototypes = Object.getOwnPropertyDescriptors(AElement/* default.prototype */.Z.prototype); Object.defineProperties(element, prototypes); AElement/* default.call */.Z.call(element); return element; }; /*** * * @param {*=} option * @constructor */ function Dom(option) { option = option || {}; this.creator = option.creator || {}; Object.defineProperties(this.creator, { svg: { set: function () { //do nothing }, get: function () { return svgCreator; } }, attachhook: { set: function () { //do nothing }, get: function () { return AttachHook/* default */.Z; } } }); this['$ '.trim()] = this.$.bind(this); this['_ '.trim()] = this._.bind(this); this['$' + '$'] = this.$$.bind(this); this.buildDom = this._; } Dom.prototype.defaultTag = 'div'; Dom.prototype.fromCode = function (code) { code = code.trim().replace(/>\s+</gm, '><'); var temTag = 'div'; if (code.startsWith('<td') || (code.startsWith('<th') && !code.startsWith('<thead'))) temTag = 'tr'; else if (code.startsWith('<tr')) temTag = 'tbody'; else if (code.startsWith('<thead') || code.startsWith('<tbody')) temTag = 'table'; var tempDiv = document.createElement(temTag); tempDiv.innerHTML = code; var element = tempDiv.childNodes[0]; var prototypes = Object.getOwnPropertyDescriptors(AElement/* default.prototype */.Z.prototype); Object.defineProperties(element, prototypes); AElement/* default.call */.Z.call(element); return element; }; /** * DFS * @param {string | AElement} query * @param {AElement} root * @param {function} onFound - return true to stop find * @returns {AElement | AElementNS} */ Dom.prototype.$ = function (query, root, onFound) { var res; if (Dom.isDomNode(query)) res = query; else res = this.select(query, root, onFound); if (res) this.attach(res); return res; }; /*** * * @type {function(string, AElement, Function): AElement} */ Dom.prototype.selectAttacth = Dom.prototype.$; /** * DFS * @param {string} query * @param {AElement} root * @param {function} onFound - return true to stop find */ Dom.prototype.select = function (query, root, onFound) { root = root || document.documentElement; var matcher = JSPath/* default.compileJSPath */.Z.compileJSPath(query); return matcher.findFirst(root, onFound); }; var FeatureClass = { AElementNS: { constructor: ElementNS/* default */.Z, prototypeKeys: Object.keys(ElementNS/* default.prototype */.Z.prototype) }, AElement: { constructor: AElement/* default */.Z, prototypeKeys: Object.keys(AElement/* default.prototype */.Z.prototype) } }; /** * * @param {AElement | AElementNS } element */ Dom.prototype.attach = function (element) { if (element.attr) return; var feature = (element.getBBox && element.tagName !== 'svg') ? FeatureClass.AElementNS : FeatureClass.AElement; var elementConstructor = feature.constructor; var proto = elementConstructor.prototype; var prototypeKeys = feature.prototypeKeys; var n = prototypeKeys.length; var key; for (var i = 0; i < n; ++i) { key = prototypeKeys[i]; element[key] = proto[key]; } Object.assign(element, elementConstructor.prototype) elementConstructor.call(element); }; Dom.prototype.makeNewElement = function (tagName) { return document.createElement(tagName); }; Dom.prototype.makeNewTextNode = function (data) { return document.createTextNode(data); }; /** * * @param {AbsolConstructDescriptor | string | {} } option * @param {boolean=} isInherited * @returns {AElementNS| AElement | Text} */ Dom.prototype._ = function (option, isInherited) { var res; var creator; if (Dom.isDomNode(option)) { res = option; option = {}; /** fix reinit component */ isInherited = true; } else { if (option.charAt) { option = option.trim(); if (option[0] === '<') { res = this.fromCode(option); option = {}; } else { var queryObj = JSPath/* default.parseQuery */.Z.parseQuery(option); option = {}; option.tag = queryObj.tagName || this.defaultTag; if (queryObj.classList && queryObj.classList.length > 0) option.class = queryObj.classList; if (queryObj.id) option.id = queryObj.id; if (queryObj.attributes) option.attr = queryObj.attributes; } } } if (option.text || option.text === '') {//is textNode return this.makeNewTextNode(option.text); } option.tag = option.tag || this.defaultTag; creator = option.tag.prototype ? option.tag : this.creator[option.tag]; if (option.tag.prototype) option.tag = option.tag.tag; if (option.elt) { res = this._(option.elt); } else { if (!res) { if (creator) { if (creator.render) { res = creator.render(option.data, option, this); } else { res = creator(option.data, option, this); } } else { res = this.makeNewElement(option.tag); Object.assign(res, option.data); } } } this.attach(res); if (creator) { res._azar_extendTags = res._azar_extendTags || {}; res._azar_extendTags[option.tag] = creator; creator.property && Object.defineProperties(res, creator.property); creator.prototype && OOP/* default.extends */.ZP["extends"](res, creator.prototype); creator.attribute && res.defineAttributes(creator.attribute); if (creator.render) { if (creator.eventHandler) { res.eventHandler = res.eventHandler || {}; var eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, creator.eventHandler || creator.prototype.eventHandler); for (var eventHandlerKey in eventHandler) { if (res.eventHandler[eventHandlerKey]) { throw new Error("Same name of eventHandler[" + eventHandlerKey + "]"); } else { res.eventHandler[eventHandlerKey] = eventHandler[eventHandlerKey]; } } } creator.call(res); } } option.extendEvent && res.defineEvent(option.extendEvent); option.attr && res.attr(option.attr); option.on && res.on(option.on); option.once && res.once(option.once); option.class && res.addClass(option.class); option.style && res.addStyle(option.style); option.id && res.attr('id', option.id); if (!isInherited) res.init(option.props); var children = option.child; if (children) { if (!children.forEach || !children.map) { children = [children]; } for (var i = 0; i < children.length; ++i) { res.addChild(this._(children[i], false)); } } return res; }; /*** * * @type {function(Object, boolean): AElement} */ Dom.prototype.create = Dom.prototype._; /*** * * @param query * @param root * @returns {Array<AElement|AElementNS>} */ Dom.prototype.$$ = function (query, root) { var thisD = this; var res = []; this.selectAttacth(query, root, function (elt) { thisD.attach(elt); res.push(elt); }); return res; }; Dom.prototype.install = function (arg0, arg1) { var _this = this; if (arguments.length === 1) { if (arg0.creator && arg0.create && arg0.select) { // is a dom core var creator = arg0.creator; Object.keys(creator).forEach(function (key) { if (key.startsWith('_') || key.startsWith('$')) return; var func = creator[key]; if (typeof (func) == 'function') if (_this.creator[key] !== func) _this.creator[key] = func; }); } else if (typeof (arg0) == 'function') { var name = arg0.tag || getFunctionName(arg0) || arg0.name; if (name) { this.creator[name.toLowerCase()] = arg0; } else { console.error('No ident name of creator function', arg0); } } else if (arg0 instanceof Array) { arg0.forEach(function (func) { var name = func.tag || getFunctionName(func) || func.name; if (name) { _this.creator[name.toLowerCase()] = func; } }); } else if (typeof arg0 == 'object') { Object.keys(arg0).forEach(function (key) { if (key.startsWith('_') || key.startsWith('$')) return; var func = arg0[key]; if (typeof (func) == 'function') if (_this.creator[key] !== func) _this.creator[key] = func; }); } else { console.error('Unknown data', arg0); } } else if (arguments.length === 2) { if (arg0 instanceof Array) { if (arg1.creator) arg1 = arg1.creator; arg0.forEach(function (key) { var func = arg1[key]; if (typeof (func) == 'function') if (_this.creator[key] !== func) _this.creator[key] = func; }); } else if (arg0 instanceof RegExp) { if (arg1.creator) arg1 = arg1.creator; Object.keys(arg1).forEach(function (key) { if (key.match(arg0)) { var func = arg1[key]; if (typeof (func) == 'function') if (_this.creator[key] !== func) _this.creator[key] = func; } }); } else if (typeof (arg0) == 'string' && arg0.length > 0) { if (typeof (arg1) == 'function') { this.creator[arg0] = arg1; } else { console.error('arg1 is not a function'); } } } else { console.error('Invalid param'); } return this; }; /*** * * @param {String | null} tagName */ Dom.prototype.require = function (tagName) { return this.creator[tagName] || null; }; /** * * @param {*} o * @returns {Boolean} */ function isDomNode(o) { return ( typeof Node === "object" ? o instanceof Node : o && typeof o === "object" && typeof o.nodeType === "number" && typeof o.nodeName === "string" ); } Dom.isDomNode = isDomNode; /** * @param {AElement|Node|HTMLElement} element */ function activeFullScreen(element) { if (element.requestFullscreen) { element.requestFullscreen(); } else if (element.mozRequestFullScreen) { element.mozRequestFullScreen(); } else if (element.webkitRequestFullscreen) { element.webkitRequestFullscreen(AElement/* default.ALLOW_KEYBOARD_INPUT */.Z.ALLOW_KEYBOARD_INPUT); } else if (element.msRequestFullscreen) { element.msRequestFullscreen(); } } Dom.activeFullScreen = activeFullScreen; function inactiveFullScreen() { if (document.exitFullscreen) { document.exitFullscreen(); } else if (document.mozCancelFullScreen) { document.mozCancelFullScreen(); } else if (document.webkitExitFullscreen) { document.webkitExitFullscreen(); } else if (document.msExitFullscreen) { document.msExitFullscreen(); } } Dom.inactiveFullScreen = inactiveFullScreen; //adapt var deactiveFullScreen = inactiveFullScreen; Dom.deactiveFullScreen = deactiveFullScreen; function isFullScreen() { var fullScreenElement = document.fullscreenElement || document.webkitFullscreenElement || document.mozFullScreenElement || document.msFullscreenElement; return !!fullScreenElement; } Dom.isFullScreen = isFullScreen; /** * @param {AElement|Node|HTMLElement} current * @returns {ClientRect} */ function traceOutBoundingClientRect(current) { var screenSize = Dom.getScreenSize(); var left = 0; var right = screenSize.width; var top = 0; var bottom = screenSize.height; var ox, oy, fixed; var bound; while (current) { fixed = AElement/* default.prototype.getComputedStyleValue.call */.Z.prototype.getComputedStyleValue.call(current, 'position') == "fixed"; ox = AElement/* default.prototype.getComputedStyleValue.call */.Z.prototype.getComputedStyleValue.call(current, 'overflow-x') !== "visible"; oy = AElement/* default.prototype.getComputedStyleValue.call */.Z.prototype.getComputedStyleValue.call(current, 'overflow-y') !== "visible"; var isHtml = current.tagName.toLowerCase() === 'html'; if (ox || oy || isHtml || fixed) { if (isHtml) { bound = Object.assign({ left: 0, top: 0 }, getScreenSize()); bound.bottom = bound.height; bound.right = bound.width; } else { bound = current.getBoundingClientRect(); } if (ox || isHtml || fixed) { left = Math.max(left, bound.left); right = Math.min(right, bound.right); } if (oy || isHtml || fixed) { top = Math.max(top, bound.top); bottom = Math.min(bottom, bound.bottom); } } if (isHtml || fixed) break; current = current.parentElement; } return { left: left, right: right, top: top, bottom: bottom, width: right - left, height: bottom - top }; } Dom.traceOutBoundingClientRect = traceOutBoundingClientRect; /*** * * @param {string} fontFace * @param {number} timeout * @returns {Promise<boolean>} */ function fontFaceIsLoaded(fontFace, timeout) { timeout = timeout || 0; var element = this.ShareInstance._({ tag: 'span', style: { visibility: 'hidden', position: 'fixed', top: '-9999px', left: '-9999px', 'font-size': '256px' }, props: { innerHTML: "Test string long long long" } }); element.addTo(document.body); return element.afterAttached().then(function () { var lastOffsetWidth = element.getBoundingClientRect().width; element.addStyle('font-family', fontFace); return new Promise(function (resolve, reject) { function check(remainTime) { if (remainTime < 0) { resolve(false); element.selfRemove(); } else requestAnimationFrame(function () { var currentOffsetWidth = element.getBoundingClientRect().width; if (currentOffsetWidth != lastOffsetWidth) { resolve(true); element.selfRemove(); } else check(remainTime - 10); }); } check(timeout); }); }); } Dom.fontFaceIsLoaded = fontFaceIsLoaded; /*** * * @returns {{width: number, WIDTH: number, HEIGHT: number, height: number}} */ function getScreenSize() { var width = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; var height = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; return { WIDTH: width, HEIGHT: height, width: width, height: height }; } Dom.getScreenSize = getScreenSize; /*** * * @param {HTMLImageElement} img * @param {number=} timeout * @returns {Promise<void>} */ function waitImageLoaded(img, timeout) { var isLoaded = true; if (!img.complete) { isLoaded = false; } if (img.naturalWidth === 0) { isLoaded = false; } if (isLoaded) return Promise.resolve(); if (!img.src) return Promise.resolve(); return new Promise(function (rs) { if (img.addEventListener) { img.addEventListener('load', rs, false); img.addEventListener('error', rs, false); } else { img.attachEvent('onload', rs, false); } setTimeout(rs, timeout || 5000); }); // No other way of checking: assume it’s ok. } Dom.waitImageLoaded = waitImageLoaded; /*** * * @param {HTMLIFrameElement| Worker} iframe * @returns {Promise} */ function waitIFrameLoaded(iframe) { return new Promise(function (rs, rj) { if (document.all) { iframe.onreadystatechange = function () { if (iframe.readyState === "complete" || iframe.readyState === "loaded") rs(); }; } else { iframe.onload = rs; } setTimeout(rs, 5000) }); } Dom.waitIFrameLoaded = waitIFrameLoaded; /*** * * @param {Image} element * @returns {Promise<HTMLCanvasElement>} */ function imageToCanvas(element) { if (typeof element == 'string') { element = Dom.ShareInstance.$(element); } if (element.tagName.toLowerCase() === 'img') { var preRender = Dom.ShareInstance._('div'); preRender.addStyle({ position: 'fixed', top: '0', left: '0', zIndex: '-10000', opacity: '0' }).addTo(document.body); var canvas = document.createElement("canvas"); preRender.addChild(canvas); return Dom.waitImageLoaded(element).then(function () { canvas.width = element.width; canvas.height = element.height; var context = canvas.getContext("2d"); context.drawImage(element, 0, 0); preRender.selfRemove(); return canvas; }); } else { throw new Error("AElement must be image"); } } Dom.imageToCanvas = imageToCanvas; Dom.ShareInstance = new Dom(); Dom.scrollWidthPromise; Dom.documentReady = new Promise(function (resolve) { if (document.body) { resolve(); } else { window.addEventListener("load", resolve); } }); function getScrollSize() { if (!Dom.scrollWidthPromise) Dom.scrollWidthPromise = new Promise(function (resolve) { function prerender() { var parent = Dom.ShareInstance._({ style: { 'z-index': '-100', opacity: '0', width: '100px', height: '100px', overflow: 'scroll', top: '0', left: '0', 'box-sizing': 'content-box', position: 'fixed' } }) .addTo(document.body); var child = Dom.ShareInstance._({ style: { width: '100%', height: '100%' } }).addTo(parent); requestAnimationFrame(function () { var parentBound = parent.getBoundingClientRect(); var childBound = child.getBoundingClientRect(); resolve({ width: parentBound.width - childBound.width, height: parentBound.height - childBound.height }); parent.selfRemove(); }); } Dom.documentReady.then(prerender); }); return Dom.scrollWidthPromise; } Dom.getScrollSize = getScrollSize; /*** * * @param {(AElement|AElementNS|Node)} originElt * @param {function(originElt: (AElement|AElementNS|Node), originElt: (AElement|AElementNS|Node)):void } afterCloneCb * @return {AElement|AElementNS|Node} */ function depthClone(originElt, afterCloneCb) { /*** * * @type {AElement|AElementNS|Node} */ var newElt = originElt.cloneNode();//no deep if (originElt.childNodes) { /*** * * @type {(AElement|AElementNS)[]} */ var children = Array.prototype.map.call(originElt.childNodes, function (child) { return depthClone(child, afterCloneCb) }); for (var i = 0; i < children.length; ++i) { newElt.appendChild(children[i]); } } return (afterCloneCb && afterCloneCb(originElt, newElt)) || newElt; } /*** * * @param originElt * @param afterCloneCb * @returns {AElement|HTMLElement|Node} */ function depthCloneWithStyle(originElt, afterCloneCb) { return depthClone(originElt, function (originElt, newElt) { if (!originElt.getAttribute && !originElt.getAttributeNS) return; copyStyleRule(originElt, newElt); afterCloneCb && afterCloneCb(originElt, newElt); }); } Dom.depthClone = depthClone; Dom.depthCloneWithStyle = depthCloneWithStyle; /*** * * @param {AElement|HTMLElement|Node}sourceElt * @param {AElement|HTMLElement|Node} destElt * @returns {AElement|HTMLElement|Node} */ function copyStyleRule(sourceElt, destElt) { if (!sourceElt.getAttribute && !sourceElt.getAttributeNS) return destElt;//is text node if (!destElt.getAttribute && !destElt.getAttributeNS) return destElt;//is text node, nothing to copy var cssRules = AElement/* default.prototype.getCSSRules.call */.Z.prototype.getCSSRules.call(sourceElt); var cssKey = cssRules.reduce(function (ac, rule) { for (var i = 0; i < rule.style.length; ++i) { ac[rule.style[i]] = true; } return ac; }, {}); for (var key in cssKey) { destElt.style[key] = AElement/* default.prototype.getComputedStyleValue.call */.Z.prototype.getComputedStyleValue.call(sourceElt, key); } return destElt; } Dom.copyStyleRule = copyStyleRule; /** * */ function getSystemFontSize() { if (window.mobileHost && window.mobileHost.systemFont) { return window.mobileHost.systemFont.pointSize; } var _ = Dom.ShareInstance._; var initSpan = Dom.ShareInstance._({ tag: 'span', style: { font: 'inherit', } }); var appleSpan = Dom.ShareInstance._({ tag: 'span', style: { font: '-apple-system-body', } }).addTo(document.body); var renderer = _({ style: { font: 'initial', position: 'fixed', top: 0, left: 0, visibility: 'hidden', opacity: 0, zIndex: -100 }, child: [initSpan && appleSpan] }).addTo(document.body); var appleSize = appleSpan.getFontSize(); var initSize = initSpan.getFontSize(); var defaultSize = appleSize !== initSize ? appleSize : initSize; renderer.remove(); return Math.round(defaultSize * 14 / 16); } function getTextNodeBound(textNode) { if (document.createRange) { var range = document.createRange(); range.selectNodeContents(textNode); if (range.getBoundingClientRect) { return range.getBoundingClientRect(); } } return null; } Dom.getTextNodeBound = getTextNodeBound; /*** * get absol construct descriptor for HTML element only * @param {AElement | Text} elt * @returns {AbsolConstructDescriptor} */ function getConstructDescriptor(elt) { var obj = {}; obj.tag = elt.tagName.toLowerCase(); var classAttr = elt.getAttribute('class'); var classList; if (classAttr) classList = (0,attribute.parseClassAttr)(classAttr); if (classList && classList.length > 0) obj.class = classList; var styleAttr = elt.getAttribute('style'); var style; if (styleAttr) style = (0,attribute.parseStyleAttr)(styleAttr); var attributes = elt.attributes; var attNode; var attrName; var attrValue; var attr = {}; var on = {}; var props = {}; var eventMatch, eventName; var propMatch, propName; for (var i = 0; i < attributes.length; ++i) { attNode = attributes[i]; attrName = attNode.nodeName; attrValue = attNode.nodeValue; if (attrName == 'style' || attrName == 'class') continue; eventMatch = attrName.match(/^on(.+)/) if (eventMatch) { eventName = eventMatch[1]; on[eventName] = new Function('event', 'sender', attrValue); continue; } propMatch = attrName.match(/^prop-(.+)/); if (propMatch) { propName = propMatch[1]; props[propName] = attrValue; continue; } attr[attrName] = attrValue; } var key; for (key in style) { //style is not empty obj.style = style; break; } for (key in attr) { obj.attr = attr; break; } for (key in on) { obj.on = on; break; } for (key in props) { obj.props = props; break; } return obj; } Dom.getConstructDescriptor = getConstructDescriptor; Dom.addToResizeSystem = function (element) { ResizeSystem/* default.add */.Z.add(element); }; Dom.updateResizeSystem = function () { ResizeSystem/* default.update */.Z.update(); } Dom.updateSizeUp = function (fromElt) { ResizeSystem/* default.updateUp */.Z.updateUp(fromElt); }; /* harmony default export */ const HTML5_Dom = (Dom); /** * * @param elt */ function isVisibilityOnScreen(elt) { if (!elt) return false; if (!AElement/* default.prototype.isDescendantOf.call */.Z.prototype.isDescendantOf.call(elt, document.body)) { return false; } var current = elt; var comStyle; while (current) { if (current === document.body) break; comStyle = window.getComputedStyle(current, null); if (comStyle.getPropertyValue('display') === 'none') return false; if (comStyle.getPropertyValue('visisbility') === 'hidden') return false; if (comStyle.getPropertyValue('opacity') === '0') return false; current = current.parentElement; } var bound = elt.getBoundingClientRect(); var outBound = traceOutBoundingClientRect(elt); if (bound.top > outBound.bottom) return false; if (bound.bottom < outBound.top) return false; if (bound.left > outBound.right) return false; if (bound.right < outBound.left) return false; return true; } Dom.isVisibilityOnScreen = isVisibilityOnScreen; /***/ }), /***/ 5150: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__), /* harmony export */ "J6": () => (/* binding */ setDomImmediate), /* harmony export */ "fi": () => (/* binding */ clearDomImmediate) /* harmony export */ }); /* harmony import */ var _EventEmitter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(863); /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7951); /* harmony import */ var _OOP__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3349); /* harmony import */ var _AttachHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(5675); /* harmony import */ var _Code_safeThrow__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(5650); /*** * * @extends EventEmitter * @param {AElement=} attachHookElt * @constructor */ function DomSignal(attachHookElt) { _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .ZP.call(this); this.signals = {}; this.ev_attached = this.ev_attached.bind(this); this.$attachhook = attachHookElt || this.createBuildInAttachHook(); this.$attachhookParent = (attachHookElt && attachHookElt.parentElement) || null; this.$attachhook.on('attached', this.ev_attached); this.$attachhook.ofDS = this; this.isPending = false; } _OOP__WEBPACK_IMPORTED_MODULE_2__/* ["default"].mixClass */ .ZP.mixClass(DomSignal, _EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP); DomSignal.prototype.createBuildInAttachHook = function () { var elt = document.createElement('img'); Object.defineProperties(elt, Object.getOwnPropertyDescriptors(_AElement__WEBPACK_IMPORTED_MODULE_1__/* ["default"].prototype */ .Z.prototype)); Object.defineProperties(elt, Object.getOwnPropertyDescriptors(_AttachHook__WEBPACK_IMPORTED_MODULE_3__/* ["default"].prototype */ .Z.prototype)); Object.defineProperties(elt, _AttachHook__WEBPACK_IMPORTED_MODULE_3__/* ["default"].property */ .Z.property); _AElement__WEBPACK_IMPORTED_MODULE_1__/* ["default"].call */ .Z.call(elt); elt.setAttribute('src', ''); elt.defineEvent('attached'); elt.addStyle('display', 'none'); _AttachHook__WEBPACK_IMPORTED_MODULE_3__/* ["default"].call */ .Z.call(elt); elt.cancelWaiting(); return elt; } DomSignal.prototype.execSignal = function () { var signals = this.signals; this.signals = {}; this.isPending = false; for (var name in signals) { this.fire.apply(this, [name].concat(signals[name])); } }; DomSignal.prototype.emit = function (name) { if (this.$attachhook && (this.$attachhook.canceled || this.$attachhook.attached) && !this.isPending) { this.$attachhook.remove(); this.$attachhook.resetState(); } this.signals[name] = Array.prototype.slice.call(arguments, 1); this.isPending = true; if (!this.$attachhookParent) { this.$attachhookParent = document.body; } if (!this.$attachhook.parentElement) { this.$attachhook.resetState(); this.$attachhookParent.appendChild(this.$attachhook); } }; DomSignal.prototype.ev_attached = function () { this.execSignal(); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DomSignal); var currentAT = null; var callbackList = {}; var id = 0; function setDomImmediate(callback) { var cid = ++id; callbackList[cid] = { exec: callback, args: Array.prototype.slice.call(arguments, 1) }; if (!currentAT) { currentAT = document.createElement('img'); currentAT.setAttribute('src', ''); currentAT.addEventListener('error', function () { currentAT.remove(); currentAT = null; Object.keys(callbackList).map(function (key) { var cb = callbackList[key]; delete callbackList[key]; if (cb) { try { cb.exec.call(null, cb.args); } catch (error) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z)(error); } } }) }) } return cid; } function clearDomImmediate(id) { delete callbackList[id]; } /***/ }), /***/ 488: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function DynamicCSS() { this.elt = document.createElement('style'); this.data = {}; this.state = 'STANDBY'; this.start(); } /** * * @returns {this} */ DynamicCSS.prototype.commit = function () { this.elt.innerHTML = Object.keys(this.data).map(ruleQuery => { var rule = this.data[ruleQuery]; return [ ruleQuery + ' {', ' ' + Object.keys(rule).map(name => name + ': ' + rule[name] + ';').join('\n'), '}' ].join('\n'); } ).join('\n\n'); return this; }; DynamicCSS.prototype.start = function () { if (this.state !== 'STANDBY' && this.state !== 'STOP') return; this.state = 'RUNNING'; document.head.appendChild(this.elt); return this; }; DynamicCSS.prototype.stop = function () { if (this.state !== 'RUNNING') return; this.elt.remove(); return this; }; DynamicCSS.prototype.destroy = function () { this.stop(); if (this.state !== 'STOP') return; this.elt = null; return this; }; /*** * * @param {string} ruleQuery * @param {string} name * @param {string} value * @returns {this} */ DynamicCSS.prototype.setProperty = function (ruleQuery, name, value) { this.data[ruleQuery] = this.data[ruleQuery] || {}; this.data[ruleQuery][name] = value; return this; }; /** * * @param ruleQuery * @param name * @returns {*|undefined} */ DynamicCSS.prototype.getProperty = function (ruleQuery, name) { var rule = this.data[ruleQuery]; return rule ? rule[name] : undefined; }; /*** * * @param ruleQuery * @param property * @returns {DynamicCSS} */ DynamicCSS.prototype.removeProperty = function (ruleQuery, property) { var rule = this.data[ruleQuery]; if (rule) delete rule[property]; return this; }; /*** * * @param ruleQuery * @param {object} properties * @returns {this} */ DynamicCSS.prototype.setRule = function (ruleQuery, properties) { this.data[ruleQuery] = Object.assign({}, properties); return this; }; /*** * * @param ruleQuery * @param {object} properties * @returns {this} */ DynamicCSS.prototype.modifyRule = function (ruleQuery, properties) { this.data[ruleQuery] = Object.assign(this.data[ruleQuery] || {}, properties); return this; }; /*** * * @param {string} ruleQuery * @returns {object} */ DynamicCSS.prototype.getRule = function (ruleQuery) { return this.data[ruleQuery]; }; /** * * @param {string} ruleQuery * @returns {this} */ DynamicCSS.prototype.removeRule = function (ruleQuery) { delete this.data[ruleQuery]; return this; }; /*** * * @param {object} rules * @returns {this} */ DynamicCSS.prototype.setRules = function (rules) { Object.keys(rules).forEach(key => this.setRule(key, rules[key])); return this; }; DynamicCSS.prototype.getRules = function () { return this.data; }; DynamicCSS.prototype.modifyRules = function (rules) { Object.keys(rules).forEach(key => this.modifyRule(key, rules[key])); return this; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DynamicCSS); /***/ }), /***/ 1487: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7951); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z); /***/ }), /***/ 1321: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _AElementNS__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2510); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_AElementNS__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z); /***/ }), /***/ 863: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Ed": () => (/* binding */ isMouseRight), /* harmony export */ "FQ": () => (/* binding */ isMouseLeft), /* harmony export */ "EY": () => (/* binding */ hitElement), /* harmony export */ "FG": () => (/* binding */ copyEvent), /* harmony export */ "VY": () => (/* binding */ findChangedTouchByIdent), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports eventProperties, touchProperties, isMouseMiddle, copyTouch, findTouchByIdent */ /* harmony import */ var _Code_safeThrow__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5650); function EventEmitter() { if (!this._azar_extendEvents) { Object.defineProperty(this, '_azar_extendEvents', { enumerable: false, value: this._azar_extendEvents || { supported: {}, prioritize: {}, nonprioritize: {} } }); Object.defineProperty(this, '__azar_force', { value: !(typeof Node === "object" ? this instanceof Node : this && typeof this === "object" && typeof this.nodeType === "number" && typeof this.nodeName === "string"), enumerable: false }); } } EventEmitter.prototype.defineEvent = function (name) { if (name instanceof Array) { for (var i = 0; i < name.length; ++i) this._azar_extendEvents.supported[name[i]] = true; } else this._azar_extendEvents.supported[name] = true; return this; }; EventEmitter.prototype.isSupportedEvent = function (name) { return this.__azar_force || !!this._azar_extendEvents.supported[name]; }; EventEmitter.prototype.emit = function (eventName, data) { this.fire.apply(this, arguments); }; EventEmitter.prototype.fire = function (eventName, data) { var others = Array.prototype.slice.call(arguments, 1); var listenerList; var i; var startTime, endTime; if (this.isSupportedEvent(eventName)) { if (this._azar_extendEvents.prioritize[eventName]) { listenerList = this._azar_extendEvents.prioritize[eventName].slice(); for (i = 0; i < listenerList.length; ++i) { try { startTime = Date.now(); listenerList[i].wrappedCallback.apply(this, others); endTime = Date.now(); if (endTime - startTime > 200) { console.log('slow function call ('+(endTime - startTime)+')', listenerList[i]); } } catch (e) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z)(e); } } } if (this._azar_extendEvents.nonprioritize[eventName]) { listenerList = this._azar_extendEvents.nonprioritize[eventName].slice(); for (i = 0; i < listenerList.length; ++i) { try { startTime = Date.now(); listenerList[i].wrappedCallback.apply(this, others); endTime = Date.now(); if (endTime - startTime > 200) { console.log('slow function call ('+(endTime - startTime)+')', listenerList[i]); } } catch (e) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z)(e); } } } } else { if (this.dispatchEvent) { var event = new Event(eventName); data && Object.assign(event, data); this.dispatchEvent(event); } else throw new Error("Not support event " + eventName); } return this; }; EventEmitter.prototype.eventEmittorOnWithTime = function (isOnce, arg0, arg1, arg2) { if (typeof arg0 == 'object') { for (var key in arg0) { this.eventEmittorOnWithTime(isOnce, key, arg0[key]); } return this; } else { if (typeof arg1 == 'object') { return this.eventEmittorOnWithTime(isOnce, arg0, arg1.callback, arg1.cap); } else { var eventArr = this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] || []; var eventIndex = -1; for (var i = 0; i < eventArr.length; ++i) { if (eventArr[i].wrappedCallback == arg1) { eventIndex = i; break; } } if (eventIndex < 0) { var event = { isOnce: isOnce, eventName: arg0, callback: arg1, cap: !!arg2 }; //wrappedCallback will be call if (isOnce) { event.wrappedCallback = function () { this.off(event.eventName, event.wrappedCallback, event.cap); event.callback.apply(this, arguments); }; } else { event.wrappedCallback = event.callback; } if (!this.isSupportedEvent(arg0)) { if (this.addEventListener) { this.addEventListener(arg0, event.wrappedCallback, !!arg2); } else { this.attachEvent('on' + arg0, arg1, !!arg2); } } eventArr.push(event); this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] = eventArr; } else { console.warn("dupplicate event"); } } return this; } }; EventEmitter.prototype.on = function (arg0, arg1, arg2) { this.eventEmittorOnWithTime(false, arg0, arg1, arg2); return this; }; EventEmitter.prototype.once = function (arg0, arg1, arg2) { this.eventEmittorOnWithTime(true, arg0, arg1, arg2); return this; }; EventEmitter.prototype.off = function (arg0, arg1, arg2) { if (typeof arg0 == 'object') { for (var key in arg0) { this.off(key, arg0[key]); } return this; } else { if (typeof arg1 == 'object') { return this.off(arg0, arg1.callback, arg1.cap); } else { var eventArr = this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] || []; var newEventArray = []; for (var i = 0; i < eventArr.length; ++i) { var event = eventArr[i]; if (event.wrappedCallback == arg1) { //Dont add to newEventArray if (this.isSupportedEvent(arg0)) { } else { if (this.removeEventListener) { this.removeEventListener(event.eventName, event.wrappedCallback, !!event.cap); } else { this.detachEvent('on' + event.eventName, event.wrappedCallback, !!event.cap); } } } else { newEventArray.push(event); } } this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] = newEventArray; return this; } } }; var eventProperties = ["altKey", "bubbles", "button", "buttons", "cancelBubble", "cancelable", "clientX", "clientY", "composed", "ctrlKey", "currentTarget", "defaultPrevented", "deltaMode", "deltaX", "deltaY", "deltaZ", "detail", "eventPhase", "explicitOriginalTarget", "isTrusted", "layerX", "layerY", "metaKey", "movementX", "movementY", "mozInputSource", "mozPressure", "offsetX", "offsetY", "originalTarget", "pageX", "pageY", "rangeOffset", "rangeParent", "region", "relatedTarget", "returnValue", "screenX", "screenY", "shiftKey", "srcElement", "target", "timeStamp", "type", "deltaMode", "deltaX", "deltaY", "deltaZ", 'preventDefault']; var touchProperties = ['clientX', 'clientY', 'force', 'identifier', 'pageX', 'pageY', 'rotationAngle', 'screenX', 'screenY', 'target']; function isMouseRight(event) { var isRightMB = false; if ("which" in event) // Gecko (Firefox), WebKit (Safari/Chrome) & Opera isRightMB = event.which === 3; else if ("button" in event) // IE, Opera isRightMB = event.button == 2; return isRightMB; } function isMouseLeft(event) { var isLeftMB = false; if ("which" in event) // Gecko (Firefox), WebKit (Safari/Chrome) & Opera isLeftMB = event.which === 1; else if ("button" in event) // IE, Opera isLeftMB = event.button === 0; return isLeftMB; } function isMouseMiddle(event) { var isMiddleMB = false; if ("which" in event) // Gecko (Firefox), WebKit (Safari/Chrome) & Opera isMiddleMB = event.which === 2; else if ("button" in event) // IE, Opera isMiddleMB = event.button === 1; return isMiddleMB; } /** * * @type AElement * @name sponsorElement * @memberof AElement# */ /** * * @param {AElement} element * @param {Event |{target: AElement}} event * @returns {boolean} */ function hitElement(element, event) { var current = event.target; while (current) { if (current === element) return true; if (current.sponsorElement && current.sponsorElement !== current.parentElement) {// sponsorElement like trigger of quick-menu if (hitElement(element, { target: current.sponsorElement })) return true; } current = current.parentElement; } return false; } function copyEvent(event, props) { var result = {}; var key, value; //copy native property for (var i = 0; i < eventProperties.length; ++i) { key = eventProperties[i]; value = event[key]; if (value !== undefined) { if (typeof value == "function") { result[key] = event[key].bind(event); } else { result[key] = event[key]; } } } Object.assign(result, event); if (props) Object.assign(result, props) if (event.changedTouches) { result.changedTouches = Array.prototype.map.call(event.changedTouches, function (touch) { return copyTouch(touch); }); } if (event.touches) { result.touches = Array.prototype.map.call(event.touches, function (touch) { return copyTouch(touch); }); } return result; } function copyTouch(touch, props) { var result = {}; var key, value; //copy native property for (var i = 0; i < touchProperties.length; ++i) { key = touchProperties[i]; value = touch[key]; if (value !== undefined) { if (typeof value == "function") { result[key] = touch[key].bind(touch); } else { result[key] = touch[key]; } } } Object.assign(result, touch); if (props) Object.assign(result, props); return result; } /*** * * @param {TouchEvent} event * @return {Touch | null} */ function findChangedTouchByIdent(event, identifier) { if (event.changedTouches) { for (var i = 0; i < event.changedTouches.length; ++i) { if (event.changedTouches[i].identifier === identifier) { return event.changedTouches[i]; } } } return null; } /*** * * @param event * @param identifier * @return {Touch|null} */ function findTouchByIdent(event, identifier) { if (event.touches) { for (var i = 0; i < event.touches.length; ++i) { if (event.touches[i].identifier === identifier) { return event.touches[i]; } } } return null; } EventEmitter.isMouseRight = isMouseRight; EventEmitter.isMouseLeft = isMouseLeft; EventEmitter.hitElement = hitElement; EventEmitter.copyEvent = copyEvent; EventEmitter.eventProperties = eventProperties; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (EventEmitter); /***/ }), /***/ 8706: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function JSPath(props) { this.path = props.path; } /** * * @param {Element} element * @returns {Boolean} */ JSPath.prototype.match = function (element, query) { if (query.id) { if (!element.getAttribute || element.getAttribute('id') != query.id) return false; } if (query.tagName) { var matchTag = false; if (element._azar_extendTags && element._azar_extendTags[query.tagName]) matchTag = true; matchTag = matchTag || ((element.tagName || '').toUpperCase() == query.tagName.toUpperCase()); if (!matchTag) return false; } if (query.classList) for (var i = 0; i < query.classList.length; ++i) { if (!element.classList || !element.classList.contains(query.classList[i])) return false; } if (query.attributes) { for (var key in query.attributes) { var value; if (element.attr) { value = element.attr(key); if (value != query.attributes[key]) return false; } else if (element.getAttribute) { value = element.getAttribute(key); if (value != query.attributes[key]) return false; } } } return true; }; /** * Warning : still fail in some testcase */ JSPath.prototype.findFirst = function (root, onFound) { var queue = [{ e: root, i: 0 }]; var current; while (queue.length > 0) { current = queue.shift(); var isMathed = false; var currentElt = current.e; var currentI = current.i; if (this.match(currentElt, this.path[currentI])) { if (this.path[currentI].childCombinate) { var trackI = currentI; var trackElement = currentElt; var isTrackMatch = true; while (isTrackMatch && trackI > 0 && this.path[trackI].childCombinate) { if (!trackElement.parentNode || !this.match(trackElement.parentNode, this.path[trackI - 1])) { isTrackMatch = false; } else { trackElement = trackElement.parentNode; trackI--; } } if (isTrackMatch) isMathed = true; } else { isMathed = true; } } if (isMathed && currentI + 1 == this.path.length) { if (!onFound || (onFound && onFound(currentElt))) return currentElt; } if (currentElt.childNodes) { var l = currentElt.childNodes.length; for (var i = 0; i < l; ++i) { if (currentElt.childNodes[i].tagName) queue.push({ e: currentElt.childNodes[i], i: currentI + (isMathed && currentI + 1 < this.path.length ? 1 : 0) }); } } } return undefined; }; JSPath.prototype.findAll = function (root, onFound) { var res = []; var queue = [{ e: root, i: 0 }]; var current; while (queue.length > 0) { current = queue.shift(); var isMathed = false; var currentElt = current.e; var currentI = current.i; if (this.match(currentElt, this.path[currentI])) { if (this.path[currentI].childCombinate) { var trackI = currentI; var trackElement = currentElt; var isTrackMatch = true; while (isTrackMatch && trackI > 0 && this.path[trackI].childCombinate) { if (!trackElement.parentNode || !this.match(trackElement.parentNode, this.path[trackI - 1])) { isTrackMatch = false; } else { trackElement = trackElement.parentNode; trackI--; } } if (isTrackMatch) isMathed = true; } else { isMathed = true; } } if (isMathed && currentI + 1 == this.path.length) { if (!onFound || (onFound && onFound(currentElt))) res.push(currentElt); } if (currentElt.childNodes) { var l = currentElt.childNodes.length; for (var i = 0; i < l; ++i) { if (currentElt.childNodes[i].tagName) queue.push({ e: currentElt.childNodes[i], i: currentI + (isMathed && currentI + 1 < this.path.length ? 1 : 0) }); } } } return res; }; var identRegex = /[a-zA-Z0-9\-_]+/; var stringRegex = /"(([^"\\]*|(\\.))*)"/; var classRegex = new RegExp('\\.' + identRegex.source); var idRegex = new RegExp('#' + identRegex.source); var booleanRegex = /true|false/; var valueRegex = new RegExp(stringRegex.source + '|' + booleanRegex.source); var attributeRegex = new RegExp('\\[\\s*(' + identRegex.source + ')\\s*(=\\s*(' + valueRegex.source + '))\\]'); var queryRegex = new RegExp([ '(', identRegex.source, '|', attributeRegex.source, '|', classRegex.source, '|', idRegex.source, ')+' ].join('')); JSPath.__tagRegex = new RegExp(queryRegex.source + '|\\>', 'g'); JSPath.__tagNameRegex = new RegExp('^' + identRegex.source, 'i'); JSPath.__classRegex = new RegExp(classRegex.source, 'g'); JSPath.__idRegex = new RegExp(idRegex.source, 'i'); JSPath.__attrRegex = new RegExp(attributeRegex.source, 'g'); JSPath.parseQuery = function (s) { var tag = {}; s = s.replace(JSPath.__attrRegex, function (full, name, assign, jsonTextValue) { tag.attributes = tag.attributes || {}; if (assign) { tag.attributes[name] = JSON.parse(jsonTextValue); } else tag.attributes[name] = true; return ''; }); var classList = s.match(this.__classRegex); var idList = s.match(this.__idRegex); var tagList = s.match(this.__tagNameRegex); if (idList && idList.length > 0) { tag.id = idList[0].substring(1); } if (tagList && tagList.length > 0) { tag.tagName = tagList[0].trim(); } if (classList && classList.length > 0) { tag.classList = classList.map(function (s) { return s.substring(1) }); } return tag; }; /** * @param {String} text * @returns {JSPath} */ JSPath.compileJSPath = function (text) { var tagTexts = text.match(this.__tagRegex) || ['']; var path = []; var childCombinate = false; for (var i = 0; i < tagTexts.length; ++i) { var s = tagTexts[i]; if (s == '>') { childCombinate = true; } else { var tag = this.parseQuery(s); tag.childCombinate = childCombinate; path.push(tag); childCombinate = false; } } return new JSPath({ path: path }); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (JSPath); /***/ }), /***/ 6013: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports LangSys, textNodeLanguageChangeHandler, elementLanguageChangeHandler */ /* harmony import */ var _ResizeSystem__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6700); /* harmony import */ var _Code_safeThrow__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(5650); /*** * @typedef LanguageSystemExtension * @property {function(key: string, code?: string): (string | null)} getText */ /**** * * @constructor */ function LanguageSystem() { this.data = {}; this.code = navigator.language || navigator.userLanguage; /*** * * @type {LanguageSystemExtension[]} * @private */ this._extensions = []; } LanguageSystem.prototype.notifyLanguageChange = function () { var sizeChange = false; function visit(elt) { if (elt.onlanguagechange) { try { elt.onlanguagechange(); sizeChange = true; } catch (err) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z)(err); } if (elt.childNodes && elt.childNodes.length > 0) { Array.prototype.forEach.call(elt.childNodes, visit); } } } visit(document.body); if (sizeChange) _ResizeSystem__WEBPACK_IMPORTED_MODULE_0__/* ["default"].update */ .Z.update(); }; /*** * * @param {ChildNode | Text | HTMLElement | Element} node */ LanguageSystem.prototype.bind = function (node, key) { if (node.nodeType === 1) { this.bindTextNode(node, key); } else if (node.nodeType === 3) { this.bindElement(node, key); } }; /*** * * @param {Text | {__as_language_key: string}} node * @param {string} key */ LanguageSystem.prototype.bindTextNode = function (node, key) { node.__as_language_key = key; node.onlanguagechange = textNodeLanguageChangeHandler; }; /*** * * @param {ChildNode | HTMLElement | Element | {__as_language_key: string}} node * @param {string} key */ LanguageSystem.prototype.bindElement = function (node, key) { node.__as_language_key = key; node.onlanguagechange = elementLanguageChangeHandler; }; /*** * * @param {string} key * @param {string} [code] */ LanguageSystem.prototype.getText = function (key, code) { var code = code || this.code; var res; var ex; for (var i = this._extensions.length - 1; i >= 0; --i) { ex = this._extensions[i]; res = ex.getText && ex.getText.apply(ex, arguments); if (res) break; } if (!res) { res = this.data[code] && this.data[code][key]; } return res || null; }; /*** * * @param {LanguageSystemExtension} ex */ LanguageSystem.prototype.addExtension = function (ex){ this._extensions.push(ex); }; var LangSys = new LanguageSystem(); LangSys.getText = function () { if (window.LanguageModule && window.LanguageModule.text){ LangSys.addExtension({ getText: function () { var text = window.LanguageModule.text.apply(window.LanguageModule, arguments); if (text && (text.startsWith('[key:') && text.charAt(text.length - 1) === ']')) return null; return text || null; } }); LangSys.getText = LanguageSystem.prototype.getText; return this.getText.apply(this, arguments); } return LanguageSystem.prototype.getText.apply(this, arguments); } function textNodeLanguageChangeHandler() { if (this.__as_language_key) { var newText = LangSys.getText(this.__as_language_key); if (newText && newText.trim) { this.data = newText; } } } function elementLanguageChangeHandler() { if (this.__as_language_key) { var newText = LangSys.getText(this.__as_language_key); if (newText && newText.trim) { var textNode; for (var i = 0; i < this.childNodes.length; ++i) { if (this.childNodes[i].nodeType === 1) { textNode = this.childNodes[i]; break; } } if (!textNode) { textNode = document.createTextNode(''); } textNode.data = newText; } } } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (LangSys); /***/ }), /***/ 3349: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "pj": () => (/* binding */ drillProperty), /* harmony export */ "Jx": () => (/* binding */ mixClass), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports overrideMethod, bindFunctions, inheritCreator */ /** * @param {Object} object * @param {String} key * @param {Function} method */ function overrideMethod(object, key, method) { if (object[key] === undefined) object[key] = method; else { var _superMethod = object[key]; object[key] = (function (_superMethod, method) { return function () { var _super = this.super; this.super = _superMethod; var result = method.apply(this, arguments); this.super = _super; return result; }; })(_superMethod, method); } } function extendsObject(object, prototype) { // do not use setter, getter for (var key in prototype) { if (key !== 'constructor' && key !== '__proto__') { if ((typeof prototype[key] == 'function')) { overrideMethod(object, key, prototype[key]); } else if (prototype[key] !== undefined && prototype[key] !== null) { object[key] = prototype[key];//just copy } } } }; function quickInheritObject(child, parent) { // do not use setter, getter Object.keys(parent).forEach(function (key) { if (key !== 'constructor' && (typeof parent[key] == 'function')) { var superMethod = parent[key]; var currentMethod = child[key]; if (!currentMethod) child[key] = superMethod; else { child[key] = function () { var _super = this.super; this.super = superMethod; var result = currentMethod.apply(this, arguments); this.super = _super; return result; }; } } }); }; function drillProperty(topObject, botObject, keyTop, keyBot) { if (typeof (keyTop) == 'string') { keyBot = keyBot || keyTop; Object.defineProperty(topObject, keyTop, { set: function (value) { botObject[keyBot] = value; }, get: function () { return botObject[keyBot]; }, configurable: true }); } else { if (keyTop instanceof Array) { for (var i = 0; i < keyTop.length; ++i) { drillProperty(topObject, botObject, keyTop[i], keyTop[i]); } } else { for (var key in keyTop) { drillProperty(topObject, botObject, key, keyTop[key]); } } } }; function bindFunctions(_this, handlers) { var res = {}; for (var key in handlers) { res[key] = handlers[key].bind(_this); } return res; }; function inheritCreator(parent, child) { var i; if (child.property) { if (parent.property) { for (i in parent.property) { if (!child.property[i]) child.property[i] = parent.property[i]; } } } for (i in parent.prototype) { if (!child.prototype[i]) { child.prototype[i] = parent.prototype[i]; } else { child.prototype[i] = (function (superFunction, childFunction) { return function () { var _super = this.super; this.super = superFunction; var result = childFunction.apply(this, arguments); this.super = _super; return result; }; })(parent.prototype[i], child.prototype[i]); } } }; /*** * * @param {Function} constructor */ function mixClass(constructor) { var descriptors = {}; for (var i = 1; i < arguments.length; ++i) { Object.assign(descriptors, Object.getOwnPropertyDescriptors(arguments[i].prototype)); } delete descriptors.constructor; Object.defineProperties(constructor.prototype, descriptors); } var OOP = { overrideMethod: overrideMethod, extends: extendsObject, inherit: quickInheritObject, mixClass: mixClass, inheritCreator: inheritCreator, drillProperty: drillProperty, bindFunctions: bindFunctions }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (OOP); /***/ }), /***/ 6700: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7951); /* harmony import */ var _AElementNS__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(2510); /* harmony import */ var _DelaySignal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(8098); /** * @name requestUpdateSize * @type {function} * @memberof AElement# */ /** * @name updateSize * @type {function} * @memberof AElement# */ /** * @name onresize * @type {function} * @memberof AElement# */ /** * @name requestRevokeResource * @type {function} * @memberof AElement# */ /** * * @constructor */ function ResizeSystem() { this.elts = []; this.cache = []; this.cacheOf = null; this.lastResizeTime = 0; this.pendingElts = {}; window.addEventListener('resize', this.update.bind(this)); this['goDown' + 'AndCache'] = this.goDownAndCache.bind(this); this['notify' + 'ToElt'] = this.notifyToElt.bind(this); var setup = ()=>{ this.domSignal = new _DelaySignal__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z(); this.domSignal.on('request_update_signal', this.update.bind(this)); this.domSignal.on('request_update_pending_signal', this.updatePending.bind(this)); window.removeEventListener("load", setup); } if (document.body) { setup(); } else { window.addEventListener("load", setup); } } /*** * * @param {AElement | AElementNS} elt */ ResizeSystem.prototype.goDownAndCache = function (elt) { if (this.notifyToElt(elt)) this.cache.push(elt); if (elt.childNodes) { Array.prototype.forEach.call(elt.childNodes, this.goDownAndCache); } }; ResizeSystem.prototype.notifyToElt = function (elt) { try { if (typeof elt.requestUpdateSize == 'function') { elt.requestUpdateSize(); return true; } else if (typeof elt.updateSize == 'function') { elt.updateSize(); return true; } else if (typeof elt.onresize == 'function') { elt.onresize(); return true; } } catch (err) { console.error(err); } }; ResizeSystem.prototype.update = function () { var now = Date.now(); if (now - 100 > this.lastResizeTime) { this.removeTrash(); this.cache = undefined; } this.lastResizeTime = now; if (this.cacheOf !== null) { this.cache = undefined; this.cacheOf = null; } if (this.cache === undefined) { this.cache = []; this.elts.forEach(this.goDownAndCache); } else { this.cache.forEach(this.notifyToElt); } }; ResizeSystem.prototype.requestUpdateSignal = function () { if (!this.domSignal) return; this.domSignal.emit('request_update_signal'); }; ResizeSystem.prototype.removeTrash = function () { var oldArr = this.elts; var newArr = []; var elt; var n = oldArr.length; for (var i = 0; i < n; ++i) { elt = oldArr[i]; if (_AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.isDescendantOf.call */ .Z.prototype.isDescendantOf.call(elt, document.body)) { newArr.push(elt); } else if (typeof elt.requestRevokeResource === "function") { elt.requestRevokeResource(); } } this.elts = newArr; }; /*** * * @param {AElement| AElementNS | Node} fromElt * @param {boolean=} toRoot * @returns {boolean} */ ResizeSystem.prototype.updateUp = function (fromElt, toRoot) { var found = false; while (fromElt && (!found || toRoot)) { found = this.notifyToElt(fromElt); fromElt = fromElt.parentElement; } return found; }; ResizeSystem.prototype.updatePending = function () { var o = this.pendingElts; this.pendingElts = {}; for (var key in o) { this.notifyToElt(o[key]); } }; /*** * * @param {AElement| AElementNS | Node} fromElt * @param {boolean=} toRoot * @returns {boolean} */ ResizeSystem.prototype.requestUpdateUpSignal = function (fromElt, toRoot) { if (!this.domSignal) return; var elts = []; var found = false; while (fromElt && (!found || toRoot)) { if (typeof fromElt.requestUpdateSize == 'function' || typeof fromElt.updateSize == 'function' || typeof fromElt.onresize == 'function' ) { elts.push(fromElt); found = true; } fromElt = fromElt.parentElement; } var pendingElts = this.pendingElts; elts.forEach(function (elt) { if (!elt.__resize_ident__) elt.__resize_ident__ = Date.now() + '_' + Math.random(); if (!pendingElts[elt.__resize_ident__]) pendingElts[elt.__resize_ident__] = elt; }); this.domSignal.emit('request_update_pending_signal'); return found; }; /*** * * @param {AElement| AElementNS | Node} fromElt * @returns {boolean} */ ResizeSystem.prototype.updateDown = function (fromElt) { var now = Date.now(); if (now - 100 > this.lastResizeTime) { this.cache = undefined; } this.lastResizeTime = now; if (this.cacheOf !== fromElt) { this.cache = undefined; this.cacheOf = fromElt; } if (this.cache === undefined) { this.cache = []; this.goDownAndCache(fromElt); } else { this.cache.forEach(this.notifyToElt); } }; /*** * * @param {AElement| AElementNS | Node} elt * @return {boolean} */ ResizeSystem.prototype.add = function (elt) { for (var i = 0; i < this.elts.length; ++i) if (_AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.isDescendantOf.call */ .Z.prototype.isDescendantOf.call(elt, this.elts[i])) { return false; } this.elts = this.elts.filter(function (e) { return !_AElement__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype.isDescendantOf.call */ .Z.prototype.isDescendantOf.call(e, elt); }); this.removeTrash(); this.cache = undefined; this.elts.push(elt); return true; }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (new ResizeSystem()); /***/ }), /***/ 6821: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports svgToRasterImageUrl, svgToExportedString */ /* harmony import */ var _Dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6628); /* harmony import */ var _ElementNS__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1321); /* harmony import */ var _AElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7951); /* harmony import */ var _Color_Color__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(257); /* harmony import */ var _AttachHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(5675); /* harmony import */ var _OOP__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(3349); /*** * @extends Dom * @param option * @constructor */ function Svg(option) { _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .ZP.call(this, option); this.svgNS = "http://www.w3.org/2000/svg"; Object.defineProperties(this.creator, { sattachhook: { set: function () { //do nothing }, get: function () { return _AttachHook__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z; } } }); delete this.buidDom; this.buildSvg = this.create.bind(this); } _OOP__WEBPACK_IMPORTED_MODULE_5__/* ["default"].mixClass */ .ZP.mixClass(Svg, _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP); Svg.prototype.defaultTag = 'g'; Svg.prototype.fromCode = function (code) { code = code.trim(); var receptacle = document.createElement('div'); var element; var prototypes; if (code.startsWith('<svg')) { receptacle.innerHTML = code; element = receptacle.childNodes[0]; prototypes = Object.getOwnPropertyDescriptors(_AElement__WEBPACK_IMPORTED_MODULE_2__/* ["default"].prototype */ .Z.prototype); Object.defineProperties(element, prototypes); _AElement__WEBPACK_IMPORTED_MODULE_2__/* ["default"].call */ .Z.call(element); } else { var svgfragment = '<svg version="1.1" xmlns="http://www.w3.org/2000/svg">' + code + '</svg>'; receptacle.innerHTML = '' + svgfragment; element = receptacle.childNodes[0].childNodes[0]; prototypes = Object.getOwnPropertyDescriptors(_ElementNS__WEBPACK_IMPORTED_MODULE_1__/* ["default"].prototype */ .Z.prototype); Object.defineProperties(element, prototypes); _ElementNS__WEBPACK_IMPORTED_MODULE_1__/* ["default"].call */ .Z.call(element); } return element; }; Svg.prototype.makeNewElement = function (tagName) { return document.createElementNS(this.svgNS, tagName); }; Svg.ShareInstance = new Svg(); Svg.svgToCanvas = function (element) { if (typeof element == 'string') { element = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance.$ */ .ZP.ShareInstance.$(element); } if (element && element.tagName == 'svg') { var depthClone = function (originElt) { var newElt = originElt.cloneNode();//no deep if (!originElt.getAttributeNS) return newElt;//is text node var style = getComputedStyle(originElt); var key, value; for (var i = 0; i < style.length; ++i) { key = style[i]; value = style.getPropertyValue(key); if (value && value.length > 0 && value !== 'auto') { newElt.style.setProperty(key, value); } } var children = Array.prototype.map.call(originElt.childNodes, depthClone); for (var i = 0; i < children.length; ++i) { newElt.appendChild(children[i]); } return newElt; }; var cloneElement = depthClone(element); var renderSpace = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._({ style: { // opacity:0, zIndex: -1000, position: 'fixed', top: 0, bottom: 0 } }).addTo(document.body); renderSpace.addChild(cloneElement); var svgCode = renderSpace.innerHTML; renderSpace.clearChild(); var mBlob = new Blob([svgCode], { type: "image/svg+xml;charset=utf-8" }); var src = (URL || webkitURL).createObjectURL(mBlob); var image = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._('img'); image.attr('src', src) .addTo(renderSpace); var canvas = document.createElement("canvas"); renderSpace.addChild(canvas); return _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].waitImageLoaded */ .ZP.waitImageLoaded(image).then(function () { canvas.width = image.width; canvas.height = image.height; var context = canvas.getContext("2d"); context.drawImage(image, 0, 0); renderSpace.selfRemove(); return canvas; }); } else { throw new Error('Element must be svg'); } }; function svgToRasterImageUrl(element) { return Svg.svgToCanvas(element).then(function (canvas) { return canvas.toDataURL(); }); } Svg.svgToRasterImageUrl = svgToRasterImageUrl; /** * * @param {string|AElement}element * @param {"print"|null=} option * @returns {string} */ function svgToExportedString(element, option) { if (typeof element == 'string') { element = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance.$ */ .ZP.ShareInstance.$(element); } if (element && element.tagName === 'svg') { var depthClone = function (originElt) { var newElt = originElt.cloneNode();//no deep if (!originElt.getAttributeNS) return newElt;//is text node var cssRules = _AElement__WEBPACK_IMPORTED_MODULE_2__/* ["default"].prototype.getCSSRules.call */ .Z.prototype.getCSSRules.call(originElt); var cssKey = cssRules.reduce(function (ac, rule) { for (var i = 0; i < rule.style.length; ++i) { ac[rule.style[i]] = true; } return ac; }, {}); for (var key in cssKey) { newElt.style[key] = _AElement__WEBPACK_IMPORTED_MODULE_2__/* ["default"].prototype.getComputedStyleValue.call */ .Z.prototype.getComputedStyleValue.call(originElt, key); } var children = Array.prototype.map.call(originElt.childNodes, depthClone); for (var i = 0; i < children.length; ++i) { newElt.appendChild(children[i]); } return newElt; }; var cloneElement = depthClone(element); var renderSpace = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._({ style: { // opacity:0, zIndex: -1000, position: 'fixed', top: 0, bottom: 0 } }).addTo(document.body); renderSpace.addChild(cloneElement); var svgCode = renderSpace.innerHTML; renderSpace.selfRemove(); return svgCode; } else { throw new Error('Element must be svg'); } }; Svg.svgToExportedString = svgToExportedString; /** * * @param element * @param {"print"|null=}option * @returns {string} */ function svgToSvgUrl(element, option) { var svg = svgToExportedString(element, option); svg = '<?xml version="1.0" encoding="UTF-8" standalone="no"?>\n' + svg; var blob = new Blob([svg], { type: 'image/svg+xml' }); var url = URL.createObjectURL(blob); return url; } Svg.svgToSvgUrl = svgToSvgUrl; /*** * * @param {AElement|String | {computeStyle?: boolean, elt: AElement, keepBackgroundColor?:boolean,convertSVG?:boolean}} option * @return {Promise<unknown>} */ _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].printElement */ .ZP.printElement = function (option) { var _ = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._; var $ = _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance.$ */ .ZP.ShareInstance.$; option = option || {}; if (typeof option == 'string') { option = { elt: _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance.$ */ .ZP.ShareInstance.$(option) }; } else if (typeof option.elt == 'string') { option.elt = $(option.elt); } else if (_Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isDomNode */ .ZP.isDomNode(option)) { option = { elt: option }; } option = Object.assign({ keepBackgroundColor: true, convertSVG: false, computeStyle: false }, option); if (_Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isDomNode */ .ZP.isDomNode(option.elt)) { function afterCloneCb(originElt, newElt) { if (!newElt.tagName) return; var tagName = newElt.tagName.toLowerCase(); if (newElt.getBBox && tagName !== 'svg') return; var url, img; var needCopyStyle = option.computeStyle; var needKeepBackgroundColor = option.keepBackgroundColor; var printViewBox; if (tagName === 'canvas' || (tagName === 'svg' && option.convertSVG)) { if (tagName === "canvas") { url = originElt.toDataURL(); } else { url = svgToSvgUrl(originElt, 'print');//todo: option } img = _({ tag: 'img', props: { src: url } }); $(newElt).selfReplace(img); newElt = img; needCopyStyle = true; } else if (tagName === 'svg' && originElt.getAttribute('data-print-view-box')) { printViewBox = originElt.getAttribute('data-print-view-box').split(' ').map(function (v) { return parseFloat(v); }); newElt.setAttribute('viewBox', printViewBox.join(' ')); newElt.setAttribute('width', printViewBox[2]); newElt.setAttribute('height', printViewBox[3]); newElt.style.setProperty('width', printViewBox[2] + 'px'); newElt.style.setProperty('height', printViewBox[3] + 'px'); } else if (tagName === 'script') { newElt.remove(); } else if (tagName === 'img') { newElt.setAttribute('src', originElt.src); } else if (tagName === 'input') { if (originElt.getAttribute('type') === 'radio' || originElt.getAttribute('type') === 'checkbox') { if (originElt.checked) { newElt.setAttribute('checked', true); } } else if (originElt.getAttribute('type') === 'text' || !originElt.getAttribute('type') || originElt.getAttribute('type') === 'number') { newElt.setAttribute('value', originElt.value); } } if (needCopyStyle) { (0,_Dom__WEBPACK_IMPORTED_MODULE_0__/* .copyStyleRule */ .E7)(originElt, newElt); } if (needKeepBackgroundColor) { try { var bgColor = _AElement__WEBPACK_IMPORTED_MODULE_2__/* ["default"].prototype.getComputedStyleValue.call */ .Z.prototype.getComputedStyleValue.call(originElt, 'background-color'); if (bgColor) { bgColor = _Color_Color__WEBPACK_IMPORTED_MODULE_3__/* ["default"].parse */ .Z.parse(bgColor); if (bgColor.rgba[3] > 0) { newElt.style.setProperty('background-color', bgColor.toString('hex8'), 'important'); } } } catch (e) { } } return newElt; } var newElt = (0,_Dom__WEBPACK_IMPORTED_MODULE_0__/* .depthClone */ .qE)(option.elt, afterCloneCb); var renderSpace = _({ style: { position: 'fixed', top: '0', left: '0', right: '0', bottom: '0', overflow: 'auto', zIndex: '10', opacity: '0', visibility: 'hidden' } }); $('link', document.head, function (elt) { var temp = elt.cloneNode(false); //copy absolute url temp.setAttribute('href', elt.href); renderSpace.addChild(temp); }); if (!option.computeStyle) { $('style', document.head, function (elt) { if (elt == _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].$printStyle */ .ZP.$printStyle) return; renderSpace.addChild(elt.cloneNode(true)); }); } renderSpace.addChild(newElt); var eltCode = renderSpace.innerHTML; renderSpace.clearChild(); option.title = option.title || ($('title', document.head) || { innerHTML: 'absol.js' }).innerHTML; var htmlCode = ['<ht' + 'ml>', ' <h' + 'ead><title>' + option.title + '</title><meta charset="UTF-8">', '<style>', option.overideStyle ? 'html, body{width:initial !important; height:initial !important; overflow: initial !important; overflow-x: initial !important;overflow-y: initial !important; }' : '', '@media print {',//still not work ' body{', ' -webkit-print-color-adjust: exact;', ' color-adjust: exact;', ' } ', ' div, tr, td, table{', ' }', ' }', 'div, table, tr, td{', ' page-break-inside: initial;', ' page-break-before: avoid;', ' page-break-after: avoid;', '}', option.extendCss || '', '</style>', '</he' + 'ad>', '<bod' + 'y>', eltCode, '<scr' + 'ipt>' + (option.extendScript || '') + '</scri' + 'pt>',//browser parse script tag fail '<scr' + 'ipt>setTimeout(function(){ window.print();},1000);</scri' + 'pt>',//browser parse script tag fail '</bod' + 'y>', '</ht' + 'ml>'].join('\n'); var blob = new Blob([htmlCode], { type: 'text/html; charset=UTF-8' }); renderSpace.addTo(document.body); var iframe = _('iframe').attr('src', URL.createObjectURL(blob)).addStyle({ width: '100%', height: '100%' }).addTo(renderSpace); return new Promise(function (rs, rj) { function waitLoad() { if (iframe.contentWindow && iframe.contentWindow.document && iframe.contentWindow.document.body) { if (typeof option.onLoad == 'function') option.onLoad(); iframe.contentWindow.focus(); setTimeout(function () { function waitFocusBack() { if (!document.hasFocus || document.hasFocus()) { renderSpace.remove(); if (typeof option.onFinish == 'function') option.onFinish(); rs(); } else { setTimeout(waitFocusBack, 300) } } waitFocusBack(); }, 4000); } else setTimeout(waitLoad, 1000) } waitLoad(); }); } else { throw new Error('Invalid param!'); } } ; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Svg); /***/ }), /***/ 5827: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "getTextNodesIn": () => (/* binding */ getTextNodesIn), /* harmony export */ "setSelectionRangeStart": () => (/* binding */ setSelectionRangeStart), /* harmony export */ "setSelectionRangeEnd": () => (/* binding */ setSelectionRangeEnd), /* harmony export */ "setSelectionRange": () => (/* binding */ setSelectionRange), /* harmony export */ "getTextIn": () => (/* binding */ getTextIn), /* harmony export */ "textToNodes": () => (/* binding */ textToNodes), /* harmony export */ "getCaretPosition": () => (/* binding */ getCaretPosition), /* harmony export */ "setCaretPosition": () => (/* binding */ setCaretPosition), /* harmony export */ "measureText": () => (/* binding */ measureText) /* harmony export */ }); /* harmony import */ var _Dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6628); function getTextNodesIn(node) { var textNodes = []; if (node.nodeType == 3) { textNodes.push(node); } else { var children = node.childNodes; for (var i = 0, len = children.length; i < len; ++i) { textNodes.push.apply(textNodes, getTextNodesIn(children[i])); } } return textNodes; } /** * * @param {Element} el * @param {Range} range * @param {Number} start * @returns {Number} -1: ok, ret >= 0(is length of text) : need move to next element * */ function setSelectionRangeStart(el, range, start) { if (start > 0) { if (el.nodeType == Node.TEXT_NODE) { var text = el.data; if (start <= text.length) { range.setStart(el, start); return -1; } else return text.length; } if (el.tagName.toLowerCase() == 'br') { return 0; } else { var delta = 0; var i = 0; var textLength = 0; var newLine = false; while (delta >= 0 && i < el.childNodes.length) { var childElt = el.childNodes[i]; if (newLine) { newLine = false; ++textLength; } delta = setSelectionRangeStart(childElt, range, start - textLength); if (delta >= 0) textLength += delta; if (childElt.nodeType != Node.TEXT_NODE && (window.getComputedStyle(childElt).display == 'block' || childElt.tagName.toLowerCase() == 'br')) { newLine = true; } ++i; } if (delta >= 0) return textLength; return -1; } } else { range.setStart(el, 0); return -1; } } /** * * @param {Element} el * @param {Range} range * @param {Number} end * @returns {Number} -1: ok, ret >= 0(is length of text) : need move to next element * */ function setSelectionRangeEnd(el, range, end) { if (end > 0) { if (el.nodeType == Node.TEXT_NODE) { var text = el.data; if (end <= text.length) { range.setEnd(el, end); return -1; } else return text.length; } if (el.tagName.toLowerCase() == 'br') { return 0; } else { var delta = 0; var i = 0; var textLength = 0; var newLine = false; while (delta >= 0 && i < el.childNodes.length) { var childElt = el.childNodes[i]; if (newLine) { newLine = false; ++textLength; } delta = setSelectionRangeEnd(childElt, range, end - textLength); if (delta >= 0) textLength += delta; if (childElt.nodeType != Node.TEXT_NODE && (window.getComputedStyle(childElt).display == 'block' || childElt.tagName.toLowerCase() == 'br')) { newLine = true; } ++i; } if (delta >= 0) return textLength; return -1; } } else { range.setEnd(el, 0); return -1; } } function setSelectionRange(el, start, end) { if (document.createRange && window.getSelection) { var range = document.createRange(); range.selectNodeContents(el); var delta; if (start >= 0) { delta = setSelectionRangeStart(el, range, start); if (delta >= 0) range.setStart(el, el.childNodes.length); } else { start = 0; range.setStart(el, 0); } if (end >= start) { delta = setSelectionRangeEnd(el, range, end); if (delta >= 0) range.setEnd(el, el.childNodes.length); } var sel = window.getSelection(); sel.removeAllRanges(); sel.addRange(range); } else if (document.selection && document.body.createTextRange) { var textRange = document.body.createTextRange(); textRange.moveToElementText(el); textRange.collapse(true); textRange.moveEnd("character", end); textRange.moveStart("character", start); textRange.select(); } } function getTextIn(e) { if (e.nodeType == Node.TEXT_NODE) { return e.data; } if (e.tagName && e.tagName.toLowerCase() == 'br') return ''; var texts = []; var newLine = false; for (var i = 0; i < e.childNodes.length; ++i) { if (newLine) { newLine = false; texts.push('\n'); } var childElt = e.childNodes[i]; texts.push(getTextIn(childElt)); if (childElt.nodeType != Node.TEXT_NODE && (window.getComputedStyle(childElt).display == 'block' || childElt.tagName.toLowerCase() == 'br')) { newLine = true; } } return texts.join(''); } function textToNodes(text) { var lines = text.split(/\r?\n/); return lines.map(function (text) { if (text.length == 0) { return _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._({ child: { tag: 'br' } }); } else { return _Dom__WEBPACK_IMPORTED_MODULE_0__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._({ child: { text: text } }); } }); } /* ** Returns the caret (cursor) position of the specified text field (oField). ** Return value range is 0-oField.value.length. */ function getCaretPosition(oField) { // Initialize var iCaretPos = 0; // IE Support if (document.selection) { // Set focus on the element oField.focus(); // To get cursor position, get empty selection range var oSel = document.selection.createRange(); // Move selection start to 0 position oSel.moveStart('character', -oField.value.length); // The caret position is selection length iCaretPos = oSel.text.length; } // Firefox support else if (oField.selectionStart || oField.selectionStart == '0') iCaretPos = oField.selectionDirection == 'backward' ? oField.selectionStart : oField.selectionEnd; // Return results return iCaretPos; } function setCaretPosition(oField, caretPos) { if (oField.createTextRange) { var range = oField.createTextRange(); range.move('character', caretPos); range.select(); } else { if (oField.selectionStart) { oField.focus(); oField.setSelectionRange(caretPos, caretPos); } else oField.focus(); } } function measureText(text, font) { // re-use canvas object for better performance var canvas = measureText.canvas || (measureText.canvas = document.createElement("canvas")); var context = canvas.getContext("2d"); if (font) context.font = font; var metrics = context.measureText(text); return metrics; } /***/ }), /***/ 27: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "DB": () => (/* binding */ normalizeKeyBindingIdent), /* harmony export */ "Ej": () => (/* binding */ keyboardEventToKeyBindingIdent) /* harmony export */ }); /* unused harmony exports isFnKey, isSpaceKey, isCtrlKey, isAltKey, isShiftKey, isMetaKey */ function isFnKey(name) { return name.match(/^[fF]([2-9]|(1([0-2]?)))$/) } function isSpaceKey(name) { return name === ' ' || name.match(/^[sS]pace$/); } function isCtrlKey(name) { return name.match(/(^([cC]ontrol)|ctrl)$/); } function isAltKey(name) { return name.match(/^[aA]lt$/); } function isShiftKey(name) { return name.match(/^[sS]hift$/); } function isMetaKey(name) { return name.toLowerCase().match(/^(command|windows|meta)$/); } /*** * * @param {string} text * @return {string} */ function normalizeKeyBindingIdent(text) { var keys = text.trim().toLowerCase().split(/[-+\s_.]+/) .filter(function (w) { return w.length > 0; }); var values = { meta: 1, ctrl: 2, alt: 3, shift: 4 }; keys.sort(function (a, b) { var va, vb; va = values[a] || 100; vb = values[b] || 100; return va - vb; }); return keys.join('-'); } /*** * * @param {KeyboardEvent} event * @return {string} */ function keyboardEventToKeyBindingIdent(event) { var keys = []; var keyName = event.key || String.fromCharCode(event.which || event.keyCode); if (event.metaKey) { keys.push('meta'); } if (event.ctrlKey) keys.push('ctrl'); if (event.altKey) keys.push('alt'); if (event.shiftKey) keys.push('shift'); if (isSpaceKey(keyName)) { keys.push('space'); } else if (isFnKey(keyName)) { keys.push(keyName.toLowerCase()) } else if (!isMetaKey(keyName) && !isAltKey(keyName) && !isCtrlKey(keyName) && !isShiftKey(keyName)) keys.push(keyName.toLowerCase()); return keys.join('-'); } /***/ }), /***/ 369: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function TemplateString(props) { this.parts = props.parts; } TemplateString.prototype.toJSCode = function () { return this.parts.map(function (e) { if (e.type == TemplateString.TYPE_EXPRESSION) { return '(' + e.data + ')'; } else { return JSON.stringify(e.data); } }).join('+'); }; TemplateString.__partRegex = /(\{\{(([^\}]|(\}[^\}]))*)\}\})|(([^\{]|(\{[^\{]))+)/g; /** * @param {String} text */ TemplateString.__matchExpression = function (text) { if (text[0] == '{' && text[1] == '{' && text[text.length - 1] == '}' && text[text.length - 2] == '}') { return [text, text.substr(2, text.length - 4).trim()]; } else { return false; } }; TemplateString.TYPE_STRING = 0; TemplateString.TYPE_EXPRESSION = 1; TemplateString.parse = function (text) { text = text+''; var matchedParts = text.match(this.__partRegex); if (matchedParts) { var parts = matchedParts.map(function (e) { var matchedExp = this.__matchExpression(e); if (matchedExp) { return { type: this.TYPE_EXPRESSION, data: matchedExp[1] }; } else { return { type: this.TYPE_STRING, data: e }; } }.bind(this)); return new TemplateString({ parts: parts }); } else { return new TemplateString({ parts: [] }); } }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TemplateString); /***/ }), /***/ 2914: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "NQ": () => (/* binding */ generateJSVariable), /* harmony export */ "Ew": () => (/* binding */ copyJSVariable), /* harmony export */ "wP": () => (/* binding */ replaceDateStringJSVariable) /* harmony export */ }); /* unused harmony export isJSVariableEqual */ /** * * @param obj * @param {string=}indent * @param {object=}opt * @returns {string} */ function generateJSVariable(obj,indent, opt) { indent = indent || ''; var childIndent = indent + ' '; if (obj === null) { return 'null'; } else if (obj instanceof Date) { return 'new Date(' + obj.getTime() + ')'; } else if (obj instanceof Array) { if (obj.length === 0) return '[]'; return '[\n' + obj.map(function (it) { return childIndent + generateJSVariable(it, childIndent, opt); }).join(',\n') + '\n' + indent + ']'; } else if (obj instanceof Error) { return generateJSVariable({message: obj.message, stack: obj.stack}); } else if (typeof obj === 'object') { var keys = Object.keys(obj); if (keys.length === 0) return '{}'; return '{\n' + keys.map(function (key) { var value = obj[key]; if (!key.match(/^[a-zA-Z_$]([a-zA-Z_0-9$]*)$/)) key = JSON.stringify(key); return childIndent + key + ': ' + generateJSVariable(value, childIndent, opt) }).join(',\n') + '\n' + indent + '}'; } else if (obj === undefined) { return 'undefined'; } else { return JSON.stringify(obj); } } /*** * * @param o * @param {Array<{test, replace}>| null=} replacers * @returns {*} */ function copyJSVariable(o, replacers) { var replacer; if (replacers && replacers.length > 0) { replacer = replacers.find((rp) => { return rp.test.apply(rp, [o].concat(Array.prototype.slice.call(arguments, 2))); }); if (replacer) { return replacer.replace.apply(replacer, [o].concat(Array.prototype.slice.call(arguments, 2))); } } if (o === null) return null; if (o === undefined) return undefined; var type = typeof o; if (type === "boolean") return o; if (o instanceof Date || (typeof o.getTime === "function")) return new Date(o.getTime()); if (type === "number") return o; if (type === "string") return o + ''; if (typeof o.map === "function") { return o.map((it, i) => copyJSVariable(it, replacers, i, o)); } if (type === "object" && o.constructor === Object) { return Object.keys(o).reduce((ac, cr) => { ac[cr] = copyJSVariable(o[cr], replacers, cr, o); return ac; }, {}); } return o; } function replaceDateStringJSVariable(o) { return copyJSVariable(o, [{ test: (x) => { return (typeof x === "string") && x.match(/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)\s+([a-zA-Z]{3})\s+[\d\s:]+GMT[\d+]+\s*\([^)]+\)$/) && !isNaN(new Date(x).getTime()); }, replace: x => new Date(x) }]); } /*** * * @param a * @param b * @return {boolean} */ function isJSVariableEqual(a, b) { if (a === b) return true;//1 var tA = typeof a; var tB = typeof b; if (tA !== tB) return false; //2 if (!a !== !b) return false; if (tA === 'string') return false;//because 1 & 2 if (tA === "number"){ if (isNaN(a) && isNaN(b)) return true;//because 2 return false;//because 1 } var aIsDate = a instanceof Date; var bIsDate = b instanceof Date; if (aIsDate !== bIsDate) return false; if (aIsDate) return isJSVariableEqual(a.getTime(), b.getTime()); var aIsArray = a instanceof Array; var bIsArray = a instanceof Array; if (aIsArray !== bIsArray) return false; var i; if (aIsArray) { if (a.length !== b.length) return false; for (i = 0; i < a.length; ++i) { if (!isJSVariableEqual(a[i], b[i])) return false; } return true; } //object if (a.equals) return a.equals(b); var aKeys = Object.keys(a); var bKeys = Object.keys(b); aKeys.sort(); bKeys.sort(); if (!isJSVariableEqual(aKeys, bKeys)) return false; for (i = 0; i < aKeys.length; ++i) { if (!isJSVariableEqual(a[aKeys[i]], b[aKeys[i]])) return false; } return true; } /***/ }), /***/ 2953: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXPORTS __webpack_require__.d(__webpack_exports__, { "computeMeasureExpression": () => (/* reexport */ computeMeasureExpression), "parseClassAttr": () => (/* binding */ parseClassAttr), "parseMeasureValue": () => (/* binding */ parseMeasureValue), "parseStyleAttr": () => (/* binding */ parseStyleAttr) }); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParser.js + 1 modules var DPParser = __webpack_require__(3281); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParseInstance.js var DPParseInstance = __webpack_require__(56); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSX/CSSParser.js /***** css expression rules****/ // var exp = `calc(var(--abcd) + 15px + 15%)`; var elementRegexes = [ ['varname', /--[a-z-]+/], ['word', /[_a-zA-Z][_a-zA-Z0-9]*/], ['msnumber', /(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)(vh|vw|px|%|pt)/], ['number', /(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)/], ['symbol', /[^\s_a-zA-Z0-9]/], ['string', /("(?:[^"\\]|\\.)*?")|('(?:[^'\\]|\\.)*?')/] ]; var rules = []; rules.push({ target: 'measure_num', elements: ['.msnumber'], toAST: function (pN) { pN = pN.children[0]; return { type: "MeasureLiteral", value: parseFloat(pN.content.replace(/vh|vw|px|%|pt/, '')), unit: pN.content.match(/px|%|pt|vw|vh/)[0] } } }); rules.push({ target: 'number', elements: ['.number'], toAST: function (pN) { pN = pN.children[0]; return { type: "NumericLiteral", value: parseFloat(pN.content), } } }); rules.push({ target: 'exp', elements: ['measure_num'], toAST: function (pN) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(pN.children[0]); } }); rules.push({ target: 'bracket_group', elements: ['_(', 'exp', '_)'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[1]); } }); rules.push({ target: 'exp', elements: ['bracket_group'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'variable_name', elements: ['.varname'], toAST: function (parsedNode) { return { type: 'VariableName', name: parsedNode.children[0].content } } }); rules.push({ target: 'exp', elements: ['variable_name'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); ['+', '-', '*', '/'].forEach(function (op) { rules.push({ target: 'bin_op', elements: ['_' + op], toAST: function (parsedNode) { return { type: "BinaryOperator", content: op } } }); }); var operatorOrder = { '*': 5, '/': 5, '%': 5, '+': 6, '-': 6 } var operatorTokenToAst = token => ({ type: token.type, content: token.content }); rules.push({ target: 'exp', elements: ['exp', 'bin_op', 'exp'], // longestOnly: true,//* error when parse return (...)... ident: 'bin_op_rec', toASTChain: function (parseNode) { var res = []; if (parseNode.children[0].rule === this) { res = res.concat(this.toASTChain(parseNode.children[0])); } else { res.push((0,DPParseInstance/* parsedNodeToAST */.Hg)(parseNode.children[0])); } res.push(parseNode.children[1].children[0]); if (parseNode.children[2].rule === this) { res = res.concat(this.toASTChain(parseNode.children[2])); } else { res.push((0,DPParseInstance/* parsedNodeToAST */.Hg)(parseNode.children[2])); } return res; }, toAST: function (parsedNode) { var chain = this.toASTChain(parsedNode); var stack = []; var item; var newNode; while (chain.length > 0) { item = chain.shift(); if (item.content in operatorOrder) { while (stack.length >= 3 && operatorOrder[stack[stack.length - 2].content] <= operatorOrder[item.content]) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = operatorTokenToAst(stack.pop()); newNode.left = stack.pop(); stack.push(newNode); } } stack.push(item); } while (stack.length >= 3) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = operatorTokenToAst(stack.pop()); newNode.left = stack.pop(); stack.push(newNode); } return stack.pop(); } }); rules.push({ target: 'args_list', elements: ['exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); }, toASTChain: function (parsedNode) { return [(0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode)]; } }); rules.push({ target: 'ident', elements: ['.word'], toAST: function (parsedNode) { return { type: 'Identifier', name: parsedNode.children[0].content } } }); rules.push({ target: 'number', elements: ['.number'], toAST: function (parsedNode) { return { type: 'NumericLiteral', value: parseFloat(parsedNode.children[0].content) } } }); rules.push({ target: 'args_list', elements: ['args_list', '_,', 'exp'], longestOnly: true, ident: 'args_list_rec', toASTChain: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToASTChain */.xI)(parsedNode.children[0]).concat((0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[2])); } }); rules.push({ target: 'function_callee', elements: ['ident'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'function_callee', elements: ['mem_exp'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }) rules.push({ target: 'function_call', elements: ['function_callee', '_(', 'args_list', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: parsedNode.children[2].rule.toASTChain(parsedNode.children[2]), callee: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]) } } }); rules.push({ target: 'function_call', elements: ['function_callee', '_(', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: [], callee: (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]) }; } }); rules.push({ target: 'exp', elements: ['function_call'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['number'], toAST: function (parsedNode) { return (0,DPParseInstance/* parsedNodeToAST */.Hg)(parsedNode.children[0]); } }); var cssExpressionParser = new DPParser/* default */.Z({ elementRegexes: elementRegexes, rules: rules }); var getScreenViewSize = () => { var div = document.createElement('div'); div.style.width = '100vw'; div.style.height = '100vh'; div.style.zIndex = '-10000'; div.style.visibility = 'hidden'; div.style.position = 'fixed'; document.body.appendChild(div); var res = div.getBoundingClientRect(); div.remove(); return { width: res.width, height: res.height }; } var fx = { calc: function (x) { return x; }, 'var': function (x, ctx) { if (!ctx.style) { if (ctx.elt) { ctx.style = getComputedStyle(ctx.elt); } } if (ctx.style) { if (ctx.style.getPropertyValue) { return ctx.style.getPropertyValue(x); } else { return ctx.style[x]; } } throw new Error("Miss style:CSSStyleDeclaration in ctx"); }, '*': function (x, y, ctx) { if (x && x.unit) { if (y && y.unit) { throw Error(`Can not call ${x.value + x.unit} * ${y.value + y.unit}`); } else { return { value: x.value * y, unit: x.unit }; } } else { if (y && y.unit) { return { value: x * y.value, unit: y.unit }; } else return x * y; } }, '/': function (x, y, ctx) { if (x && x.unit) { if (y && y.unit) { throw Error(`Can not call ${x.value + x.unit} / ${y.value + y.unit}`); } else { return { value: x.value / y, unit: x.unit }; } } else { if (y && y.unit) { throw Error(`Can not call ${x} / ${y.value + y.unit}`); } else return x * y; } }, '+': function add(x, y, ctx) { if (x && x.unit) { if (y && y.unit) { if (x.unit === y.unit) { return { value: x.value + y.value, unit: x.unit }; } else { return fx['+'](fx.toPx(x, ctx), fx.toPx(y, ctx)); } } else { throw Error(`Can not call ${x.value + x.unit} + ${y}`); } } else { if (y && y.unit) { throw Error(`Can not call ${x} + ${y.value + y.unit}`); } else return x + y; } }, '-': function add(x, y, ctx) { if (x && x.unit) { if (y && y.unit) { if (x.unit === y.unit) { return { value: x.value - y.value, unit: x.unit }; } else { return fx['+'](fx.toPx(x, ctx), fx.toPx(y, ctx)); } } else { throw Error(`Can not call ${x.value - x.unit} + ${y}`); } } else { if (y && y.unit) { throw Error(`Can not call ${x} - ${y.value + y.unit}`); } else return x + y; } }, toPx: (val, ctx) => { switch (val.unit) { case '%': if (typeof ctx.parentSize !== "number") throw new Error("Miss parentSize:number(px) in ctx"); return { value: ctx.parentSize * val.value / 100, unit: 'px' }; case 'vh': if (!ctx.screenSize) { ctx.screenSize = getScreenViewSize(); } return { value: ctx.screenSize.height * val.value / 100, unit: 'px' }; case 'vw': if (!ctx.screenSize) { ctx.screenSize = getScreenViewSize(); } return { value: ctx.screenSize.width * val.value / 100, unit: 'px' }; default: break; } return val; } }; var visitors = { CallExpression: (astNode, ctx) => { var args = astNode.arguments.map(it => accept(it, ctx)); args.push(ctx); return fx[astNode.callee.name].apply(null, args); }, BinaryExpression: (astNode, ctx) => { var left = accept(astNode.left, ctx); var right = accept(astNode.right, ctx); var func = fx[astNode.operator.content]; return func(left, right, ctx); }, MeasureLiteral: (astNode, ctx) => { return { value: astNode.value, unit: astNode.unit } }, NumericLiteral: (astNode, ctx) => { return astNode.value; }, VariableName: (astNode, ctx) => { return astNode.name; } }; var accept = (astNode, ctx) => { return visitors[astNode.type](astNode, ctx); } /** * * @param {string} exp * @param {{parentSize?: number, screenViewSize?:{width: number, height: number}, style?:CSSStyleDeclaration|Object, elt:AElement|any}} ctx * @param {boolean=} debug * @returns {*|null} */ function computeMeasureExpression(exp, ctx, debug) { try { var p = cssExpressionParser.parse(exp, 'exp'); if (p.ast) { return accept(p.ast, ctx); } return null; } catch (error) { return null; } } function getQuerySelectorSpecificity(selector) { let inline = 0; let idCount = 0; let classCount = 0; let tagCount = 0; // Remove pseudo-elements selector = selector.replace(/::\w+/g, ''); // Check for inline styles (not directly calculable from selector string) if (selector.includes('style="')) { inline = 1; } // Count ID selectors idCount = (selector.match(/#[\w-]+/g) || []).length; // Count class selectors, attributes selectors, and pseudo-classes classCount = (selector.match(/\.[\w-]+/g) || []).length + (selector.match(/\[[^\]]+\]/g) || []).length + (selector.match(/:(?!:)[\w-]+/g) || []).length; // Count element selectors and pseudo-elements tagCount = (selector.match(/^[\w-]+|\s[\w-]+/g) || []).length; return [inline, idCount, classCount, tagCount]; } function compareQuerySelectorSpecificity(selector1, selector2) { const specificity1 = getQuerySelectorSpecificity(selector1); const specificity2 = getQuerySelectorSpecificity(selector2); return arrayLexicographicalCompare(selector1, specificity2); } ;// CONCATENATED MODULE: ./node_modules/absol/src/JSX/attribute.js /** * * @param {String} text * @returns {Object} */ function parseStyleAttr(text) { return text.split(';').map(function (line) { var parts = line.split(':'); if (parts.length < 2) return null; var key = parts.shift().trim(); var value = parts.join(':').trim(); if (key.length == 0 || value.length == 0) return null; return [key, value]; }).filter(function (it) { return it != null }).reduce(function (ac, cr) { ac[cr[0]] = cr[1]; return ac; }, {}); } /** * * @param {String} text * @returns {Array<String>} */ function parseClassAttr(text) { return text.trim().split(/\s+/); } /** * * @param mValue * @returns {{unit: null, value: string}|{unit: string, value: number}|null} */ function parseMeasureValue(mValue) { if (mValue === 'auto') return { unit: null, value: 'auto' }; if (mValue === 'match_parent') return { unit: null, value: 'match_parent' }; var value = NaN; var unit = null; var matched; if (typeof mValue === "number") { value = mValue; unit = 'px'; } else if (typeof mValue === "string") { matched = mValue.match(/([+-]?([0-9]*[.])?[0-9]+([eE][+-]?[0-9]+)?)(px|%|vw|vh|em|rem|pt)?/i); if (matched) { value = parseFloat(matched[1]); unit = matched[4]; } } if (isNaN(value)) return null; unit = unit || 'px'; return { value: value, unit: unit }; } /***/ }), /***/ 9846: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _Vec2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(557); function Mat3(data) { this.data = data || Array(6).fill(0); } Mat3.identity = function () { return new Mat3([1, 0, 0, 0, 1, 0, 0, 0, 1]); }; /** * * @returns {Mat3|null} */ Mat3.prototype.invert = function () { var a = this.data; var out = Array(9); var a00 = a[0], a01 = a[1], a02 = a[2]; var a10 = a[3], a11 = a[4], a12 = a[5]; var a20 = a[6], a21 = a[7], a22 = a[8]; var b01 = a22 * a11 - a12 * a21; var b11 = -a22 * a10 + a12 * a20; var b21 = a21 * a10 - a11 * a20; // Calculate the determinant var det = a00 * b01 + a01 * b11 + a02 * b21; if (!det) return null; det = 1.0 / det; out[0] = b01 * det; out[1] = (-a22 * a01 + a02 * a21) * det; out[2] = (a12 * a01 - a02 * a11) * det; out[3] = b11 * det; out[4] = (a22 * a00 - a02 * a20) * det; out[5] = (-a12 * a00 + a02 * a10) * det; out[6] = b21 * det; out[7] = (-a21 * a00 + a01 * a20) * det; out[8] = (a11 * a00 - a01 * a10) * det; return new Mat3(out); }; /** * * @param {Vec2} v * @return {Mat3} */ Mat3.prototype.translate = function (v) { var out = Array(9); var a = this.data; var a00 = a[0], a01 = a[1], a02 = a[2]; var a10 = a[3], a11 = a[4], a12 = a[5]; var a20 = a[6], a21 = a[7], a22 = a[8]; var x = v.x, y = v.y; out[0] = a00; out[1] = a01; out[2] = a02; out[3] = a10; out[4] = a11; out[5] = a12; out[6] = x * a00 + y * a10 + a20; out[7] = x * a01 + y * a11 + a21; out[8] = x * a02 + y * a12 + a22; return new Mat3(out); }; /** * * @param {Mat3} mat * @returns {Mat3} */ Mat3.prototype.multiply = function (mat) { var a = this.data; var b = mat.data; var a00 = a[0], a01 = a[1], a02 = a[2]; var a10 = a[3], a11 = a[4], a12 = a[5]; var a20 = a[6], a21 = a[7], a22 = a[8]; var b00 = b[0], b01 = b[1], b02 = b[2]; var b10 = b[3], b11 = b[4], b12 = b[5]; var b20 = b[6], b21 = b[7], b22 = b[8]; var out = Array(9); out[0] = b00 * a00 + b01 * a10 + b02 * a20; out[1] = b00 * a01 + b01 * a11 + b02 * a21; out[2] = b00 * a02 + b01 * a12 + b02 * a22; out[3] = b10 * a00 + b11 * a10 + b12 * a20; out[4] = b10 * a01 + b11 * a11 + b12 * a21; out[5] = b10 * a02 + b11 * a12 + b12 * a22; out[6] = b20 * a00 + b21 * a10 + b22 * a20; out[7] = b20 * a01 + b21 * a11 + b22 * a21; out[8] = b20 * a02 + b21 * a12 + b22 * a22; return new Mat3(out); } /*** * * @param {Number} rad * @return {Mat3} */ Mat3.prototype.rotate = function (rad) { var a = this.data; var a00 = a[0], a01 = a[1], a02 = a[2]; var a10 = a[3], a11 = a[4], a12 = a[5]; var a20 = a[6], a21 = a[7], a22 = a[8]; var s = Math.sin(rad); var c = Math.cos(rad); var out = Array(9); out[0] = c * a00 + s * a10; out[1] = c * a01 + s * a11; out[2] = c * a02 + s * a12; out[3] = c * a10 - s * a00; out[4] = c * a11 - s * a01; out[5] = c * a12 - s * a02; out[6] = a20; out[7] = a21; out[8] = a22; return new Mat3(out); }; /*** * * @param {Vec2} v * @returns {Mat3} */ Mat3.prototype.scale = function (v) { var x = v.x; var y = v.y; var out = Array(9); out[0] = x * a[0]; out[1] = x * a[1]; out[2] = x * a[2]; out[3] = y * a[3]; out[4] = y * a[4]; out[5] = y * a[5]; out[6] = a[6]; out[7] = a[7]; out[8] = a[8]; return new Mat3(out); }; /*** * * @return {Mat3} */ Mat3.prototype.transpose = function (){ var a = this.data; var out = Array(9); out[0] = a[0]; out[1] = a[3]; out[2] = a[6]; out[3] = a[1]; out[4] = a[4]; out[5] = a[7]; out[6] = a[2]; out[7] = a[5]; out[8] = a[8]; return new Mat3(out); }; /** * * @param {Vec2}v */ Mat3.prototype.apply2DTransform = function (v) { var a = this.data; var x0 = v.x; var y0 = v.y; var x = x0 * a[0] + y0 * a[3] + a[6]; var y = x0 * a[1] + y0 * a[4] + a[7]; return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(x, y); } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Mat3); /***/ }), /***/ 9894: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _Vec2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(557); /*** * * @param {Vec2[]} vertices * @constructor */ function Polygon(vertices) { this.vertices = vertices; } /*** * * @param {Vec2} P * @returns {-1|0|1} */ Polygon.prototype.pointLocalIn = function (P) { var A = this.vertices[this.vertices.length - 1]; var B; var AB, PA, PB; var t, x; var count = 0; for (var i = 0; i < this.vertices.length; ++i) { B = this.vertices[i]; PA = A.sub(P); PB = B.sub(P); if (PA.cross(PB) === 0 && PA.dot(PB) <= 0) { return 0; } AB = B.sub(A); if (A.y !== B.y) { t = -PA.y / AB.y; x = A.x + AB.x * t; if (t >= 0 && t < 1 && x > P.x) { count++; } } A = B; } return count % 2 === 1 ? 1 : -1; }; Polygon.prototype.getPathString = function () { var vts = this.vertices; var res = 'M' + vts[0].x + ' ' + vts[0].y; for (var i = 1; i < vts.length; ++i) { res += 'L' + vts[i].x + ' ' + vts[i].y; } res += 'z'; return res; }; Polygon.prototype.copy = function () { return new Polygon(this.vertices.map((v) => { return v.copy(); })); }; Polygon.make = function (vertices) { return new Polygon(vertices); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Polygon); /***/ }), /***/ 2759: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _Vec2__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(557); /** * * @param {Number} x * @param {Number} y * @param {Number} width * @param {Number} height */ function Rectangle(x, y, width, height) { this.width = width; this.height = height; this.x = x; this.y = y; } /** * * @return {Vec2} * @constructor */ Rectangle.prototype.A = function () { return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(this.x, this.y); }; /*** * * @return {Vec2} * @constructor */ Rectangle.prototype.B = function () { return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(this.x + this.width, this.y); }; /*** * * @return {Vec2} * @constructor */ Rectangle.prototype.C = function () { return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(this.x + this.width, this.y + this.height); }; /*** * * @return {Vec2} * @constructor */ Rectangle.prototype.D = function () { return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(this.x, this.y + this.height); }; /*** * * @return {number} */ Rectangle.prototype.square = function () { return this.width * this.height; }; Rectangle.prototype.nearestPoint = function (arg0, arg1) { if (arg1) arg0 = _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"].make */ .Z.make(arg0, arg1); var res = this.A(); var mind = res.dist(arg0); var d = this.B().dist(arg0); if (d < mind) { mind = d; res = this.B(); } d = this.C().dist(arg0); if (d < mind) { mind = d; res = this.C(); } d = this.D().dist(arg0); if (d < mind) { mind = d; res = this.D(); } return res; }; Rectangle.prototype.centerPoint = function () { return new _Vec2__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z(this.x + this.width / 2, this.y + this.height / 2); }; /*** * * @param {Rectangle} r * @param {number=} margin * @return {boolean} */ Rectangle.prototype.isCollapse = function (r, margin) { if (!margin) margin = 0; return !(this.x >= r.x + r.width + margin || this.y >= r.y + r.height + margin || r.x >= this.x + this.width + margin || r.y >= this.y + this.height + margin); }; /*** * * @param {Rectangle} r * @return {number} */ Rectangle.prototype.collapsedSquare = function (r) { var collapseRect = this.collapsedRect(r); if (collapseRect) { return collapseRect.square(); } else { return 0; } }; /*** * * @param {Rectangle} r * @return {Rectangle} */ Rectangle.prototype.collapsedRect = function (r) { var maxX, minX, maxY, minY, width, height; minX = Math.max(this.x, r.x); minY = Math.max(this.y, r.y); maxX = Math.min(this.x + this.width, r.x + r.width); maxY = Math.min(this.y + this.height, r.y + r.height); width = maxX - minX; height = maxY - minY; if (width >= 0 && height >= 0) { return new Rectangle(minX, minY, width, height); } return null; }; /** * @param {Rectangle} r * @returns {Boolean} */ Rectangle.prototype.contains = function (r) { return (this.x <= r.x) && (this.y <= r.y) && (this.x + this.width >= r.x + r.width) && (this.y + this.height >= r.y + r.height); }; /** * @param {Vec2} p * @returns {Boolean} */ Rectangle.prototype.containsPoint = function (p) { return (this.x <= p.x) && (this.y <= p.y) && (this.x + this.width >= p.x) && (this.y + this.height >= p.y); }; /** * @param {Rectangle} other * @returns {Rectangle} */ Rectangle.prototype.merge = function (other) { var left = Math.min(this.x, other.x); var top = Math.min(this.y, other.y); var right = Math.max(this.x + this.width, other.x + other.width); var bottom = Math.max(this.y + this.height, other.y + other.height); return new Rectangle(left, top, right - left, bottom - top); }; /** * @returns {Rectangle} */ Rectangle.prototype.copy = function () { return new Rectangle(this.x, this.y, this.width, this.height); }; /** * @returns {Rectangle} */ Rectangle.prototype.clone = function () { return this.copy(); }; /*** * * @param {Rectangle} r */ Rectangle.prototype.equals = function (r) { return this.x === r.x && this.y === r.y && this.height === r.height && this.width === r.width; }; /** * @param {Number} x * @param {Number} y * @param {Number} width * @param {Number} height * @returns {Rectangle} */ Rectangle.make = function (x, y, width, height) { return new Rectangle(x, y, width, height); }; /** * @param {Number} x * @param {Number} y * @param {Number} width * @param {Number} height * @returns {Rectangle} */ Rectangle.makeCenter = function (x, y, width, height) { return new Rectangle(x - width / 2, y - height / 2, width, height); }; /** * @param {ClientRect|DOMRect} clientRect * @returns {Rectangle} */ Rectangle.fromClientRect = function (clientRect) { return new Rectangle(clientRect.left, clientRect.top, clientRect.width, clientRect.height); }; /*** * * @param {Vec2[]} points * @returns {Rectangle} */ Rectangle.boundingPoints = function (points) { var minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity; var point; for (var i = 0; i < points.length; ++i) { point = points[i]; minX = Math.min(minX, point.x); maxX = Math.max(maxX, point.x); minY = Math.min(minY, point.y); maxY = Math.max(maxY, point.y); } return new Rectangle(minX, minY, maxX - minX, maxY - minY); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Rectangle); /***/ }), /***/ 557: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /*** * * @param {Number} x * @param {Number} y * @constructor */ function Vec2(x, y) { this.x = x; this.y = y; } /*** * * @returns {Vec2} */ Vec2.prototype.copy = function () { return new Vec2(this.x, this.y); }; /*** * * @returns {string} */ Vec2.prototype.toString = function () { return "(" + this.x + ", " + this.y + ")"; }; /*** * * @returns {number} */ Vec2.prototype.abs = function () { return Math.sqrt(this.x * this.x + this.y * this.y); }; /*** * * @returns {Vec2} */ Vec2.prototype.normalized = function () { var l = this.abs(); if (l == 0) l = 1; return this.div(l); }; /*** * * @param {number} h * @returns {Vec2} */ Vec2.prototype.mult = function (h) { return new Vec2(this.x * h, this.y * h); }; /*** * * @param {number} h * @returns {Vec2} */ Vec2.prototype.div = function (h) { return new Vec2(this.x / h, this.y / h); }; /*** * * @param v * @returns {number} */ Vec2.prototype.dist = function (v) { var dx = v.x - this.x; var dy = v.y - this.y; return Math.sqrt(dx * dx + dy * dy); }; /*** * * @param {Vec2} v * @returns {Vec2} */ Vec2.prototype.sub = function (v) { return new Vec2(this.x - v.x, this.y - v.y); }; /*** * * @param {Vec2} v * @returns {Vec2} */ Vec2.prototype.add = function (v) { return new Vec2(this.x + v.x, this.y + v.y); }; /*** * * @returns {Vec2} */ Vec2.prototype.inv = function () { return new Vec2(-this.x, -this.y); }; /*** * * @param {Vec2} v * @param {number} h * @returns {Vec2} */ Vec2.prototype.linear = function (v, h) { return new Vec2(this.x * (1 - h) + v.x * h, this.y * (1 - h) + v.y * h); }; /*** * * @param {Vec2} v1 * @returns {number} */ Vec2.prototype.dot = function (v1) { return this.x * v1.x + this.y * v1.y; }; /*** * * @param {Vec2} v1 * @returns {number} */ Vec2.prototype.cross = function (v1) { return this.x * v1.y - this.y * v1.x; }; /*** * * @returns {number} */ Vec2.prototype.direction = function () { return Math.atan2(this.y, this.x); }; /*** * * @param {Number} dx * @param {Number} dy */ Vec2.prototype.translate = function (dx, dy) { return this.add(new Vec2(dx, dy)); }; /**** * * @param {Number} angle - radian * @returns {Vec2} */ Vec2.prototype.rotate = function (angle) { var sinA = Math.sin(angle); var cosA = Math.cos(angle); var x = this.x * cosA - this.y * sinA; var y = this.x * sinA + this.y * cosA; return new Vec2(x, y); }; /*** * * @returns {Vec2} */ Vec2.prototype.rotate90 = function () { return new Vec2(-this.y, this.x); }; /*** * * @param {Vec2} b */ Vec2.prototype.equals = function (b){ return b && this.x === b.x && this.y === b.y; }; /*** * * @param {number} angle * @returns {Vec2} */ Vec2.fromDirection = function (angle) { return new Vec2(Math.cos(angle), Math.sin(angle)); }; /*** * * @param x * @param y * @returns {Vec2} */ Vec2.make = function (x, y) { if (x instanceof Array) { return new Vec2(x[0], x[1]); } else if (x instanceof Vec2) { return x.copy(); } else return new Vec2(x, y); }; Vec2.ZERO = new Vec2(0, 0); Vec2.OX = new Vec2(1, 0); Vec2.OY = new Vec2(0, 1); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Vec2); /***/ }), /***/ 7988: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "map": () => (/* binding */ map), /* harmony export */ "sumArr": () => (/* binding */ sumArr), /* harmony export */ "radianInRange": () => (/* binding */ radianInRange), /* harmony export */ "distance": () => (/* binding */ distance), /* harmony export */ "numberToString": () => (/* binding */ numberToString), /* harmony export */ "isNumber": () => (/* binding */ isNumber), /* harmony export */ "numberAutoFixed": () => (/* binding */ numberAutoFixed), /* harmony export */ "integerZeroPadding": () => (/* binding */ integerZeroPadding), /* harmony export */ "harmonicMean": () => (/* binding */ harmonicMean) /* harmony export */ }); /** * * @param {number} x * @param {number} l * @param {number} h * @param {number} L * @param {number} H * @returns {number} */ function map(x, l, h, L, H) { return (x - l) / (h - l) * (H - L) + L; } function sumArr(arr) { var res = 0; for (var i = 0; i < arr.length; ++i) res += arr[i]; return res; } function radianInRange(x, start, end) { if (start > end) return radianInRange(x, end, start); if (x < start) x += (Math.PI * 2) * Math.ceil((start - x) / 2 / Math.PI); if (x > end) x -= (Math.PI * 2) * Math.ceil((x - end) / 2 / Math.PI); return x >= start && x <= end; } function distance(x0, y0, x1, y1) { var dx = x0 - x1; var dy = y0 - y1; return Math.sqrt(dx * dx + dy * dy); } /** * * @param {Number} numb * @param {Number} floatFixed * @param {"."|","} decimalSeparator * @param {","|"."} thousandsSeparator * @param {Number} decimalPadding */ function numberToString(numb, floatFixed, decimalSeparator, thousandsSeparator, decimalPadding) { if (floatFixed === undefined || floatFixed === null || typeof floatFixed != "number" || isNaN(floatFixed) || floatFixed < -1) floatFixed = -1; if (decimalSeparator === undefined || decimalSeparator === null || (decimalSeparator != '.' && decimalSeparator != ',')) decimalSeparator = '.'; if (thousandsSeparator === undefined || thousandsSeparator === null || (floatFixed >= 0 && thousandsSeparator == decimalSeparator)) thousandsSeparator = undefined; if (thousandsSeparator != ',' && thousandsSeparator != '.') thousandsSeparator = undefined; if (decimalPadding === undefined || decimalPadding === null || typeof decimalPadding != "number" || isNaN(decimalPadding) || decimalPadding < 0) decimalPadding = 0; var text = numb.toString(); var matched = text.match(/[+-]?([0-9]*)(\.([0-9]*))?(e([+-]?[0-9]+))?/); var dec = matched[1] || ''; var real = matched[3] || ''; var floatPoint = parseInt(matched[5] || '0'); var decDigits = dec.split('').map(function (d) { return parseInt(d) }); var realDigits = real.split('').map(function (d) { return parseInt(d) }); while (floatPoint < 0) { if (decDigits.length > 0) { realDigits.unshift(decDigits.pop()); } else { realDigits.unshift(0); } floatPoint++; } while (floatPoint > 0) { if (realDigits.length > 0) { decDigits.push(realDigits.unshift()); } else { decDigits.push(0); } floatPoint++; } var mem = 0, i, cValue; if (floatFixed > realDigits.length) { while (realDigits.length < floatFixed) { realDigits.push(0); } } else if (floatFixed < realDigits.length && floatFixed >= 0) { i = floatFixed; mem = realDigits[i] >= 5 ? 1 : 0; realDigits.splice(floatFixed); --i; while (mem > 0) { if (i >= 0) { cValue = realDigits[i] + mem; realDigits[i] = cValue % 10; mem = Math.floor(cValue / 10); } else { if (decDigits.length + i < 0) decDigits.unshift(0); cValue = decDigits[decDigits.length + i] + mem; decDigits[decDigits.length + i] = cValue % 10; mem = Math.floor(cValue / 10); } --i; } } while (decDigits.length < decimalPadding) { decDigits.unshift(0); } var decText = numb < 0 ? '-' : ''; var breadMod = (decDigits.length + 2) % 3; if (thousandsSeparator) { for (i = 0; i < decDigits.length; ++i) { decText += decDigits[i]; if (i % 3 == breadMod && i + 1 < decDigits.length) { decText += thousandsSeparator; } } } else { decText += decDigits.join(''); } var realText = realDigits.length == 0 ? '' : decimalSeparator + realDigits.join(''); return decText + realText; } /*** * * @param value * @param {string=}decimalSeparator */ function isNumber(value, decimalSeparator) { decimalSeparator = decimalSeparator || '.'; if (typeof value === "number") return true; if (typeof value !== "string") return false; var thousandsSeparator = decimalSeparator === '.' ? ',' : '.'; value = value.split(thousandsSeparator).join(''); value = value.replace(decimalSeparator, '.'); return !!value.match(/^[+-]?\d+(\.\d+)?$/); } function numberAutoFixed(x, eDelta) { eDelta = eDelta || 10; eDelta = Math.round(eDelta); var e = parseFloat('1e+' + eDelta); return Math.round(x * e) / e; } /*** * * @param {number} number * @param {number} length * @returns {string} */ function integerZeroPadding(number, length) { var res = number + ''; while (res.length < length) res = '0' + res; return res; } function harmonicMean(a, b) { return 2 / (1 / a + 1 / b); } /***/ }), /***/ 7848: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Ld": () => (/* binding */ randomArbitrary), /* harmony export */ "Iy": () => (/* binding */ randomInt) /* harmony export */ }); /* unused harmony export randomPick */ /** * Returns a random number between min (inclusive) and max (exclusive) */ function randomArbitrary(min, max) { return Math.random() * (max - min) + min; } /** * Returns a random integer between min (inclusive) and max (inclusive) * Using Math.round() will give you a non-uniform distribution! */ function randomInt(min, max) { return Math.floor(Math.random() * (max - min + 1)) + min; } function randomPick(arr) { var id = randomInt(0, arr.length - 1); return arr[id]; } /***/ }), /***/ 5447: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "fileExist": () => (/* binding */ fileExist), /* harmony export */ "saveAs": () => (/* binding */ saveAs), /* harmony export */ "saveTextAs": () => (/* binding */ saveTextAs) /* harmony export */ }); /* harmony import */ var _Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9399); /*** * @typedef {{revokeTimeout?: number, autoBom?:boolean }} FileSaverOpts * */ function fileExist(url) { var xhr = new XMLHttpRequest(); xhr.open('HEAD', url, true); return new Promise(function (resolve) { xhr.onreadystatechange = function () { if (this.readyState === 4) { resolve(xhr.status === 200); } }; xhr.onerror = function (err) {}; xhr.send(); }); } /*** * * @param url * @param name * @param {FileSaverOpts} opts */ function download(url, name, opts) { var xhr = new XMLHttpRequest(); xhr.open('GET', url); xhr.responseType = 'blob'; xhr.onload = function () { saveAs(xhr.response, name, opts); } xhr.onerror = function () { console.error('Could not download: ' + url); }; xhr.send(null); } function bom(blob, opts) { if (typeof opts === undefined) opts = { autoBom: false }; else if (typeof opts !== 'object') opts = { autoBom: !opts }; if (opts.autoBom && /^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(blob.type)) { return new Blob([String.fromCharCode(0xFEFF), blob], { type: blob.type }) } return blob; } function corsEnabled(url) { var xhr = new XMLHttpRequest(); return new Promise(function (resolve) { xhr.onload = function () { resolve(xhr.status >= 200 && xhr.status < 299); }; xhr.onerror = function () { resolve(xhr.status >= 200 && xhr.status < 299); } xhr.open('HEAD', url, true); xhr.send(); }); } function click(node) { try { node.dispatchEvent(new MouseEvent('click')); } catch (e) { var evt = document.createEvent('MouseEvents'); evt.initMouseEvent('click', true, true, window, 0, 0, 0, 80, 20, false, false, false, false, 0, null); node.dispatchEvent(evt); } } function normalSaveAs(blob, name, opts) { var URL = window.URL || window.webkitURL; var a = document.createElement('a'); name = name || blob.name || 'download'; a.download = name; a.rel = 'noopener'; if (typeof blob === 'string') { a.href = blob; if (a.origin !== location.origin) { corsEnabled(a.href).then(function (result){ if (result) { download(blob, name, opts); } else { a.target = '_blank'; click(a); } }); } else { click(a); } } else { a.href = URL.createObjectURL(blob); setTimeout(function () { }, ((opts && opts.revokeTimeout) || 4E4)); setTimeout(function () { click(a); }, 0); } } function msSaveAs(blob, name, opts) { name = name || blob.name || 'download'; if (typeof blob === 'string') { corsEnabled(blob).then(function (result) { if (result) { download(blob, name, opts); } else { var a = document.createElement('a'); a.href = blob; a.target = '_blank'; setTimeout(function () { click(a); }); } }); } else { navigator.msSaveOrOpenBlob(bom(blob, opts), name); } } function popupSaveAs(blob, name, opts, popup) { if (typeof blob === 'string') { download(blob, name, opts); return; } popup = popup || open('', '_blank'); if (popup) { popup.document.title = name || 'download'; popup.document.body.innerText = "downloading..." } name = name || blob.name || 'download'; blob.name = name; var force = blob.type === 'application/octet-stream'; var isSafari = _Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isSafari */ .Z.isSafari; var isChromeIOS = _Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isChromeIOS */ .Z.isChromeIOS; var isMacOSWebView = _Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isMacOSWebView */ .Z.isMacOSWebView; var isSafariUnder13 = (_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].browser.type */ .Z.browser.type === 'safari' && parseFloat(_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].browser.version */ .Z.browser.version) < 13); if ((!isChromeIOS || (force && isSafari) || isMacOSWebView) && typeof FileReader !== 'undefined' & !isSafariUnder13) { var reader = new FileReader(); reader.onloadend = function () { var url = reader.result; url = isChromeIOS ? url : url.replace(/^data:[^;]*/, 'data:attachment/file'); if (popup) popup.location.href = url; else location = url; popup = null; }; reader.readAsDataURL(blob); } else { var URL = window.URL || window.webkitURL; var url = URL.createObjectURL(blob); if (popup) popup.location.href = url; else location.href = url; popup = null; setTimeout(function () { URL.revokeObjectURL(blob); }, (opts && opts.revokeTimeout) || 4E4); } } /*** * * @param {string | File | Blob}blob * @param {string=} name * @param {Object=} opts * @param {Object=} popup */ function saveAs(blob, name, opts, popup) { if (typeof window !== "object" || window !== self) { console.error("FileSaver is not support!") } else if ('wkSaveAs' in navigator) { navigator.wkSaveAs(blob, name, opts); } else if ('download' in HTMLAnchorElement.prototype && !_Detector_BrowserDetector__WEBPACK_IMPORTED_MODULE_0__/* ["default"].isMacOSWebView */ .Z.isMacOSWebView) { normalSaveAs(blob, name, opts); } else if ('msSaveOrOpenBlob' in navigator) { msSaveAs(blob, name, opts); } else { setTimeout(function () { popupSaveAs(blob, name, opts, popup); }, 100) } } function saveTextAs(text, name, opts) { var blob = new Blob([text], { type: 'text/plain' }); saveAs(blob, name, opts); } /***/ }), /***/ 3154: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(863); /* harmony import */ var _String_stringGenerate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1334); /* harmony import */ var _Code_safeThrow__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5650); var TYPE_WORKER = 'WORKER'; var TYPE_IFRAME = 'IFRAME'; var TYPE_IFRAME_MASTER = 'IFRAME_MASTER'; var TYPE_WORKER_MASTER = 'WORKER_MASTER'; /** * * @param {Worker|HTMLIFrameElement|WorkerGlobalScope|Window=} host */ function IFrameBridge(host) { _HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"].call */ .ZP.call(this); /*** * * @type {Worker|HTMLIFrameElement|WorkerGlobalScope|Window|WorkerGlobalScope|Window} */ this.host = host || self; this.sender = null; this.receiver = null; this.origin = null; this.type = 'NOT_DETECT'; this.id = "UNSET"; this.sync = this._detectHost().then(() => this._attach()); this.__azarResolveCallbacks = {}; this.__azarRejectCallbacks = {}; } IFrameBridge.TYPE_WORKER = TYPE_WORKER; IFrameBridge.TYPE_IFRAME = TYPE_IFRAME; IFrameBridge.TYPE_IFRAME_MASTER = TYPE_IFRAME_MASTER; IFrameBridge.TYPE_WORKER_MASTER = TYPE_WORKER_MASTER; IFrameBridge.prototype._detectHost = function () { return new Promise(rs => { var iframeLoaded = () => { if (this.host.removeEventListener) { this.host.removeEventListener("load", iframeLoaded); } else { this.host.detachEvent("onload", iframeLoaded); } this.sender = this.host.contentWindow; rs(); }; if (this.host instanceof Worker) { this.type = TYPE_WORKER_MASTER; this.sender = this.host; this.receiver = this.host; } else if (this.host.tagName === 'IFRAME') { this.type = TYPE_IFRAME_MASTER; this.receiver = self; this.id = this.host.src; this.origin = '*'; if (this.host.addEventListener) { this.host.addEventListener("load", iframeLoaded); } else { this.host.attachEvent("onload", iframeLoaded); } } else if (IFrameBridge.isInIFrame()) { this.type = TYPE_IFRAME; this.sender = window.parent; this.receiver = this.host; this.id = location.href; this.origin = '*'; } else if (IFrameBridge.isInWorker()) { this.type = TYPE_WORKER; this.sender = this.host; this.receiver = this.host; } if (this.sender) rs(); }); }; IFrameBridge.prototype._attach = function () { if (this.receiver.addEventListener) { this.receiver.addEventListener("message", this.__azarMessageListener.bind(this), false); } else if (this.receiver.attachEvent) { this.receiver.attachEvent("onmessage", this.__azarMessageListener.bind(this)); } else { this.receiver.onmessage = this.__azarMessageListener.bind(this); } }; IFrameBridge.fromIFrame = function (iframe) { return new IFrameBridge(iframe); var host = iframe.contentWindow || iframe.contentDocument; var src = iframe.src; var rootOrigin = location.origin; var iframeOrigin = src.match(/^(http|https):\/\/[^/]+/); if (iframeOrigin) { iframeOrigin = iframeOrigin[0]; } else { iframeOrigin = rootOrigin; } if (host) return new IFrameBridge(host, iframeOrigin); else { var result = new IFrameBridge(undefined, iframeOrigin); var attachedHost = function () { var host = iframe.contentWindow || iframe.contentDocument; result.attach(host); }; if (iframe.addEventListener) { iframe.addEventListener("load", attachedHost); } else { iframe.attachEvent("onload", attachedHost); } return result; } }; IFrameBridge.getInstance = function () { if (!IFrameBridge.shareInstance) { var origin = location.origin; var rootOrigin = IFrameBridge.fromIFrame() ? IFrameBridge.getParentUrl().match(/^(http|https):\/\/[^/]+/): null; if (rootOrigin) { rootOrigin = rootOrigin[0]; } else { rootOrigin = origin; } // IFrameBridge.shareInstance = new IFrameBridge(self, rootOrigin == origin? undefined: "*" || rootOrigin ); var host = self; IFrameBridge.shareInstance = new IFrameBridge(host, rootOrigin); } return IFrameBridge.shareInstance; }; Object.defineProperties(IFrameBridge.prototype, Object.getOwnPropertyDescriptors(_HTML5_EventEmitter__WEBPACK_IMPORTED_MODULE_0__/* ["default"].prototype */ .ZP.prototype)); IFrameBridge.prototype.constructor = IFrameBridge; IFrameBridge.isInIFrame = function () { return !IFrameBridge.isInWorker() && (top !== self) ; }; IFrameBridge.isInWorker = function () { return (typeof WorkerGlobalScope !== 'undefined') && (self instanceof WorkerGlobalScope); } IFrameBridge.getParentUrl = function () { var parentUrl = (window.location != window.parent.location) ? document.referrer : document.location.href; return parentUrl; }; IFrameBridge.prototype.__azarMessageListener = function (event) { this.__azarHandleData(event.data); }; IFrameBridge.prototype.__azarHandleData = function (data) { if (data.bridgeId !== this.id) return; if (data.type) { if (data.type == "INVOKE") { try { var result = this.__azarSelfInvoke(data.name, data.params); if (result && typeof result.then == 'function') { result.then(function (result) { this.__azarResolve(data.taskId, result); }.bind(this)) .catch(function (err) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z)(err); this.__azarResolve(data.taskId, null, err); }.bind(this)); } else { this.__azarResolve(data.taskId, result); } } catch (err) { (0,_Code_safeThrow__WEBPACK_IMPORTED_MODULE_2__/* ["default"] */ .Z)(err); this.__azarResolve(data.taskId, null, err); } } else if (data.type == "INVOKE_RESULT") { if (this.__azarResolveCallbacks[data.taskId]) { if (data.error) { this.__azarRejectCallbacks[data.taskId](data.error); } else { this.__azarResolveCallbacks[data.taskId](data.result); } delete this.__azarResolveCallbacks[data.taskId]; delete this.__azarRejectCallbacks[data.taskId]; } } else if (data.type == "EMIT") { this.fire.apply(this, data.params); } else this.fire('message', data, this); } }; IFrameBridge.prototype.__azarResolve = function (taskId, result, error) { var data = { type: "INVOKE_RESULT", taskId: taskId, result: result, error: error, bridgeId: this.id }; if (this.origin) { this.sender.postMessage(data, this.origin); } else { this.sender.postMessage(data); } }; IFrameBridge.prototype.__azarSelfInvoke = function (name, params) { if (typeof this[name] == 'function') { return this[name].apply(this, params); } else { return this[name]; } }; IFrameBridge.prototype.emit = function () { var params = []; params.push.apply(params, arguments); this.sync.then(function () { var data = { type: "EMIT", params: params, bridgeId: this.id }; if (this.origin) { this.sender.postMessage(data, this.origin); } else { this.sender.postMessage(data); } }.bind(this)); return this; }; IFrameBridge.prototype.invoke = function (name) { var params = []; params.push.apply(params, arguments); params.shift(); return this.sync.then(function () { var indent = (0,_String_stringGenerate__WEBPACK_IMPORTED_MODULE_1__.randomIdent)(32); var data = { type: 'INVOKE', params: params, taskId: indent, name: name, bridgeId: this.id }; if (this.origin) { this.host.postMessage(data, this.origin); } else { this.host.postMessage(data); } return new Promise(function (resolve, reject) { this.__azarResolveCallbacks[indent] = resolve; this.__azarRejectCallbacks[indent] = reject; }.bind(this)); }.bind(this)); }; IFrameBridge.prototype.importScriptURLs = function () { return this.invoke.apply(this, ['_receiveScriptURLs'].concat(Array.prototype.slice.call(arguments))); }; IFrameBridge.prototype.importScript = function (code) { var blob = new Blob([code], { type: 'application/javascript' }); var url = URL.createObjectURL(blob); return this.importScriptURLs(url); }; IFrameBridge.prototype.createMethod = function (name, fx) { this[name] = function () { return this.invoke.apply(this, [name].concat(Array.prototype.slice.call(arguments))); }; return this.invoke.apply(this, ['_receiveMethod', name, fx.toString()]); }; IFrameBridge.prototype._receiveScriptURLs = function () { if (self.importScripts) { self.importScripts.apply(self, arguments); } }; IFrameBridge.prototype._receiveMethod = function (name, code) { this[name] = (new Function('return ' + code))(); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (IFrameBridge); /***/ }), /***/ 6672: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ Network_Thread) }); // EXTERNAL MODULE: ./node_modules/absol/src/Network/IFrameBridge.js var IFrameBridge = __webpack_require__(3154); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); ;// CONCATENATED MODULE: ./node_modules/absol/src/Network/RemoteThread.tpl /* harmony default export */ const RemoteThread = ("function safeThrow(error) {\r\n setTimeout(function () {\r\n throw error;\r\n }, 0);\r\n}\r\n\r\nfunction EventEmitter() {\r\n if (!this._azar_extendEvents) {\r\n Object.defineProperty(this, '_azar_extendEvents', {\r\n enumerable: false,\r\n value: this._azar_extendEvents || { supported: {}, prioritize: {}, nonprioritize: {} }\r\n });\r\n Object.defineProperty(this, '__azar_force', {\r\n value: true,\r\n enumerable: false\r\n });\r\n }\r\n}\r\n\r\n\r\nEventEmitter.prototype.defineEvent = function (name) {\r\n if (name instanceof Array) {\r\n for (var i = 0; i < name.length; ++i)\r\n this._azar_extendEvents.supported[name[i]] = true;\r\n }\r\n else\r\n this._azar_extendEvents.supported[name] = true;\r\n return this;\r\n};\r\n\r\nEventEmitter.prototype.isSupportedEvent = function (name) {\r\n return true;\r\n};\r\n\r\n\r\nEventEmitter.prototype.emit = function (eventName, data) {\r\n this.fire.apply(this, arguments);\r\n};\r\n\r\nEventEmitter.prototype.fire = function (eventName, data) {\r\n var others = Array.prototype.slice.call(arguments, 1);\r\n if (this.isSupportedEvent(eventName)) {\r\n var listenerList;\r\n var i;\r\n if (this._azar_extendEvents.prioritize[eventName]) {\r\n listenerList = this._azar_extendEvents.prioritize[eventName].slice();\r\n for (i = 0; i < listenerList.length; ++i) {\r\n try {\r\n listenerList[i].wrappedCallback.apply(this, others);\r\n } catch (e) {\r\n safeThrow(e);\r\n }\r\n }\r\n }\r\n\r\n if (this._azar_extendEvents.nonprioritize[eventName]) {\r\n listenerList = this._azar_extendEvents.nonprioritize[eventName].slice();\r\n for (i = 0; i < listenerList.length; ++i) {\r\n try {\r\n listenerList[i].wrappedCallback.apply(this, others);\r\n } catch (e) {\r\n safeThrow(e);\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n if (this.dispatchEvent) {\r\n var event = new Event(eventName);\r\n data && Object.assign(event, data);\r\n this.dispatchEvent(event);\r\n }\r\n else\r\n throw new Error(\"Not support event \" + eventName);\r\n }\r\n return this;\r\n};\r\n\r\n\r\nEventEmitter.prototype.eventEmittorOnWithTime = function (isOnce, arg0, arg1, arg2) {\r\n if (typeof arg0 == 'object') {\r\n for (var key in arg0) {\r\n this.eventEmittorOnWithTime(isOnce, key, arg0[key]);\r\n }\r\n return this;\r\n }\r\n else {\r\n if (typeof arg1 == 'object') {\r\n return this.eventEmittorOnWithTime(isOnce, arg0, arg1.callback, arg1.cap);\r\n }\r\n else {\r\n var eventArr = this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] || [];\r\n var eventIndex = -1;\r\n for (var i = 0; i < eventArr.length; ++i) {\r\n if (eventArr[i].wrappedCallback == arg1) {\r\n eventIndex = i;\r\n break;\r\n }\r\n }\r\n if (eventIndex < 0) {\r\n var event = { isOnce: isOnce, eventName: arg0, callback: arg1, cap: !!arg2 };\r\n //wrappedCallback will be call\r\n if (isOnce) {\r\n event.wrappedCallback = function () {\r\n event.callback.apply(this, arguments);\r\n this.off(event.eventName, event.wrappedCallback, event.cap);\r\n };\r\n }\r\n else {\r\n event.wrappedCallback = event.callback;\r\n }\r\n\r\n if (!this.isSupportedEvent(arg0)) {\r\n if (this.addEventListener) {\r\n this.addEventListener(arg0, event.wrappedCallback, !!arg2);\r\n }\r\n else {\r\n this.attachEvent('on' + arg0, arg1, !!arg2);\r\n }\r\n }\r\n\r\n eventArr.push(event);\r\n this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] = eventArr;\r\n }\r\n else {\r\n console.warn(\"dupplicate event\");\r\n }\r\n\r\n }\r\n return this;\r\n }\r\n};\r\n\r\n\r\nEventEmitter.prototype.on = function (arg0, arg1, arg2) {\r\n this.eventEmittorOnWithTime(false, arg0, arg1, arg2);\r\n return this;\r\n};\r\n\r\n\r\nEventEmitter.prototype.once = function (arg0, arg1, arg2) {\r\n this.eventEmittorOnWithTime(true, arg0, arg1, arg2);\r\n return this;\r\n};\r\n\r\nEventEmitter.prototype.off = function (arg0, arg1, arg2) {\r\n if (typeof arg0 == 'object') {\r\n for (var key in arg0) {\r\n this.off(key, arg0[key]);\r\n }\r\n return this;\r\n }\r\n else {\r\n if (typeof arg1 == 'object') {\r\n return this.off(arg0, arg1.callback, arg1.cap);\r\n }\r\n else {\r\n var eventArr = this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] || [];\r\n var newEventArray = [];\r\n for (var i = 0; i < eventArr.length; ++i) {\r\n var event = eventArr[i];\r\n if (event.wrappedCallback == arg1) {\r\n //Dont add to newEventArray\r\n if (this.isSupportedEvent(arg0)) {\r\n }\r\n else {\r\n if (this.removeEventListener) {\r\n this.removeEventListener(event.eventName, event.wrappedCallback, !!event.cap);\r\n }\r\n else {\r\n this.detachEvent('on' + event.eventName, event.wrappedCallback, !!event.cap);\r\n }\r\n }\r\n }\r\n else {\r\n newEventArray.push(event);\r\n }\r\n }\r\n this._azar_extendEvents[arg2 ? 'prioritize' : 'nonprioritize'][arg0] = newEventArray;\r\n return this;\r\n }\r\n }\r\n\r\n};\r\n\r\n\r\nvar TYPE_WORKER = 'WORKER';\r\n\r\n/**\r\n *\r\n * @param {Worker|HTMLIFrameElement|WorkerGlobalScope|Window=} host\r\n */\r\nfunction IFrameBridge(host) {\r\n EventEmitter.call(this);\r\n /***\r\n *\r\n * @type {Worker|HTMLIFrameElement|WorkerGlobalScope|Window|WorkerGlobalScope|Window}\r\n */\r\n this.host = host || self;\r\n this.sender = null;\r\n this.receiver = null;\r\n this.origin = null;\r\n this.type = 'NOT_DETECT';\r\n this.id = \"UNSET\";\r\n\r\n this.sync = this._detectHost().then(() => this._attach());\r\n\r\n this.__azarResolveCallbacks = {};\r\n this.__azarRejectCallbacks = {};\r\n}\r\n\r\nIFrameBridge.prototype._detectHost = function () {\r\n this.type = TYPE_WORKER;\r\n this.sender = this.host;\r\n this.receiver = this.host;\r\n return Promise.resolve();\r\n};\r\n\r\n\r\nIFrameBridge.prototype._attach = function () {\r\n if (this.receiver.addEventListener) {\r\n this.receiver.addEventListener(\"message\", this.__azarMessageListener.bind(this), false);\r\n }\r\n else if (this.receiver.attachEvent) {\r\n this.receiver.attachEvent(\"onmessage\", this.__azarMessageListener.bind(this));\r\n }\r\n else {\r\n this.receiver.onmessage = this.__azarMessageListener.bind(this);\r\n }\r\n};\r\n\r\n\r\nIFrameBridge.getInstance = function () {\r\n if (!IFrameBridge.shareInstance) {\r\n var origin = location.origin;\r\n var rootOrigin = IFrameBridge.getParentUrl().match(/^(http|https):\\/\\/[^/]+/);\r\n if (rootOrigin) {\r\n rootOrigin = rootOrigin[0];\r\n }\r\n else {\r\n rootOrigin = origin;\r\n }\r\n\r\n // IFrameBridge.shareInstance = new IFrameBridge(self, rootOrigin == origin? undefined: \"*\" || rootOrigin );\r\n var host = self;\r\n IFrameBridge.shareInstance = new IFrameBridge(host, rootOrigin);\r\n }\r\n return IFrameBridge.shareInstance;\r\n};\r\n\r\n\r\nObject.defineProperties(IFrameBridge.prototype, Object.getOwnPropertyDescriptors(EventEmitter.prototype));\r\nIFrameBridge.prototype.constructor = IFrameBridge;\r\n\r\n\r\nIFrameBridge.getParentUrl = function () {\r\n var parentUrl = (window.location != window.parent.location)\r\n ? document.referrer\r\n : document.location.href;\r\n return parentUrl;\r\n};\r\n\r\nIFrameBridge.prototype.__azarMessageListener = function (event) {\r\n this.__azarHandleData(event.data);\r\n};\r\n\r\n\r\nIFrameBridge.prototype.__azarHandleData = function (data) {\r\n if (data.bridgeId !== this.id) return;\r\n if (data.type) {\r\n if (data.type == \"INVOKE\") {\r\n try {\r\n var result = this.__azarSelfInvoke(data.name, data.params);\r\n if (result && typeof result.then == 'function') {\r\n result.then(function (result) {\r\n this.__azarResolve(data.taskId, result);\r\n }.bind(this))\r\n .catch(function (err) {\r\n safeThrow(err);\r\n this.__azarResolve(data.taskId, null, err);\r\n }.bind(this));\r\n }\r\n else {\r\n this.__azarResolve(data.taskId, result);\r\n }\r\n } catch (err) {\r\n safeThrow(err);\r\n this.__azarResolve(data.taskId, null, err);\r\n }\r\n }\r\n else if (data.type == \"INVOKE_RESULT\") {\r\n if (this.__azarResolveCallbacks[data.taskId]) {\r\n if (data.error) {\r\n this.__azarRejectCallbacks[data.taskId](data.error);\r\n }\r\n else {\r\n this.__azarResolveCallbacks[data.taskId](data.result);\r\n }\r\n delete this.__azarResolveCallbacks[data.taskId];\r\n delete this.__azarRejectCallbacks[data.taskId];\r\n }\r\n }\r\n else if (data.type == \"EMIT\") {\r\n this.fire.apply(this, data.params);\r\n }\r\n else this.fire('message', data, this);\r\n }\r\n};\r\n\r\n\r\nIFrameBridge.prototype.__azarResolve = function (taskId, result, error) {\r\n var data = {\r\n type: \"INVOKE_RESULT\",\r\n taskId: taskId,\r\n result: result,\r\n error: error,\r\n bridgeId: this.id\r\n };\r\n\r\n if (this.origin) {\r\n this.sender.postMessage(data, this.origin);\r\n }\r\n else {\r\n this.sender.postMessage(data);\r\n }\r\n};\r\n\r\n\r\nIFrameBridge.prototype.__azarSelfInvoke = function (name, params) {\r\n if (typeof this[name] == 'function') {\r\n return this[name].apply(this, params);\r\n }\r\n else {\r\n return this[name];\r\n }\r\n};\r\n\r\n\r\nIFrameBridge.prototype.emit = function () {\r\n var params = [];\r\n params.push.apply(params, arguments);\r\n this.sync.then(function () {\r\n var data = {\r\n type: \"EMIT\",\r\n params: params,\r\n bridgeId: this.id\r\n };\r\n if (this.origin) {\r\n this.sender.postMessage(data, this.origin);\r\n }\r\n else {\r\n this.sender.postMessage(data);\r\n }\r\n }.bind(this));\r\n return this;\r\n};\r\n\r\n\r\nIFrameBridge.prototype.invoke = function (name) {\r\n var params = [];\r\n params.push.apply(params, arguments);\r\n params.shift();\r\n return this.sync.then(function () {\r\n var indent = randomIdent(32);\r\n var data = {\r\n type: 'INVOKE',\r\n params: params,\r\n taskId: indent,\r\n name: name,\r\n bridgeId: this.id\r\n };\r\n if (this.origin) {\r\n this.host.postMessage(data, this.origin);\r\n }\r\n else {\r\n this.host.postMessage(data);\r\n }\r\n return new Promise(function (resolve, reject) {\r\n this.__azarResolveCallbacks[indent] = resolve;\r\n this.__azarRejectCallbacks[indent] = reject;\r\n }.bind(this));\r\n }.bind(this));\r\n};\r\n\r\nIFrameBridge.prototype.importScriptURLs = function () {\r\n return this.invoke.apply(this, ['_receiveScriptURLs'].concat(Array.prototype.slice.call(arguments)));\r\n};\r\n\r\nIFrameBridge.prototype.importScript = function (code) {\r\n var blob = new Blob([code], { type: 'application/javascript' });\r\n var url = URL.createObjectURL(blob);\r\n return this.importScriptURLs(url);\r\n};\r\n\r\n\r\nIFrameBridge.prototype.createMethod = function (name, fx) {\r\n this[name] = function () {\r\n return this.invoke.apply(this, [name].concat(Array.prototype.slice.call(arguments)));\r\n };\r\n return this.invoke.apply(this, ['_receiveMethod', name, fx.toString()]);\r\n};\r\n\r\n\r\nIFrameBridge.prototype._receiveScriptURLs = function () {\r\n if (self.importScripts) {\r\n self.importScripts.apply(self, arguments);\r\n }\r\n};\r\n\r\n\r\nIFrameBridge.prototype._receiveMethod = function (name, code) {\r\n this[name] = (new Function('return ' + code))();\r\n};\r\n\r\n\r\nvar IFrameBridge_prototype_descriptors = Object.getOwnPropertyDescriptors(IFrameBridge.prototype);\r\ndelete IFrameBridge_prototype_descriptors.constructor;\r\n\r\nObject.defineProperties(self, IFrameBridge_prototype_descriptors);\r\nIFrameBridge.call(self, self);"); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol/src/Network/Thread.js /*** * * @param {{methods?:Object, extendCode: string}} opt * @constructor */ function Thread(opt) { this.worker = new Worker(this._makeCodeUrl(opt)); IFrameBridge/* default.call */.Z.call(this, this.worker); this._attachClientMethods(opt.methods); } Thread.prototype._makeCodeUrl = function (opt) { var code = [ this._makeLibCode(opt.libs), RemoteThread, this._makeMethodCode(opt.methods), this._makePropCode(opt.props), opt.extendCode || '', ].join('\n\n'); var blob = new Blob([code], { type: 'application/javascript' }); var url = URL.createObjectURL(blob); return url; }; Thread.prototype._makePropCode = function (props) { if (!props) return ''; return 'Object.assign(self, ' + JSON.stringify(props) + ');'; }; Thread.prototype._makeLibCode = function (libs) { if (!libs) return ''; return libs.map(function (lib) { return 'self.importScripts(' + JSON.stringify(lib) + ');' }).join('\n'); } Thread.prototype._makeMethodCode = function (methods) { if (!methods) return ''; return Object.keys(methods).map(function (key) { var fx = methods[key]; if (typeof fx === "function") { fx = fx.toString(); return 'self[' + JSON.stringify(key) + '] = ' + fx; } }).join('\n\n'); }; Thread.prototype._attachClientMethods = function (methods) { if (!methods) return ''; Object.keys(methods).reduce(function (ac, name) { ac[name] = function () { return this.invoke.apply(this, [name].concat(Array.prototype.slice.call(arguments))) } return ac; }, this); }; Thread.prototype.destroy = function () { if (this.worker) { this.worker.terminate(); delete this.worker; } }; Thread.prototype.revokeResource = function () { this.destroy(); this.revokeResource = noop/* default */.Z; }; OOP/* default.mixClass */.ZP.mixClass(Thread, IFrameBridge/* default */.Z); /* harmony default export */ const Network_Thread = (Thread); /***/ }), /***/ 6069: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); var XHR = {}; XHR.makeHttpObject = function () { try { return new XMLHttpRequest(); } catch (error) { } try { return new ActiveXObject("Msxml2.XMLHTTP"); } catch (error) { } try { return new ActiveXObject("Microsoft.XMLHTTP"); } catch (error) { } throw new Error("Could not create HTTP request object."); }; /*** * * @param {String} url * @param {String} body * @param {String} responseType * @param {Function} success * @param {Function} failure * @returns {Promise} */ XHR.getRequest = function (url, props, success, failure) { return new Promise(function (rs, rj) { var request = XHR.makeHttpObject(); request.open("GET", url, true); if (typeof props == 'string') request.responseType = props || ''; else if (props && (typeof props == 'object')) { Object.assign(request, props); } request.send(null); request.onreadystatechange = function () { if (request.readyState == 4) { if (request.status == 200) { var response = request.response; success && success(response); rs(response); } else { failure && failure(request.status, request.statusText); rj({status: request.status }); } } }; request.onerror = function () { failure && failure(request.status, request.statusText); rj(new Error(request.status + request.statusText)); }; }); }; XHR.postRepquest = function (url, payload, props, headers, success, failure) { return new Promise(function (rs, rj) { var method = "POST"; var shouldBeAsync = true; var request = XHR.makeHttpObject(); request.onreadystatechange = function () { if (request.readyState == 4) { if (request.status == 200) { success && success(request.response); rs(request.response); } else if (failure) { failure && failure(request.status, request.statusText); rj({ status: request.status, statusText: request.statusText }); } } }; request.onerror = function () { failure && failure(request.status, request.statusText); rj(new Error(request.status + request.statusText)); }; request.open(method, url, shouldBeAsync); if (typeof props == 'string') request.responseType = props || ''; else if (props && (typeof props == 'object')) { Object.assign(request, props); } headers = headers || {}; headers["Content-Type"] = headers["Content-Type"] || "application/json;charset=UTF-8"; Object.keys(headers).forEach(function (key) { request.setRequestHeader(key, headers[key]); }); request.send(payload); }); }; XHR.request = function (method, url, props, headers, body, successCallback, failureCallback) { return new Promise(function (rs, rj) { var shouldBeAsync = true; var request = new XMLHttpRequest(); request.onreadystatechange = function () { if (request.readyState == 4) { if (request.status == 200) { successCallback && successCallback(request.response); rs(request.response); } else { failureCallback && failureCallback(request.status, request.statusText); rj({ status: request.status, statusText: request.statusText }); } } }; request.onerror = function () { var error = new Error("Network Error!"); if (failureCallback) failureCallback(error); rj(error); }; request.open(method, url, shouldBeAsync); if (typeof props == 'string') request.responseType = props || ''; else if (props && (typeof props == 'object')) { Object.assign(request, props); } headers = headers || {}; headers["Content-Type"] = headers["Content-Type"] || "application/json;charset=UTF-8"; Object.keys(headers).forEach(function (key) { request.setRequestHeader(key, headers[key]); }); request.send(body); }); }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (XHR); /***/ }), /***/ 9238: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ve": () => (/* binding */ loadScript), /* harmony export */ "AU": () => (/* binding */ isImageURLAllowCrossOrigin), /* harmony export */ "t2": () => (/* binding */ loadToBlobURL) /* harmony export */ }); var XLoader = {}; function loadScript(url, onComplete, onError) { return new Promise(function (resolve, reject) { var script = document.createElement("script"); script.type = "text/javascript"; if (script.readyState) { //IE script.onreadystatechange = function () { if (script.readyState === "loaded" || script.readyState === "complete") { script.onreadystatechange = null; onComplete && onComplete(); resolve(); } }; } else { //Others script.onload = function () { script.onload = null; script.onerror = null; onComplete && onComplete(); resolve(); }; script.onerror = function () { script.onerror = null; script.onload = null; script.remove(); onError && onError(); reject(); } } script.src = url; document.getElementsByTagName("head")[0].appendChild(script); }); } XLoader.loadScript = loadScript; function isImageURLAllowCrossOrigin(url) { return new Promise((rs, rj) => { url = url ||''; if (url.startsWith('data:') || url.startsWith('blob:')) { rs(true); return; } var img = new Image(); // img.crossOrigin = "anonymous"; img.onload = function () { var canvas = document.createElement('canvas'); canvas.width = 10; canvas.height = 10; var ctx = canvas.getContext("2d"); ctx.drawImage(this, 0, 0); try { ctx.getImageData(0, 0, 10, 10); rs(true); } catch (err) { rs(false); } } img.onerror = function (event) { rj(event.error || event); } img.src = url; }); } var blobCache = {}; /*** * * @param {string} url * @param {boolean=}noCache * @return {*} */ function loadToBlobURL(url, noCache) { if (blobCache[url]) return blobCache[url]; blobCache[url] = fetch(url).then(res=> res.blob()).then(blob=> URL.createObjectURL(blob)); return blobCache[url]; } /* unused harmony default export */ var __WEBPACK_DEFAULT_EXPORT__ = ((/* unused pure expression or super */ null && (XLoader))); /***/ }), /***/ 56: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Hg": () => (/* binding */ parsedNodeToAST), /* harmony export */ "xI": () => (/* binding */ parsedNodeToASTChain), /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _DataStructure_Heap__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5491); var TARGET = 0; var RULE = 1; var PASSED = 2; var LENGTH = 3; var TRACK = 4; /*** * @param {string} target * @param {Rule|null} rule * @param {number} passed * @param {number} length * @param {[]} track * * @returns {*[]} */ function mkItem(target, rule, passed, length, track) { return [target, rule, passed, length, track]; } function indexingItem(item) { return item[TARGET] + '*' + item[PASSED] + '*' + item[LENGTH]; } function arrayKey(item) { return item[TARGET] + '*' + item[PASSED]; } /**** * * @param {DPParser} parser * @param {string || []} source * @param {string} target * @constructor */ function DPParseInstance(parser, source, target) { this.target = target; this.parser = parser; this.targets = parser.targets; this.rules = parser.rules; this.tokenTypes = parser.tokenizer.types; this.error = null; this.source = source; var start = Date.now(); if (typeof source === "string") { this.tokens = parser.tokenizer.tokenize(source).filter(function (tk) { return tk.type !== 'skip'; }); } else if (source instanceof Array) { this.tokens = source } else { throw new Error("Invalid source, source must be string or array of token"); } this.tokenIdx = 0; this.priQueue = new _DataStructure_Heap__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP(this._cmpFunction); this.maxSize = 0; this.expectedArr = []; this.parsedNode = null; this.ast = null; start = Date.now(); this._dp(); this._trackBack(); if (this.parsedNode) { this._calcAST(); } else { this._findError(); } } DPParseInstance.prototype._dp = function () { while (this.tokenIdx < this.tokens.length) { this._nextToken(); } }; DPParseInstance.prototype._cmpFunction = function (a, b) { return b[LENGTH] - a[LENGTH]; }; DPParseInstance.prototype._nextToken = function () { var idx = this.tokenIdx++; var token = this.tokens[idx]; this.priQueue.push(mkItem('.' + token.type, null, 1, 1, [null, token])); this.priQueue.push(mkItem('_' + token.content, null, 1, 1, [null, token])); var expected = {}; var pushed = {}; var itemIndex; var longestChecked = {}; this.expectedArr.push(expected); var cur, next; var i, j, rule; var prevExpectedList, prevRule; var prevExpectedItem; //nếu cùng 1 rule, cùng điểm bắt dầu, cùng passed thì dài hơn lấy while (this.priQueue.size() > 0) { this.maxSize = Math.max(this.maxSize, this.priQueue.size()); cur = this.priQueue.pop(); for (i = 0; i < this.rules.length; ++i) { rule = this.rules[i]; if (rule.elements[0] === cur[TARGET]) { if (rule.elements.length === 1) { next = mkItem(rule.target, rule, cur[PASSED], cur[LENGTH], [null, cur]); itemIndex = indexingItem(next); if (!pushed[itemIndex]) { pushed[itemIndex] = true; this.priQueue.push(next); } expected['^'] = expected['^'] || []; expected['^'].push(next); } else { next = mkItem(rule.target, rule, 1, cur[LENGTH], [null, cur]); expected[rule.elements[1]] = expected[rule.elements[1]] || []; expected[rule.elements[1]].push(next); } } } prevExpectedList = this.expectedArr[idx - cur[LENGTH]] && this.expectedArr[idx - cur[LENGTH]][cur[TARGET]]; if (prevExpectedList) { for (j = 0; j < prevExpectedList.length; ++j) { prevExpectedItem = prevExpectedList[j]; prevRule = prevExpectedItem[RULE]; next = mkItem(prevRule.target, prevRule, prevExpectedItem[PASSED] + 1, prevExpectedItem[LENGTH] + cur[LENGTH], [prevExpectedItem, cur]); if (prevExpectedItem[PASSED] + 1 === prevRule.elements.length) { itemIndex = indexingItem(next); if (next[RULE] && next[RULE].longestOnly) { if (longestChecked[next[RULE].ident] && longestChecked[next[RULE].ident] >= next[LENGTH]){ continue; } longestChecked[next[RULE].ident] = next[LENGTH]; } if (!pushed[itemIndex]) { pushed[itemIndex] = true; this.priQueue.push(next); } expected['^'] = expected['^'] || []; expected['^'].push(next);//[rule index, passed, length] } else { expected[prevRule.elements[prevExpectedItem[PASSED] + 1]] = expected[prevRule.elements[prevExpectedItem[PASSED] + 1]] || []; expected[prevRule.elements[prevExpectedItem[PASSED] + 1]].push(next); } } } } }; DPParseInstance.prototype._trackBack = function () { var expectedAr = this.expectedArr; function visit(target, start, length) { var node = { type: target, start: start, end: start + length }; var matchedItem = null; var expected = expectedAr[start + length - 1]; if (!expected) return null; var itemList = expected['^']; if (!itemList) return null; var item; if (itemList) { for (var j = 0; j < itemList.length; ++j) { item = itemList[j]; if (item[TARGET] === target) { if (item[LENGTH] === length) { matchedItem = item; } } } } if (!matchedItem) { return null; } node.rule = matchedItem[RULE]; var childItem = []; var cTrack = matchedItem[TRACK]; var right, left; while (cTrack) { left = cTrack[0]; right = cTrack[1]; childItem.unshift(right); cTrack = left && left[TRACK]; } var ac = childItem.reduce(function (ac, item) { if (typeof item[TRACK][1].type === "string") { ac.child.push(item[TRACK][1]); ac.start += 1; } else { ac.child.push(visit(item[TARGET], ac.start, item[LENGTH])); ac.start += item[LENGTH]; } return ac; }, { start: start, child: [] }); node.children = ac.child; node.end = ac.start; return node; } this.parsedNode = visit(this.target, 0, this.expectedArr.length); }; DPParseInstance.prototype._findError = function () { function cmp(a, b) { return b.i - a.i; } var queue = new _DataStructure_Heap__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .ZP(cmp); var doneArr = Array(this.expectedArr.length).fill(null).map(function () { return {} }); this.expectedArr.forEach(function (ex, i) { for (var k in ex) { ex[k].forEach(function (it) { var target = it[TARGET]; var done = doneArr[i - it[LENGTH] + 1]; done[target] = done[target] || []; done[target].push(it); }) } }); var d = {}; queue.push({ t: this.target, i: 0 }); d[this.target + '/' + 0] = true; var cr, next; var nextIdent; var item; var hasNewExpected; while (queue.size() > 0) { cr = queue.pop(); if (cr.i >= doneArr.length) { if (!this.error || this.error.tokenIdx < cr.i || this.error.type !== "expected") { this.error = { tokenIdx: cr.i, type: 'expected', expectedToken: [] } } if (cr.t[0] === '_' || cr.t[0] === '.') { this.error.expectedToken.push(cr.t); } continue; } hasNewExpected = false; if (doneArr[cr.i][cr.t]) { doneArr[cr.i][cr.t].forEach(function (item) { if (item[PASSED] < item[RULE].elements.length) { next = { i: cr.i + item[LENGTH], t: item[RULE].elements[item[PASSED]] }; nextIdent = next.t + '/' + next.i; hasNewExpected = true; if (!d[nextIdent]) { d[nextIdent] = true; queue.push(next); } } }); } this.rules.forEach(function (rule) { if (rule.target === cr.t) { next = { i: cr.i, t: rule.elements[0] }; nextIdent = next.t + '/' + next.i; if (!d[nextIdent]) { d[nextIdent] = true; queue.push(next); } } }); if (!hasNewExpected) { if (!this.error || this.error.tokenIdx < cr.i) { this.error = { tokenIdx: cr.i, type: 'unexpected' } } } } if (this.error.type === 'expected') { this.error.message = 'Expected: ' + this.error.expectedToken.map(function (t) { if (t[0] === '.') return t.substring(1); if (t[0] === '_') return JSON.stringify(t.substring(1)); }).join(', '); } else if (this.error.type === 'unexpected') { this.error.message = 'Unexpected token ' + (this.tokens[this.error.tokenIdx].content || JSON.stringify(this.tokens[this.error.tokenIdx])); } }; DPParseInstance.prototype._calcAST = function () { this.ast = this.parsedNode.rule.toAST(this.parsedNode); }; function parsedNodeToAST(parsedNode) { return parsedNode.rule.toAST(parsedNode) } function parsedNodeToASTChain(parsedNode) { return parsedNode.rule.toASTChain(parsedNode); } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DPParseInstance); /***/ }), /***/ 3281: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // EXPORTS __webpack_require__.d(__webpack_exports__, { "Z": () => (/* binding */ Pharse_DPParser) }); ;// CONCATENATED MODULE: ./node_modules/absol/src/Pharse/DPTokenizer.js function DPTokenizer(opt) { opt = opt || {}; if (opt.elementRegexes) this.elementRegexes = opt.elementRegexes; this._combineTokenRegex(); } DPTokenizer.prototype.elementRegexes = [ ['string', /("(?:[^"\\]|\\.)*?")|('(?:[^'\\]|\\.)*?')/], ['number', /(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)/], ['word', /[_a-zA-Z][_a-zA-Z0-9]*/], ['skip', /([\s\r\n]+)|(\/\/[^\n]*)|(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)/], ['dsymbol', /\+\+|--|==|!=|<=|>=|\|\||&&/], ['tsymbol', /\.\.\./], ['symbol', /[^\s_a-zA-Z0-9]/], ]; DPTokenizer.prototype._combineTokenRegex = function () { var tokenRegexSource = this.elementRegexes.map(function (cr) { return '(' + cr[1].source + ')'; }).join('|'); this.tokenRegex = new RegExp(tokenRegexSource, 'g'); this.groupIndexOfTypes = this.elementRegexes.slice(0, this.elementRegexes.length - 1).reduce(function (ac, cr) { var subGroupLength = (new RegExp(cr[1].source + '|.')).exec('a').length; ac.push(ac[ac.length - 1] + subGroupLength); return ac; }, [1]); this.types = this.elementRegexes.reduce(function (ac, cr) { ac[cr[0]] = cr; return ac; }, {}) }; DPTokenizer.prototype.tokenize = function (source) { var regex = new RegExp(this.tokenRegex.source, 'g'); var elementRegexes = this.elementRegexes; var groupIndexOfTypes = this.groupIndexOfTypes; var res = []; var matched = regex.exec(source); var type, i; while (matched) { type = null; for (i = 0; i < groupIndexOfTypes.length; ++i) { if (matched[groupIndexOfTypes[i]]) { type = elementRegexes[i][0]; } } res.push({ type: type, content: matched[0], start: matched.index, end: matched.index + matched[0].length }); matched = regex.exec(source); } return res; }; /* harmony default export */ const Pharse_DPTokenizer = (DPTokenizer); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParseInstance.js var DPParseInstance = __webpack_require__(56); ;// CONCATENATED MODULE: ./node_modules/absol/src/Pharse/DPParser.js /*** * @typedef Rule * @property {string} target * @property {string[]} elements */ /*** * * @param {{rules?:Array, elementRegexes?:Array}}opt * @constructor */ function DPParser(opt) { opt = opt || {}; if (opt.rules) { this.rules = opt.rules; } this.targets = {}; this.tokenizer = new Pharse_DPTokenizer(opt); this.computeTarget(); } /**** * @type {Rule[]} */ DPParser.prototype.rules = []; DPParser.prototype.computeTarget = function () { this.rules.reduce(function (ac, rule) { var target = ac[rule.target]; if (!target) { target = { rules: [] } ac[rule.target] = target; } target.rules.push(rule); return ac; }, this.targets); }; /*** * * @param {string|[]}source * @param target * @returns {DPParseInstance} */ DPParser.prototype.parse = function (source, target) { return new DPParseInstance/* default */.ZP(this, source, target); }; /* harmony default export */ const Pharse_DPParser = (DPParser); /***/ }), /***/ 1942: /***/ (() => { if (navigator.geolocation) { var getCurrentPosition = navigator.geolocation.getCurrentPosition; var lastResult = null; navigator.geolocation.getCurrentPosition = function (successCallback, errorCallback, options) { if (typeof successCallback !== "function") successCallback = function (){}; if (typeof errorCallback !== "function") errorCallback = function (){}; var ended = false; var to = setTimeout(function (){ if (lastResult && !ended) { ended = true; successCallback && successCallback(lastResult); } else if (!ended) { ended = true; errorCallback && errorCallback(new Error("GPS không phản hồi.")); } }, lastResult?5000: 10000); getCurrentPosition.call(this, function (result){ lastResult = result; if (!ended) { ended = true; successCallback && successCallback(lastResult); } }, function (error) { if (error && error.message.indexOf('deni') >0 && !ended) { ended = true; errorCallback && errorCallback(new Error("Chưa cấp quyền truy cập GPS.")); } else if (lastResult && !ended) { ended = true; successCallback && successCallback(lastResult); } else if (!ended) { ended = true; errorCallback && errorCallback(error); } }, {maximumAge: 1000}); } } /***/ }), /***/ 5421: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "ZP": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* unused harmony exports getComputedStyleCache, getComputedStyleValueCache, computePrintAttr */ /* harmony import */ var _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2759); /* harmony import */ var _HTML5_Svg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6821); /* harmony import */ var _HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6628); /* harmony import */ var _JSX_attribute__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(2953); /* harmony import */ var _Network_XLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(9238); var _ = _HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].ShareInstance._ */ .ZP.ShareInstance._; var $ = _HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].ShareInstance.$ */ .ZP.ShareInstance.$; var $$ = _HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* ["default"].ShareInstance.$$ */ .ZP.ShareInstance.$$; /*** * * @param {AElement|HTMLElement} elt * @param {string=} ps * @return {*} */ function getComputedStyleCache(elt, ps) { ps = ps || ''; var key = '__computedStyleCache__' + ps; if (elt[key]) return elt[key]; elt[key] = ps ? getComputedStyle(elt, ps) : getComputedStyle(elt); return elt[key]; } /*** * * @param {AElement|HTMLElement} elt * @param {string} pName * @return {string} */ function getComputedStyleValueCache(elt, pName) { return getComputedStyleCache(elt).getPropertyValue(pName); } function computePrintAttr(elt) { var style = getComputedStyleCache(elt); var fontSize = elt.getFontSize(); var lineHeight = style.getPropertyValue('line-height'); if (lineHeight === 'normal') lineHeight = 1.2; else lineHeight = parseFloat(lineHeight.replace('px', '')) / fontSize; if (!isNaN(lineHeight)) lineHeight = 1.2; var fontWeight = style.getPropertyValue('font-weight'); var fontStyle = fontWeight === '400' ? 'normal' : 'bold'; var dirs = ['top', 'right', 'bottom', 'left']; var paddingStyle = dirs.map(dir => (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('padding-' + dir))); var borderWidthStyle = dirs.map(dir => (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('border-' + dir + '-width'))); var contentBound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); contentBound.x += paddingStyle[3].value + borderWidthStyle[3].value; contentBound.y += paddingStyle[0].value + borderWidthStyle[0].value; contentBound.width += paddingStyle[1].value + borderWidthStyle[1].value + paddingStyle[3].value + borderWidthStyle[3].value; contentBound.height += paddingStyle[2].value + borderWidthStyle[2].value + paddingStyle[0].value + borderWidthStyle[0].value; return { contentBound: contentBound, whiteSpace: style.getPropertyValue('white-space'), style: { color: style.getPropertyValue('color'), fontFamily: style.getPropertyValue('font-family'), fontStyle: fontStyle, lineHeight: lineHeight, fontSize: fontSize, align: style.getPropertyValue('text-align') } } } /*** * * @type {PSHandler[]} */ var PrintSerialHandlers = []; PrintSerialHandlers.push({ id: 'TextNode', match: (elt) => elt.nodeType === Node.TEXT_NODE, exec: (printer, text, scope, stack, accept) => { var O = printer.O; var elt = text.parentElement; var bound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect((0,_HTML5_Dom__WEBPACK_IMPORTED_MODULE_2__/* .getTextNodeBound */ .m1)(text)); if (bound.width === 0) return; var printAttr = computePrintAttr(elt); var txt = text.data; var y = -Infinity; var c; var range; var parts = []; var cPart; var j; var delta = printAttr.style.lineHeight * printAttr.style.fontSize / 3; var rect; var i = 0; while (i < txt.length) { c = txt[i]; if (!c.match(/[\s\n]/)) { j = i + 1; while (j < txt.length) { c = txt[j]; if (c.match(/[\s\n]/)) { break; } else { ++j; } } range = document.createRange(); range.setStart(text, i); range.setEnd(text, j); rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(range.getBoundingClientRect()); if (Math.abs(rect.y - y) < delta) { cPart.end = j; cPart.rect = cPart.rect.merge(rect); } else { cPart = { start: i, end: j, rect: rect }; y = rect.y; parts.push(cPart); } i = j; } else { ++i; } } parts.forEach(part => { rect = part.rect; rect.x -= O.x; rect.y -= O.y; rect.width += printAttr.style.fontSize * 1000; var lineTxt = txt.substring(part.start, part.end); if (printAttr.whiteSpace === 'normal') { lineTxt = lineTxt.replace(/[\s\n]+/g, ' '); } delete printAttr.style.align;//text-node bound printer.text(lineTxt, rect, printAttr.style); }); } }); PrintSerialHandlers.push({ id: 'Border', match: (elt, scope, stack) => { if (scope.isDeclared('borderStyle')) return false; var style = getComputedStyleCache(elt); var borderColor = style.getPropertyValue('border-color'); var borderStyle = style.getPropertyValue('border-style'); var borderWidth = style.getPropertyValue('border-width'); var borderRadius = style.getPropertyValue('border-radius'); if (borderStyle === 'none' || borderWidth === '0px') return false; scope.declare('borderStyle', { width: parseFloat(borderWidth.replace('px', '')), radius: (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(borderRadius), color: borderColor, }) return true; }, exec: (printer, elt, scope, stack, accept) => { var borderStyle = scope.get('borderStyle'); var bound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); var rect = bound.clone(); var strokeWidth = borderStyle.width; if (elt.tagName === 'TD' || elt.tagName === 'TH') { rect.x -= printer.O.x; rect.y -= printer.O.y; } else { rect.x -= printer.O.x - strokeWidth / 2; rect.y -= printer.O.y - strokeWidth / 2; rect.width -= strokeWidth; rect.height -= strokeWidth; } var radius = borderStyle.radius; var rounded; if (radius) { switch (radius.unit) { case '%': rounded = [radius.value * rect.width / 100, radius.value * rect.height / 100]; break; case 'px': rounded = radius.value; break; } } printer.rect(rect, { stroke: borderStyle.color, rounded: rounded, strokeWidth: strokeWidth }); return true; } }); PrintSerialHandlers.push({ id: 'BackgroundImage', match: (elt, scope, stack) => { return elt.getComputedStyleValue('background-image') !== 'none'; }, exec: (printer, elt, scope, stack, accept) => { var style = getComputedStyleCache(elt); var backgroundSize = style.getPropertyValue('background-size'); var url = style.getPropertyValue('background-image').trim() .replace('url("', '') .replace('")', ''); var rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); rect.x -= printer.O.x; rect.y -= printer.O.y; var borderRadius = ['top-left', 'top-right', 'bottom-right', 'bottom-left'].map(key => (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('border-' + key + '-radius'))); var image = (0,_Network_XLoader__WEBPACK_IMPORTED_MODULE_4__/* .isImageURLAllowCrossOrigin */ .AU)(url).then(result => { /*** * * @type {HTMLCanvasElement} */ var canvas = document.createElement('canvas'); var width = rect.width; var height = rect.height; canvas.width = width; canvas.height = height; var image = new Image(); image.crossOrigin = 'anonymous'; image.src = result ? url : 'https://absol.cf/crossdownload.php?file=' + encodeURIComponent(url); var ctx = canvas.getContext('2d'); var isRect = borderRadius.every(x => x.value === 0); var x, y, r; var eclipses = []; var points = []; if (!isRect) { r = borderRadius[0]; x = r.unit === '%' ? r.value / 100 * width : r.value; y = 0; points.push([x, y]); r = borderRadius[1]; x = r.unit === '%' ? (1 - r.value / 100) * width : width - r.value; points.push([x, y]); if (r.value > 0) { y = r.unit === '%' ? r.value / 100 * height : r.value; eclipses.push([x, y, width - x, y, 0, -Math.PI / 2, 0]) x = width; points.push([x, y]); } else { x = width; } r = borderRadius[2]; y = r.unit === '%' ? (1 - r.value / 100) * height : height - r.value; points.push([x, y]); if (r.value > 0) { x = r.unit === '%' ? (1 - r.value / 100) * width : width - r.value; eclipses.push([x, y, width - x, height - y, 0, 0, Math.PI / 2]); y = height; points.push([x, y]); } else { y = height; } r = borderRadius[3]; x = r.unit === '%' ? r.value / 100 * width : r.value; points.push([x, y]); if (r.value > 0) { y = r.unit === '%' ? (1 - r.value / 100) * height : height - r.value; eclipses.push([x, y, x, height - y, 0, Math.PI / 2, Math.PI]); x = 0; points.push([x, y]); } else { x = 0; } r = borderRadius[0]; y = r.unit === '%' ? r.value / 100 * height : r.value; points.push([x, y]); if (r.value > 0) { x = r.unit === '%' ? r.value / 100 * width : r.value; eclipses.push([x, y, x, y, 0, Math.PI, Math.PI * 3 / 2]); } ctx.beginPath(); points.forEach((p, i) => { if (i === 0) ctx.moveTo(p[0], p[1]); else ctx.lineTo(p[0], p[1]); }); ctx.closePath(); ctx.fillStyle = 'red'; ctx.fill(); eclipses.forEach(e => { ctx.beginPath(); ctx.ellipse(e[0], e[1], e[2], e[3], e[4], e[5], e[6]); ctx.fill(); }); ctx.globalCompositeOperation = 'source-in'; } return new Promise(rs => { image.onload = function () { var scale; var nW; var nH;//todo: handle more switch (backgroundSize) { case 'cover': scale = Math.max(width / image.naturalWidth, height / image.height); nW = image.naturalWidth * scale; nH = image.naturalHeight * scale ctx.drawImage(image, 0, 0, nW, nH); break; case 'auto': default: ctx.drawImage(image, 0, 0); } rs(canvas); }; image.onerror = function () { console.error('can not load ', image.src) rs(null); } }) }).catch(err => { console.error(err); }); printer.image(image, rect); return true; } }); PrintSerialHandlers.push({ id: 'BreakInside', match: (elt, scope, stack) => { return getComputedStyleValueCache(elt, 'break-inside') === 'avoid'; }, exec: (printer, elt, scope, stack, accept) => { var rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); rect.x -= printer.O.x; rect.y -= printer.O.y; printer.rect(rect, {}); return true; } }); PrintSerialHandlers.push({ id: 'MDI_FA', match: (elt, scope, stack) => elt.classList && (elt.classList.contains('mdi') || elt.classList.contains('fab') || elt.classList.contains('far') || elt.classList.contains('fas') || elt.classList.contains('material-icons')), exec: (printer, elt, scope, stack, accept) => { var style = elt.classList.contains('material-icons') ? getComputedStyleCache(elt) : getComputedStyleCache(elt, '::before'); var content = elt.classList.contains('material-icons') ? elt.innerHTML : style.getPropertyValue('content'); content = content.replace('"', ''); var font = style.getPropertyValue('font'); var rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); if (rect.width * rect.height === 0) return; var canvas = document.createElement('canvas'); canvas.width = rect.width; canvas.height = rect.height; var ctx = canvas.getContext('2d'); ctx.font = font; ctx.textBaseline = "top"; rect.x -= printer.O.x; rect.y -= printer.O.y; ctx.fillStyle = style.getPropertyValue('color'); ctx.fillText(content, 0, 0); printer.image(canvas, rect); } }); PrintSerialHandlers.push({ id: 'Img', match: elt => elt.tagName && elt.tagName.toLowerCase() === 'img' && elt.src && elt.naturalWidth, exec: (printer, elt, scope, stack, accept) => { var bound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); if (bound.width === 0) return; var rect = bound.clone(); rect.x -= printer.O.x; rect.y -= printer.O.y; printer.image(elt, rect); } }); PrintSerialHandlers.push({ id: 'Canvas', match: elt => elt.tagName && elt.tagName.toLowerCase() === 'canvas', exec: (printer, elt, scope, stack, accept) => { var bound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); if (bound.width === 0) return; var rect = bound.clone(); rect.x -= printer.O.x; rect.y -= printer.O.y; printer.image(elt, rect); } }); PrintSerialHandlers.push({ id: 'SVG', match: elt => elt.tagName && elt.tagName.toLowerCase() === 'svg', exec: (printer, elt, scope, stack, accept) => { var bound = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); if (bound.width === 0) return; var rect = bound.clone(); rect.x -= printer.O.x; rect.y -= printer.O.y; var res = _HTML5_Svg__WEBPACK_IMPORTED_MODULE_1__/* ["default"].svgToCanvas */ .ZP.svgToCanvas(elt.__origin__).catch(err => { console.error(err); }); res.elt = elt; printer.image(res, rect); } }); PrintSerialHandlers.push({ id: 'TextInput', match: (elt, scope, stack) => { return elt.tagName === 'INPUT' && (elt.attr('type') === 'text' || elt.attr('type') === 'number' || !elt.attr('type')); }, exec: (printer, elt, scope, stack, accept) => { var O = printer.O; var style = getComputedStyleCache(elt); var paddingLeft = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('padding-left')); var paddingTop = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('padding-top')); var paddingBottom = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('padding-bottom')); var borderLeftWidth = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('border-left-width')); var borderTopWidth = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('border-top-width')); var borderBottomWidth = (0,_JSX_attribute__WEBPACK_IMPORTED_MODULE_3__.parseMeasureValue)(style.getPropertyValue('border-top-width')); var rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); var fontSize = elt.getFontSize(); var lineHeight = style.getPropertyValue('line-height'); if (lineHeight === 'normal') lineHeight = 1.2; else lineHeight = parseFloat(lineHeight.replace('px', '')) / fontSize; if (!isNaN(lineHeight)) lineHeight = 1.2; var fontWeight = style.getPropertyValue('font-weight'); var fontStyle = fontWeight === '400' ? 'normal' : 'bold'; rect.width = 700; rect.x += borderLeftWidth.value + paddingLeft.value - O.x; rect.height -= borderTopWidth.value + borderBottomWidth.value + paddingTop.value + paddingBottom.value; rect.y += borderTopWidth.value + paddingTop.value - O.y; var centerY = rect.centerPoint().y; rect.y = centerY - fontSize * lineHeight / 2; rect.height = fontSize * lineHeight; printer.text(elt.value, rect, { fontFamily: style.getPropertyValue('font-family'), fontStyle: fontStyle, fontSize: fontSize, lineHeight: lineHeight }); } }); PrintSerialHandlers.push({ id: 'BreakPage', match: elt => elt.hasClass && elt.hasClass('as-page-break'), exec: (printer, elt, scope, stack, accept) => { var rect = _Math_Rectangle__WEBPACK_IMPORTED_MODULE_0__/* ["default"].fromClientRect */ .Z.fromClientRect(elt.getBoundingClientRect()); rect.x -= printer.O.x; rect.y -= printer.O.y; printer.pageBreak(rect.A()); } }); PrintSerialHandlers.push({ id: '*', match: () => true, exec: (printer, elt, scope, stack, accept) => { if (elt.getComputedStyleValue('display') === 'none') return; if (elt.childNodes) { Array.prototype.forEach.call(elt.childNodes, child => accept(child)); } } }) /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (PrintSerialHandlers); /***/ }), /***/ 9673: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "I": () => (/* binding */ mergePdfs) /* harmony export */ }); /* harmony import */ var _Network_XLoader__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9238); // var pdLibUrl = 'https://unpkg.com/pdf-lib/dist/pdf-lib.js'; var pdLibUrl = 'https://absol.cf/vendor/pdf-lib.js'; var libSync = null; function loadVendorLib() { if (libSync) return libSync; if ('PDFLib' in window) { libSync = Promise.resolve(window.PDFLib); } else { libSync = (0,_Network_XLoader__WEBPACK_IMPORTED_MODULE_0__/* .loadScript */ .ve)(pdLibUrl).then(() => window.PDFLib) } return libSync; } function loadPdf(data) { if (typeof data === "string") { return fetch(data).then(res => res.arrayBuffer()).then(buff => loadPdf(buff)); } else if (data instanceof ArrayBuffer) { return PDFLib.PDFDocument.load(data); } else return null; } function mergePdfs(pdfsToMerges, onProcess) { var processInfo = { all: pdfsToMerges.length, loaded: 0, merged: 0 } return loadVendorLib().then(() => { var pdfSync = pdfsToMerges.map(it => loadPdf(it).then(r => { processInfo.loaded++; onProcess && onProcess(processInfo); return r; })); pdfSync.push(PDFLib.PDFDocument.create()); return Promise.all(pdfSync); }).then(pdfs => { var mergedPdf = pdfs.pop(); return pdfs.reduce((sync, pdf) => { return mergedPdf.copyPages(pdf, pdf.getPageIndices()).then(copiedPages => sync.then(() => copiedPages)) .then(copiedPages => { copiedPages.forEach((page) => { mergedPdf.addPage(page); }); processInfo.merged++; onProcess && onProcess(processInfo); }); }, Promise.resolve()).then(() => mergedPdf); }).then(mergedPdf => mergedPdf) } /***/ }), /***/ 2691: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXPORTS __webpack_require__.d(__webpack_exports__, { "PaperPrinter": () => (/* reexport */ Print_PaperPrinter), "PrintSerializer": () => (/* reexport */ Print_PrintSerializer), "ShareSerializer": () => (/* binding */ ShareSerializer), "downloadAsPDF": () => (/* binding */ downloadAsPDF), "mergePdfs": () => (/* reexport */ pdf/* mergePdfs */.I) }); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/VarScope.js var VarScope = __webpack_require__(1312); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Rectangle.js var Rectangle = __webpack_require__(2759); // EXTERNAL MODULE: ./node_modules/absol/src/Print/PrintSerialHandlers.js var PrintSerialHandlers = __webpack_require__(5421); // EXTERNAL MODULE: ./node_modules/absol/src/Network/XLoader.js var XLoader = __webpack_require__(9238); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); ;// CONCATENATED MODULE: ./node_modules/absol/src/Print/PrintSerializer.js /*** * @typedef {Object} PSHandler * @property {string} id * @property {function(elt:AElement, scope: VarScope, stack:Array<AElement>):boolean} match * @property {function(printer: PaperPrinter,elt:AElement|Text, scope: VarScope, stack:Array<{elt: AElement|Text, scope:VarScope}>, accept: function():void):(boolean|void)} exec - return true if run other handle * */ /*** * * @constructor */ function PrintSerializer() { /*** * @type {Array<PSHandler>} */ this.handlers = this.handlers.slice(); } PrintSerializer.prototype.handlers = PrintSerialHandlers/* default */.ZP; /*** * * @param {PaperPrinter} printer * @param {AElement|AElementNS|Text} elt * @param {VarScope} scope * @param {Array<{elt: AElement|Text, scope:VarScope}>} stack */ PrintSerializer.prototype.accept = function (printer, elt, scope, stack) { if (elt.nodeType === Node.ELEMENT_NODE) Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$(elt); var handler; var matched, cont; for (var i = 0; (!matched || cont) && i < this.handlers.length; ++i) { handler = this.handlers[i]; matched = handler.match(elt, scope, stack); if (matched) { cont = handler.exec(printer, elt, scope, stack, elt1 => { this.accept(printer, elt1, new VarScope/* default */.Z(scope), stack.concat([{ elt: elt, scope: scope }])); }); } } }; /*** * * @param {Array<AElement> | AElement | Array<{elt: AElement, opt:Object}>} docList * @param printer * @param onProcess * @return {Promise<Awaited<unknown>[]>} */ PrintSerializer.prototype.serialize = function (docList, printer, onProcess) { var $ = Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$; if (!(docList instanceof Array)) docList = [docList]; docList = docList.map(doc => { if (typeof doc === "string") { return { elt: $(doc) } } else if ((0,Dom/* isDomNode */.mV)(doc)) { return { elt: $(doc) } } else if (typeof doc === "object" && doc) { if (typeof doc.elt === "string") doc.elt = $(doc.elt); if (doc.elt && (0,Dom/* isDomNode */.mV)(doc.elt)) return doc; } else return null; }).filter(it => !!it); var sync = []; var processInfo = { state: 'RENDER_DOM', total: { all: 0, text: 0, image: 0 }, dom: { text: 0, image: 0 }, onProcess: () => { onProcess && onProcess(processInfo); } }; printer.processInfo = processInfo; var contentChildList = docList.map(doc => { var elt = doc.elt; return (0,Dom/* depthClone */.qE)(elt, (originElt, copyElt) => { copyElt.__idx__ = processInfo.total.all; copyElt.__origin__ = originElt; processInfo.total.all++; var parent, fontWeight, style; var done = false; if (originElt.nodeType === Node.TEXT_NODE) { processInfo.total.text++; sync.push(new Promise(rs => { setTimeout(() => { parent = originElt.parentElement; if (!copyElt.__fontWeight__) { style = getComputedStyle(parent); fontWeight = parseInt(style.getPropertyValue('font-weight'));//not support other style copyElt.__fontWeight__ = fontWeight; if (fontWeight <= 400) { copyElt.parentElement.style.setProperty('font-weight', 'normal'); } else if (fontWeight > 400) { copyElt.parentElement.style.setProperty('font-weight', 'bold'); } processInfo.dom.text++; } processInfo.dom.text++; rs(); }, 0) })); } else if (originElt.tagName && originElt.tagName.toLowerCase() === 'canvas') { copyElt.getContext('2d').drawImage(originElt, 0, 0); } else if (originElt.tagName === 'IMG' && !originElt.classList.contains('absol-attachhook') && originElt.src) { processInfo.total.image++; sync.push((0,XLoader/* isImageURLAllowCrossOrigin */.AU)(originElt.src).then(result => { var newElt; if (!result) { newElt = copyElt.cloneNode(); newElt.__idx__ = copyElt.__idx__; newElt.__origin__ = copyElt.__origin__; ; copyElt.parentElement.replaceChild(newElt, copyElt); return (0,XLoader/* loadToBlobURL */.t2)('https://absol.cf/crossdownload.php?file=' + encodeURIComponent(originElt.src)).then(url => newElt.src = url) .then(() => (0,Dom/* waitImageLoaded */.Lp)(newElt, 10000)) .then(() => { if (!done) { processInfo.dom.image++; processInfo.onProcess(); done = true; } }); } else { return (0,Dom/* waitImageLoaded */.Lp)(copyElt, 10000).then(() => { if (!done) { processInfo.dom.image++; processInfo.onProcess(); done = true; } }); } }, (err) => { console.error(err); if (!done) { processInfo.dom.image++; processInfo.onProcess(); done = true; } })); } else if (originElt.tagName === 'INPUT') { if (originElt.getAttribute('type') === 'text' || !originElt.getAttribute('type') || originElt.getAttribute('type') === 'number') { copyElt.value = originElt.value; } else if (originElt.getAttribute('type') === 'radio') { copyElt.setAttribute('name', (copyElt.getAttribute('name') || (0,stringGenerate.randomIdent)()) + '_for_print'); copyElt.checked = originElt.checked; } } }); }); var content = Dom/* default.ShareInstance._ */.ZP.ShareInstance._({ style: { width: 794 - 57 * 2 + 'px', //WIDTH: 1123 - 57*2 display: 'inline-block', overflow: 'visible' }, class: 'as-printer-content', child: contentChildList }); var scroller = Dom/* default.ShareInstance._ */.ZP.ShareInstance._({ class: 'as-printer', style: { 'text-size-adjust': 'none', '-webkit-text-size-adjust': 'none', '-moz-text-size-adjust': 'none', '-ms-text-size-adjust': 'none', position: 'fixed', top: '10px', bottom: '10px', left: '10px', overflow: 'scroll', width: '794px', // maxWidth: '90vw', background: 'white', // zIndex: 1000, opacity: '0', zIndex: '-100', visibility: 'hidden', pointerEvents: 'none' }, child: content }).addTo(document.body); sync.push(new Promise(rs => { setTimeout(rs, 50); })); return Promise.all(sync).then(() => { processInfo.state = "SERIALIZE"; processInfo.onProcess(); docList.forEach((doc, i) => { printer.O = Rectangle/* default.fromClientRect */.Z.fromClientRect(contentChildList[i].getBoundingClientRect()).A(); printer.addSubDocument(printer.O, doc.opt); this.accept(printer, contentChildList[i], new VarScope/* default */.Z(), []); }); }) .then(() => { scroller.remove(); processInfo.onProcess = noop/* default */.Z; return printer; }); }; /*** * * @param {PSHandler} handler * @returns {this} */ PrintSerializer.prototype.addHandler = function (handler) { this.handlers.unshift(handler); return this; }; /*** * * @param {PSHandler} handler * @param {string} bf * @returns {this} */ PrintSerializer.prototype.addHandlerBefore = function (handler, bf) { var idx = this.handlers.findIndex(value => value.id === bf); if (idx >= 0) { this.handlers.splice(idx, 0, handler); } return this; }; /*** * * @param {PSHandler} handler * @param {string} at * @returns {this} */ PrintSerializer.prototype.addHandlerAfter = function (handler, at) { var idx = this.handlers.findIndex(value => value.id === at); if (idx >= 0) { this.handlers.splice(idx + 1, 0, handler); } return this; }; /*** * * @param {Array<PSHandler>} handlers * @returns {this} */ PrintSerializer.prototype.addHandlers = function (handlers) { this.handlers.unshift.apply(this.handlers, handlers); return this; }; /*** * * @param {string} id * @returns {this} */ PrintSerializer.prototype.removeHandler = function (id) { var idx = this.handlers.findIndex(value => value.id === id); if (idx >= 0) { this.handlers.splice(idx, 1); } return this; }; /*** * * @param {string} id * @returns {PSHandler|null} */ PrintSerializer.prototype.getHandler = function (id) { var idx = this.handlers.findIndex(value => value.id === id); if (idx >= 0) { return this.handlers[idx]; } return null; }; /* harmony default export */ const Print_PrintSerializer = (PrintSerializer); // EXTERNAL MODULE: ./node_modules/absol/src/Color/Color.js var Color = __webpack_require__(257); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElement.js var AElement = __webpack_require__(7951); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Vec2.js var Vec2 = __webpack_require__(557); // EXTERNAL MODULE: ./node_modules/absol/src/JSMaker/generator.js var generator = __webpack_require__(2914); ;// CONCATENATED MODULE: ./node_modules/absol/src/Print/PaperPrinter.js var fontIdOf = fontName => { if (fontName.toLowerCase().indexOf('arial') >= 0) return 'arial'; if (fontName.toLowerCase().indexOf('times') >= 0) return 'times'; if (fontName === "Material Design Icons") return 'MDI_6_7_96'; return fontName; } var P2D = 72 / 96; var color2RGB255 = color => { try { color = Color/* default.parse */.Z.parse(color + ''); return color.rgba.slice(0, 3).map(x => x * 255 >> 0); } catch (e) { return null; } }; function PaperPrinter(opt) { this.opt = Object.assign((0,generator/* copyJSVariable */.Ew)(this.defaultOptions), opt); this.objects = []; this.processInfo = { state: "STAND_BY" }; this.subDocs = null; this.pdfDoc = null; this.pageFormat = null; this.computedPages = 0; this.sync = this.ready().then(() => { this.processInfo.state = 'READY'; }); } PaperPrinter.prototype.defaultOptions = { size: 'a4', margin: { top: 57, left: 57, bottom: 57, right: 57 }, footer: null, header: null, paddingEven: true, lastPagePaddingEven: false }; PaperPrinter.prototype.share = { jsPDFUrl: 'https://absol.cf/vendor/jspdf.umd.js', jsPDF: null, readySync: null, fonts: [ { url: 'https://absol.cf/vendor/fonts/arial.ttf', fileName: 'arial.ttf', name: 'arial', style: 'normal' }, { url: 'https://absol.cf/vendor/fonts/arialbd.ttf', fileName: 'arialbd.ttf', name: 'arial', style: 'bold' }, { url: 'https://absol.cf/vendor/fonts/ariali.ttf', fileName: 'ariali.ttf', name: 'arial', style: 'italic' }, { url: 'https://absol.cf/vendor/fonts/arialbi.ttf', fileName: 'arialbi.ttf', name: 'arial', style: 'bold_italic' }, { url: 'https://absol.cf/vendor/fonts/times.ttf', fileName: 'times.ttf', name: 'times', style: 'normal' }, { url: 'https://absol.cf/vendor/fonts/timesbd.ttf', fileName: 'timesbd.ttf', name: 'times', style: 'bold' }, { url: 'https://absol.cf/vendor/fonts/timesi.ttf', fileName: 'timesi.ttf', name: 'times', style: 'italic' }, { url: 'https://absol.cf/vendor/fonts/timesbi.ttf', fileName: 'timesbi.ttf', name: 'times', style: 'bold_italic' } ] }; PaperPrinter.prototype.ready = function () { var sync; if (!this.share.readySync) { sync = this.share.fonts.map((font) => { return fetch(font.url).then(res => res.blob()) .then(blob => { var reader = new window.FileReader(); return new Promise(rs => { reader.onload = function () { rs(this.result); } reader.readAsDataURL(blob); }) }) .then(b64Url => { var idx = b64Url.indexOf('base64,'); return b64Url.substring(idx + 'base64,'.length); }).then(b64 => { font.content = b64; }) }); if (window.jspdf) { this.share.jsPDF = window.jspdf.jsPDF; } else { sync.push((0,XLoader/* loadScript */.ve)(this.share.jsPDFUrl).then(() => { this.share.jsPDF = window.jspdf.jsPDF; })) } this.share.readySync = Promise.all(sync); } return this.share.readySync; }; /*** * * @param at * @param opt */ PaperPrinter.prototype.addSubDocument = function (at, opt) { this.objects.push({ type: 'sub_document', at: at, opt: opt }); }; /*** * * @param {string} text * @param {Vec2 | Rectangle} pos * @param {Object=}style */ PaperPrinter.prototype.text = function (text, pos, style) { this.objects.push({ type: 'text', pos: pos, text: text, style: style || {} }); return this; }; /*** * * @param {string} text * @param {Vec2} start * @param {Vec2} end * @param {Object=}style */ PaperPrinter.prototype.line = function (start, end, style) { this.objects.push({ type: 'line', start: start, end: end, style: style || {} }); return this; }; /*** * * @param {Vec2} at * @param {boolean=} paddingEven */ PaperPrinter.prototype.pageBreak = function (at, paddingEven) { this.objects.push({ type: 'page_break', at: at, paddingEven: !!paddingEven }); return this; }; /*** * * @param {Rectangle}rect * @param {Object=}style */ PaperPrinter.prototype.rect = function (rect, style) { this.objects.push({ type: 'rect', rect: rect, style: style || {} }); }; /*** * * @param {HTMLCanvasElement|AElement |Image} image * @param {Rectangle}rect * @param {Object=}style */ PaperPrinter.prototype.image = function (image, rect, style) { this.objects.push({ type: 'image', rect: rect, style: style || {}, image: image }); return this; }; PaperPrinter.prototype.boundOf = function (objectData) { return this.measures[objectData.type](objectData); }; PaperPrinter.prototype.computeObjects = function () { var objects = this.objects.slice(); if (!objects[0] || objects[0].type !== 'sub_document') { objects.unshift({ type: 'sub_document', at: Vec2/* default.ZERO */.Z.ZERO, }) } this.subDocs = objects.reduce((ac, obj) => { switch (obj.type) { case 'sub_document': ac.push({ objects: [obj] }); break; default: ac[ac.length - 1].objects.push(obj); break; } return ac; }, []); this.subDocs.forEach((doc, i) => { doc.objects.forEach((o, i) => { o.idx = i; o.bound = this.boundOf(o); }); var newDocCmd = doc.objects.shift(); doc.objects.sort((a, b) => { return a.bound.y - b.bound.y; }); doc.opt = Object.assign((0,generator/* copyJSVariable */.Ew)(this.opt), newDocCmd.opt || {}); doc.objects.unshift(newDocCmd); doc.startPage = i > 0 ? this.subDocs[i - 1].startPage + this.subDocs[i - 1].pages.length : this.computedPages; if (this.opt.paddingEven && doc.startPage % 2 > 0) doc.startPage++; var pageContentHeight = 1123 - doc.opt.margin.top - doc.opt.margin.bottom; doc.pages = doc.objects.reduce((ac, cr) => { var page = ac[ac.length - 1]; if (cr.bound.height > pageContentHeight) { page.objects.push(cr); } else { if (cr.bound.y + cr.bound.height - page.y > pageContentHeight || cr.type === 'page_break') { page = { y: cr.bound.y, objects: [cr] }; ac.push(page); } else { page.objects.push(cr); } } return ac; }, [{ objects: [], y: 0 }]); doc.pages.forEach(page => page.objects.sort((a, b) => a.idx - b.idx)); this.computedPages = doc.startPage + doc.pages.length; }); }; PaperPrinter.prototype.getDoc = function () { if (this.docSync) return this.docSync; this.docSync = this.sync.then(() => { if (this.pdfDoc) return this.pdfDoc; var jsPDF = jspdf.jsPDF; this.pdfDoc = new jsPDF({ orientation: 'p', unit: 'px', format: 'a4', putOnlyUsedFonts: true, floatPrecision: 16, dpi: 300, hotfixes: ["px_scaling"] }); this.share.fonts.forEach(font => { this.pdfDoc.addFileToVFS(font.fileName, font.content); this.pdfDoc.addFont(font.fileName, font.name, font.style); }); return this.pdfDoc; }); this.sync = this.docSync; return this.docSync; }; PaperPrinter.prototype.flush = function () { this.sync = this.getDoc().then(pdfDoc => { this.computeObjects(); var subDocs = this.subDocs; this.subDocs = null;//reset var onProcess = this.opt.onProcess; var processInfo = this.processInfo; processInfo.pdf = { all: subDocs.reduce((ac, sD) => ac + sD.objects.length, 0), done: 0 }; processInfo.onProcess = () => { onProcess && onProcess(processInfo); }; processInfo.state = 'RENDER_PDF'; return subDocs.reduce((sync, doc, i) => { return sync.then(() => { var startPage = doc.startPage; while (pdfDoc.getNumberOfPages() <= startPage) { pdfDoc.addPage(); } return doc.pages.reduce((docSync, page, i) => { return docSync.then(() => { if (pdfDoc.getNumberOfPages() <= startPage + i) { pdfDoc.addPage(); } pdfDoc.setPage(startPage + i + 1); page.O = new Vec2/* default */.Z(this.opt.margin.left, this.opt.margin.top - page.y); return page.objects.reduce((pageSync, obj) => { return pageSync.then(() => { var type = obj.type; var res = this.pdfHandlers[type](page, pdfDoc, obj); processInfo.pdf.done++; if (res && res.then) { res.then(() => processInfo.onProcess()) } return res; }); }, Promise.resolve()).then(() => { pdfDoc.setTextColor(0, 0, 0); pdfDoc.setFontSize(14 * P2D); pdfDoc.setFont('arial', 'normal'); pdfDoc.text((i + 1) + '/' + doc.pages.length, 794 - 25, 1123 - 25, { align: 'right' }); if (typeof doc.opt.footer === 'string') { pdfDoc.text(doc.opt.footer, 25, 1123 - 25, { align: 'left' }); } }); }) }, Promise.resolve()) .then(() => { if (this.opt.lastPagePaddingEven) { while (pdfDoc.getNumberOfPages() % 2 > 0) { pdfDoc.addPage(); } } }) }) }, Promise.resolve()); }); return this.sync; }; PaperPrinter.prototype.exportAsPDF = function () { return this.flush().then(() => this.pdfDoc); }; PaperPrinter.prototype.pdfHandlers = { text: function (context, doc, data) { var fontFamily = data.style.fontFamily; var lineHeight = data.style.lineHeight || 1.2; var color = color2RGB255(data.style.color) || [0, 0, 0]; doc.setTextColor(color[0], color[1], color[2]); var fontSize = data.style.fontSize || 14; var textPos = data.pos.A().add(context.O); doc.setLineHeightFactor(lineHeight); doc.setFontSize(fontSize * P2D); doc.setFont(fontIdOf(fontFamily), data.style.fontStyle); var style = { baseline: 'top', maxWidth: data.pos.width }; if (data.style.align) { //todo: check align style.align = { start: 'left', end: 'right', center: 'center' }[data.style.align] || 'left'; } doc.text(data.text, textPos.x, textPos.y + fontSize * (lineHeight - 1) / 2, style); }, rect: function (context, doc, data) { var fillColor = null; var strokeColor = null; var strokeWidth = data.style.strokeWidth || 1; var rounded = data.style.rounded; if (typeof rounded === "number") rounded = [rounded, rounded]; if (data.style.fill) { fillColor = color2RGB255(data.style.fill); } if (data.style.stroke) { strokeColor = color2RGB255(data.style.stroke); } if (fillColor) doc.setFillColor(fillColor[0], fillColor[1], fillColor[2]); if (strokeColor) { doc.setLineWidth(strokeWidth); doc.setDrawColor(strokeColor[0], strokeColor[1], strokeColor[2]); } var flat = 'F'; if (strokeColor && fillColor) flat = 'FD'; else if (strokeColor) flat = 'S'; else if (fillColor) flat = 'F'; else return; var O = context.O; var A = data.rect.A().add(O); if (rounded) { doc.roundedRect(A.x, A.y, data.rect.width, data.rect.height, rounded[0], rounded[1], flat); } else { doc.rect(A.x, A.y, data.rect.width, data.rect.height, flat); } }, line: function (context, doc, data) { var fillColor = null; var strokeColor = null; var strokeWidth = data.style.strokeWidth || 1; if (data.style.stroke) { strokeColor = color2RGB255(data.style.stroke); } if (strokeColor) { doc.setLineWidth(strokeWidth); doc.setDrawColor(strokeColor[0], strokeColor[1], strokeColor[2]); } var flat = 'S'; var O = context.O; var A = data.start.add(O); var B = data.end.add(O); doc.line(A.x, A.y, B.x, B.y, flat); }, image: function (context, doc, data) { var handleImage = image => { if (!image) return; var rect = data.rect.clone(); rect.x += context.O.x; rect.y += context.O.y; doc.addImage(image, 'PNG', rect.x, rect.y, rect.width, rect.height) } if (data.image.then) { return data.image.then(handleImage).catch(err => { }); } else return handleImage(data.image); }, page_break: function (context, doc, data) { }, sub_document: function (context, doc, data) { } }; PaperPrinter.prototype.measures = { sub_document: data => { return new Rectangle/* default */.Z(0, 0, 0, 0); }, rect: data => { return data.rect; }, text: data => { return data.pos; }, image: data => { return data.rect; }, line: data => { return Rectangle/* default.boundingPoints */.Z.boundingPoints([data.start, data.end]); }, page_break: data => { return new Rectangle/* default */.Z(0, data.at.y, 0, 0); } }; /* harmony default export */ const Print_PaperPrinter = (PaperPrinter); // EXTERNAL MODULE: ./node_modules/absol/src/Network/FileSaver.js var FileSaver = __webpack_require__(5447); // EXTERNAL MODULE: ./node_modules/absol/src/Print/pdf.js var pdf = __webpack_require__(9673); ;// CONCATENATED MODULE: ./node_modules/absol/src/Print/printer.js var ShareSerializer = new Print_PrintSerializer(); /*** * * @param elt * @param fileName * @param {function(processInfo):void=} onProcess * @returns {Promise<*>} */ /** * @type {((elt:AElement, fileName: string, onProcess: function(processInfo):void) => Promise ) & ((elt:AElement, opt: object, onProcess: function(processInfo):void) => Promise) } */ function downloadAsPDF(docList, arg2, onProcess) { var opt = { fileName: 'exports.pdf.js' }; if (typeof arg2 === 'string') opt.fileName = arg2; else Object.assign(opt, arg2); var $ = Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$; if (!(docList instanceof Array)) docList = [docList]; docList = docList.map(doc => { if (typeof doc === "string") { return { elt: $(doc) } } else if ((0,Dom/* isDomNode */.mV)(doc)) { return { elt: $(doc) } } else if (typeof doc === "object" && doc) { if (typeof doc.elt === "string") doc.elt = $(doc.elt); if (doc.elt && (0,Dom/* isDomNode */.mV)(doc.elt)) return doc; } else return null; }).filter(it => !!it).map(doc => { var elt = docList[0]; if (elt.fmComponent) { if (!doc.opt) doc.opt = {}; if (!doc.opt.margin) { doc.opt.margin = { top: elt.fmComponent.style.paddingTop || 57, left: elt.fmComponent.style.paddingLeft || 57, bottom: elt.fmComponent.style.paddingBottom || 57, right: elt.fmComponent.style.paddingRight || 57 }; } } return doc; }); var serializer = ShareSerializer; opt.onProcess = (typeof onProcess === "function") ? onProcess : (function (){}); var printer = new Print_PaperPrinter(opt); return serializer.serialize(docList, printer, opt.onProcess) .then(printer => printer.exportAsPDF()) .then(doc => { (0,FileSaver.saveAs)(doc.output('blob'), opt.fileName); }); } /***/ }), /***/ 3224: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var _Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56); /********************************* * EXPRESSION */ var operatorOrder = { 'NOT': 4, '!': 4, '*': 5, '/': 5, 'MOD': 5, '%': 5, '+': 6, '-': 6, '<': 9, '>': 9, '<=': 9, '>=': 9, '==': 9, '===': 9, '!=': 9, 'AND': 14, '&&': 14, 'OR': 15, '||': 15, 'XOR': 15, } var elementRegexes = [ ['string', /("(?:[^"\\]|\\.)*?")|('(?:[^'\\]|\\.)*?')/], ['number', /(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)/], ['word', /[_a-zA-Z][_a-zA-Z0-9]*/], ['skip', /([\s\r\n]+)|(\/\/[^\n]*)|(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)/], ['tsymbol', /(\.\.\.)|(===)/], ['dsymbol', /\+\+|--|==|!=|<=|>=|\|\||&&/], ['symbol', /[^\s_a-zA-Z0-9]/], ]; var rules = []; rules.push({ target: 'null', elements: ['_null'], toAST: function (parsedNode) { return { type: 'NullLiteral', } } }); rules.push({ target: 'ident', elements: ['.word'], toAST: function (parsedNode) { return { type: 'Identifier', name: parsedNode.children[0].content } } }); rules.push({ target: 'args_list', elements: ['exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); }, toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode)]; } }); rules.push({ target: 'args_list', elements: ['args_list', '_,', 'exp'], longestOnly: true, ident: 'args_list_rec', toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat((0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])); } }); rules.push({ target: 'function_callee', elements: ['ident'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'function_callee', elements: ['mem_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }) rules.push({ target: 'function_call', elements: ['function_callee', '_(', 'args_list', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: parsedNode.children[2].rule.toASTChain(parsedNode.children[2]), callee: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } } }); rules.push({ target: 'function_call', elements: ['function_callee', '_(', '_)'], toAST: function (parsedNode) { return { type: 'CallExpression', arguments: [], callee: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) }; } }); rules.push({ target: 'new_expression', elements: ['_new', 'function_call'], toAST: function (parsedNode) { var callAst = (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) return { type: 'NewExpression', arguments: callAst.arguments, callee: callAst.callee } } }); rules.push({ target: 'exp', elements: ['new_expression'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['null'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['ident'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'number', elements: ['.number'], toAST: function (parsedNode) { return { type: 'NumericLiteral', value: parseFloat(parsedNode.children[0].content) } } }); rules.push({ target: 'string', elements: ['.string'], toAST: function (parsedNode) { var content = parsedNode.children[0].content; if (content[0] === "'") content = '"' + content.substring(1, content.length - 1).replace(/["]/g, '\\"') + '"'; return { type: 'StringLiteral', value: JSON.parse(content) } } }); rules.push({ target: 'boolean', elements: ['_true'], toAST: function (parsedNode) { return { type: 'BooleanLiteral', value: true }; } }); rules.push({ target: 'boolean', elements: ['_false'], toAST: function (parsedNode) { return { type: 'BooleanLiteral', value: false }; } }); rules.push({ target: 'exp', elements: ['number'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['string'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['boolean'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); ['+', '-', '*', '/', '%', '&&', '||', 'XOR', '==','===', '!=', '<', '>', '>=', '<='].forEach(function (op) { rules.push({ target: 'bin_op', elements: ['_' + op], toAST: function (parsedNode) { return { type: "BinaryOperator", content: op } } }); }); rules.push({ target: 'exp', elements: ['exp', 'bin_op', 'exp'], // longestOnly: true,//* error when parse return (...)... ident: 'bin_op_rec', toASTChain: function (parseNode) { var res = []; if (parseNode.children[0].rule === this) { res = res.concat(this.toASTChain(parseNode.children[0])); } else { res.push((0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[0])); } res.push(parseNode.children[1].children[0]); if (parseNode.children[2].rule === this) { res = res.concat(this.toASTChain(parseNode.children[2])); } else { res.push((0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[2])); } return res; }, toAST: function (parsedNode) { var chain = this.toASTChain(parsedNode); var stack = []; var item; var newNode; while (chain.length > 0) { item = chain.shift(); if (item.content in operatorOrder) { while (stack.length >= 3 && operatorOrder[stack[stack.length - 2].content] <= operatorOrder[item.content]) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = stack.pop(); newNode.left = stack.pop(); stack.push(newNode); } } stack.push(item); } while (stack.length >= 3) { newNode = { type: 'BinaryExpression' }; newNode.right = stack.pop(); newNode.operator = stack.pop(); newNode.left = stack.pop(); stack.push(newNode); } return stack.pop(); } }); rules.push({ target: 'condition_exp', elements: ['exp', '_?', 'exp', '_:', 'exp'], toAST: function (parsedNode) { return { type: 'ConditionalExpression', test: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), consequent: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]), alternate: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[4]) } } }); rules.push({ target: 'sequence_exp', elements: ['exp', '_,', 'exp'], toAST: function (parsedNode) { return { type: 'SequenceExpression', expressions: [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])] } } }); rules.push({ target: 'sequence_exp', elements: ['sequence_exp', '_,', 'exp'], toAST: function (parsedNode) { var ast = (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); ast.expressions.push((0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])); return ast; } }); rules.push({ target: 'exp', elements: ['condition_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'exp', elements: ['function_call'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'bracket_group', elements: ['_(', 'exp', '_)'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]); } }); rules.push({ target: 'exp', elements: ['bracket_group'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); // rules.push({ // target: 'exp', // elements: ['_(', 'exp', '_)'], // toAST: function (parsedNode) { // return parsedNodeToAST(parsedNode.children[1]); // } // }); ['+', '-', '!'].forEach(function (op) { ['number', 'bracket_group', 'ident', 'function_call', 'mem_exp', 'unary_exp'].forEach(function (arg) { rules.push({ target: 'unary_exp', elements: ['_' + op, arg], toAST: function (parsedNode) { return { type: 'UnaryExpression', argument: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), operator: { type: 'UnaryOperator', content: op } } } }); }); }); rules.push({ target: 'exp', elements: ['unary_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'mem_exp', elements: ['ident', '_.', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['ident', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['new_expression', '_.', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['new_expression', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['mem_exp', '_.', 'ident'], longestOnly: true, ident: 'mem_exp_ident_rev', toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['mem_exp', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['bracket_group', '_.', 'ident'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: false, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'mem_exp', elements: ['bracket_group', '_[', 'exp', '_]'], toAST: function (parsedNode) { return { type: "MemberExpression", computed: true, object: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), property: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'exp', elements: ['mem_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'object_exp', elements: ['_{', '_}'], toAST: function (parsedNode) { return { type: 'ObjectExpression', properties: [] } } }); rules.push({ target: 'object_exp', elements: ['_{', 'object_property_list', '_}'], toAST: function (parsedNode) { return { type: 'ObjectExpression', properties: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[1]) } } }); rules.push({ target: 'exp', elements: ['object_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'object_property', elements: ['ident', '_:', 'exp'], toAST: function (parsedNode) { return { type: 'ObjectProperty', key: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), value: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) }; } }); rules.push({ target: 'object_property', elements: ['string', '_:', 'exp'], toAST: function (parsedNode) { return { type: 'ObjectProperty', key: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), value: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) }; } }); rules.push({ target: 'object_property_list', elements: ['object_property'], toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'object_property_list', elements: ['object_property_list', '_,', 'object_property'], longestOnly: true, ident: 'object_property_list_rec', toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat([(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])]); } }); /**********************************************************************************************************************/ rules.push({ target: 'exp', elements: ['array_exp'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'array_exp', elements: ['_[', '_]'], toAST: function (parsedNode) { return { type: "ArrayExpression", elements: [] }; } }); rules.push({ target: 'array_exp', elements: ['_[', 'array_item_list', '_]'], toAST: function (parsedNode) { return { type: "ArrayExpression", elements: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[1]) }; } }); rules.push({ target: 'array_item_list', elements: ['exp'], toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'array_item_list', elements: ['array_item_list', '_,', 'exp'], longestOnly: true, ident: 'array_item_list_rec', toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat([(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])]); } }); /**********************************************************************************************************************/ /**************FOR QUICK PARSING***********************/ rules.push({ target: 'exp', elements: ['.constance'], toAST: function (parsedNode) { return parsedNode.children[0] }, toASTChain: function (parsedNode) { return [parsedNode.children[0]]; } }); /***********************************************************************************************************************/ rules.push({ target: 'generic_type', elements: ['ident'], toAST: function (parsedNode) { return { type: 'GenericType', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } } }); rules.push({ target: 'linked_type', elements: ['_linktype', 'exp'], toAST: function (parsedNode) { return { type: 'LinkedType', address: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) } } }); rules.push({ target: 'var_type', elements: ['generic_type'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } }); rules.push({ target: 'var_type', elements: ['linked_type'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } }); /* rules.push({ target: 'var_type', elements: ['ident', '<', 'var_type', '>'] }); rules.push({ target: 'var_type', elements: ['ident', '<', '.string', '>'] }); */ rules.push({ target: 'type_annotation', elements: ['_:', 'var_type'], toAST: function (parsedNode) { return { type: 'TypeAnnotation', typeAnnotation: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) } } }); /**********************************************************************************************************************/ /* @decrepted ast rules.push({ target: 'variable_declaration', elements: ['_var', 'ident', 'type_annotation', '_;'], toAST: function (parsedNode) { return { type: 'VariableDeclaration', id: parsedNodeToAST(parsedNode.children[1]), typeAnnotation: parsedNodeToAST(parsedNode.children[2]) } } }); rules.push({ target: 'variable_declaration', elements: ['_var', 'ident', '_;'], toAST: function (parsedNode) { return { type: 'VariableDeclaration', id: parsedNodeToAST(parsedNode.children[1]), } } }); rules.push({ target: 'variable_declaration', elements: ['_var', 'ident', '_=', 'exp', '_;'], toAST: function (parsedNode) { return { type: 'VariableDeclaration', id: parsedNodeToAST(parsedNode.children[1]), init: parsedNodeToAST(parsedNode.children[3]) } } }); rules.push({ target: 'variable_declaration', elements: ['_var', 'ident', 'type_annotation', '_=', 'exp', '_;'], toAST: function (parsedNode) { return { type: 'VariableDeclaration', id: parsedNodeToAST(parsedNode.children[1]), typeAnnotation: parsedNodeToAST(parsedNode.children[2]), init: parsedNodeToAST(parsedNode.children[4]), kind: 'var' } } }); */ rules.push({ target: 'variable_declarator', elements: ['ident', '_=', 'exp'], toAST: function (parsedNode) { return { type: 'VariableDeclarator', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), init: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) } } }); rules.push({ target: 'variable_declarator', elements: ['ident', 'type_annotation' ,'_=', 'exp'], toAST: function (parsedNode) { return { type: 'VariableDeclarator', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), typeAnnotation: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), init: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]) } } }); rules.push({ target: 'variable_declarator', elements: ['ident'], toAST: function (parsedNode) { return { type: 'VariableDeclarator', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), init: null } } }); rules.push({ target: 'variable_declarator', elements: ['ident', 'type_annotation'], toAST: function (parsedNode) { return { type: 'VariableDeclarator', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), typeAnnotation: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), init: null } } }); rules.push({ target: 'variable_declarator_sequence', elements: ['variable_declarator'], toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'variable_declarator_sequence', elements: ['variable_declarator_sequence', '_,', 'variable_declarator'], toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat([(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])]); } }); rules.push({ target: 'variable_declaration', elements: ['_var', 'variable_declarator_sequence', '_;'], toAST: function (parsedNode) { return { type: 'VariableDeclaration', declarations: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[1]), kind: 'var' } } }); //todo rules.push({ target: 'expression_statement', elements: ['function_call', '_;'], toAST: function (parsedNode) { return { type: 'ExpressionStatement', expression: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } } }); /**********************************************************************************************************************/ rules.push({ target: 'assign_expression', elements: ['ident', '_=', 'exp'], toAST: function (parseNode) { return { type: 'AssignmentExpression', left: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[0]), right: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[2]) } } }); rules.push({ target: 'assign_expression', elements: ['mem_exp', '_=', 'exp'], toAST: function (parseNode) { return { type: 'AssignmentExpression', left: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[0]), right: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parseNode.children[2]) } } }); rules.push({ target: 'expression_statement', elements: ['assign_expression', '_;'], toAST: function (parsedNode) { return { type: 'ExpressionStatement', expression: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } } }); /**********************************************************************************************************************/ rules.push({ target: 'if_statement_1', elements: ['_if', '_(', 'exp', '_)', 'statement'], toAST: function (parsedNode) { return { type: 'IfStatement', test: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]), consequent: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[4]) } } }); rules.push({ target: 'if_statement_2', elements: ['if_statement_1', '_else', 'statement'], toAST: function (parsedNode) { var ast = (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); ast.alternate = (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]); return ast; } }); rules.push({ target: 'statement', elements: ['if_statement_1'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['if_statement_2'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'for_count_statement', elements: ['_for', 'ident', '_from', 'exp', '_to', 'exp', 'block_statement'], toAST: function (parsedNode) { return { type: 'ForCountStatement', for: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), from: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]), to: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[5]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[6]) }; } }); rules.push({ target: 'for_of_statement', elements: ['_for', 'ident', '_of', 'exp', 'block_statement'], toAST: function (parsedNode) { return { type: 'ForOfStatement', for: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), of: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[4]) }; } }); rules.push({ target: 'for_in_statement', elements: ['_for', 'ident', '_in', 'exp', 'block_statement'], toAST: function (parsedNode) { return { type: 'ForInStatement', for: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), in: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[4]) }; } }); rules.push({ target: 'iterable_range', elements: ['iterable_range_limit', '_...', 'iterable_range_limit'] }); rules.push({ target: 'iterable_range_limit', elements: ['.number'] }); rules.push({ target: 'iterable_range_limit', elements: ['ident'] }); /**************************************************************************************/ rules.push({ target: 'for_statement', elements: ['_for', 'bracket_group', 'statement'], }) /**********************************************************************************************************************/ rules.push({ target: 'while_statement', elements: ['_while', 'bracket_group', 'statement'], toAST: function (parsedNode) { return { type: 'WhileStatement', test: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2]) }; } }); rules.push({ target: 'statement', elements: ['while_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'do_while_statement', elements: ['_do', 'statement', '_while', 'bracket_group', '_;'], toAST: function (parsedNode) { return { type: 'DoWhileStatement', test: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) }; } }); rules.push({ target: 'statement', elements: ['do_while_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'break_statement', elements: ['_break', '_;'], toAST: function (parsedNode) { return { type: 'BreakStatement' }; } }); rules.push({ target: 'statement', elements: ['break_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'block_statement', elements: ['_{', '_}'], toAST: function (parsedNode) { return { type: 'BlockStatement', body: [] } } }); rules.push({ target: 'block_statement', elements: ['_{', 'statement_arr', '_}'], toAST: function (parsedNode) { return { type: 'BlockStatement', body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[1]) }; } }); rules.push({ target: 'statement', elements: ['variable_declaration'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['block_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['expression_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['for_count_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['for_in_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['for_of_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement', elements: ['assign_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'statement_arr', elements: ['statement'], toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0])]; } }); rules.push({ target: 'statement_arr', elements: ['statement_arr', 'statement'], longestOnly: true, toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat([(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1])]); } }); /**********************************************************************************************************************/ rules.push({ target: 'function_arguments_declaration', elements: ['_(', '_)'], toASTChain: function (parsedNode) { return []; } }); rules.push({ target: 'function_arguments_declaration', elements: ['_(', 'argument_declaration_list', '_)'], toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[1]); } }); rules.push({ target: 'argument_declaration', elements: ['ident', 'type_annotation'], toAST: function (parsedNode) { return { type: "ArgumentDeclaration", id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]), typeAnnotation: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) } } }); rules.push({ target: 'argument_declaration', elements: ['ident'], toAST: function (parsedNode) { return { type: "ArgumentDeclaration", id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]) } } }); rules.push({ target: 'argument_declaration_list', elements: ['argument_declaration'], toASTChain: function (parsedNode) { return [(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0])] } }); rules.push({ target: 'argument_declaration_list', elements: ['argument_declaration_list', '_,', 'argument_declaration'], toASTChain: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]).concat([(0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[2])]) } }); /**********************************************************************************************************************/ rules.push({ target: 'return_statement', elements: ['_return', 'exp', '_;'], toAST: function (parsedNode) { return { type: "ReturnStatement", argument: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]) }; } }); rules.push({ target: 'return_statement', elements: ['_return', '_;'], toAST: function (parsedNode) { return { type: "ReturnStatement" }; } }); rules.push({ target: 'statement', elements: ['return_statement'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); /**********************************************************************************************************************/ rules.push({ target: 'function_declare', elements: ['_function', 'ident', 'function_arguments_declaration', 'type_annotation', 'block_statement'], toAST: function (parsedNode) { return { type: 'FunctionDeclaration', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), params: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[2]), returnType: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[4]) }; } }); rules.push({ target: 'function_declare', elements: ['_function', 'ident', 'function_arguments_declaration', 'block_statement'], toAST: function (parsedNode) { return { type: 'FunctionDeclaration', id: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[1]), params: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[2]), body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[3]) }; } }); rules.push({ target: 'statement', elements: ['function_declare'], toAST: function (parsedNode) { return (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToAST */ .Hg)(parsedNode.children[0]); } }); rules.push({ target: 'program', elements: ['statement_arr'], toAST: function (parsedNode) { return { type: "Program", body: (0,_Pharse_DPParseInstance__WEBPACK_IMPORTED_MODULE_0__/* .parsedNodeToASTChain */ .xI)(parsedNode.children[0]) } } }); /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({ elementRegexes: elementRegexes, rules: rules, operatorOrder: operatorOrder }); /***/ }), /***/ 6382: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "wrapToLines": () => (/* binding */ wrapToLines), /* harmony export */ "nonAccentVietnamese": () => (/* binding */ nonAccentVietnamese), /* harmony export */ "pascalCaseToCamelCase": () => (/* binding */ pascalCaseToCamelCase), /* harmony export */ "kebabCaseToCamelCase": () => (/* binding */ kebabCaseToCamelCase), /* harmony export */ "underScoreToCamelCase": () => (/* binding */ underScoreToCamelCase), /* harmony export */ "camelCaseToPascalCase": () => (/* binding */ camelCaseToPascalCase), /* harmony export */ "underScoreToPascalCase": () => (/* binding */ underScoreToPascalCase), /* harmony export */ "kebabCaseToPascalCase": () => (/* binding */ kebabCaseToPascalCase), /* harmony export */ "pascalCaseToKebabCase": () => (/* binding */ pascalCaseToKebabCase), /* harmony export */ "camelCaseToKebabCase": () => (/* binding */ camelCaseToKebabCase), /* harmony export */ "underScoreToKebabCase": () => (/* binding */ underScoreToKebabCase), /* harmony export */ "pascalCaseToUnderScore": () => (/* binding */ pascalCaseToUnderScore), /* harmony export */ "pascalCaseToUpperUnderScore": () => (/* binding */ pascalCaseToUpperUnderScore), /* harmony export */ "camelCaseToUnderScore": () => (/* binding */ camelCaseToUnderScore), /* harmony export */ "camelCaseToUpperUnderScore": () => (/* binding */ camelCaseToUpperUnderScore), /* harmony export */ "kebabCaseToUnderScore": () => (/* binding */ kebabCaseToUnderScore), /* harmony export */ "kebabCaseToUpperUnderScore": () => (/* binding */ kebabCaseToUpperUnderScore), /* harmony export */ "normalizeIdent": () => (/* binding */ normalizeIdent), /* harmony export */ "breakTextToLineByLength": () => (/* binding */ breakTextToLineByLength) /* harmony export */ }); /** * * @param {String} s * @param {Number} maxLength */ function wrapToLines(s, maxLength) { var res = []; var currentWord = ''; var currentLine = ''; for (var i = 0; i < s.length; ++i) { if (s[i].match(/\s/)) { if (currentWord.length + currentLine.length >= maxLength) { if (currentLine.length > 0) { res.push(currentLine.trim()); currentLine = ''; currentWord = currentWord.trimLeft() + s[i]; } else { currentLine = currentLine + currentWord; res.push(currentLine.trim()); currentLine = ''; currentWord = ''; } } else { currentLine = currentLine + currentWord; currentWord = s[i]; } } else { currentWord = currentWord + s[i]; } } currentLine = (currentLine + currentWord).trim(); if (currentLine.length > 0) res.push(currentLine); return res; } /** * * @param {String} s * @returns {String} */ function nonAccentVietnamese(s) { return s.replace(/à|á|ạ|ả|ã|â|ầ|ấ|ậ|ẩ|ẫ|ă|ằ|ắ|ặ|ẳ|ẵ/g, "a") .replace(/À|Á|Ạ|Ả|Ã|Â|Ầ|Ấ|Ậ|Ẩ|Ẫ|Ă|Ằ|Ắ|Ặ|Ẳ|Ẵ/g, "A") .replace(/è|é|ẹ|ẻ|ẽ|ê|ề|ế|ệ|ể|ễ/g, "e") .replace(/È|É|Ẹ|Ẻ|Ẽ|Ê|Ề|Ế|Ệ|Ể|Ễ/g, "E") .replace(/ì|í|ị|ỉ|ĩ/g, "i") .replace(/Ì|Í|Ị|Ỉ|Ĩ/g, "I") .replace(/ò|ó|ọ|ỏ|õ|ô|ồ|ố|ộ|ổ|ỗ|ơ|ờ|ớ|ợ|ở|ỡ/g, "o") .replace(/Ò|Ó|Ọ|Ỏ|Õ|Ô|Ồ|Ố|Ộ|Ổ|Ỗ|Ơ|Ờ|Ớ|Ợ|Ở|Ỡ/g, "O") .replace(/ù|ú|ụ|ủ|ũ|ư|ừ|ứ|ự|ử|ữ/g, "u") .replace(/Ù|Ú|Ụ|Ủ|Ũ|Ư|Ừ|Ứ|Ự|Ử|Ữ/g, "U") .replace(/ỳ|ý|ỵ|ỷ|ỹ/g, "y") .replace(/Ỳ|Ý|Ỵ|Ỷ|Ỹ/g, "Y") .replace(/đ/g, "d") .replace(/Đ/g, "D") .replace(/\u0300|\u0301|\u0303|\u0309|\u0323/g, "") .replace(/\u02C6|\u0306|\u031B/g, ""); } /** * * @param {String} s * @returns {String} */ function pascalCaseToCamelCase(s) { return s.substr(0, 1).toLowerCase() + s.substr(1); } /** * * @param {String} s * @returns {String} */ function kebabCaseToCamelCase(s) { return s.replace(/-+([^-])/g, function (full, c) { return c.toUpperCase(); }); } /** * * @param {String} s * @returns {String} */ function underScoreToCamelCase(s) { return s.replace(/(_+)?([^_]+)/g, function (full, underscore, word) { if (underscore) { if (word) { return word.substr(0, 1).toUpperCase() + word.substr(1).toLowerCase(); } else return ''; } else { return word.toLowerCase(); } }); } /** * * @param {String} s * @returns {String} */ function camelCaseToPascalCase(s) { return s.substr(0, 1).toUpperCase() + s.substr(1); } /** * * @param {String} s * @returns {String} */ function underScoreToPascalCase(s) { return s.replace(/(_+|^)?([^_]+)/g, function (full, underscore, word) { return word.substr(0, 1).toUpperCase() + word.substr(1).toLowerCase(); }); } /** * * @param {String} s * @returns {String} */ function kebabCaseToPascalCase(s) { return s.replace(/(-+|^)([^-])/g, function (full, u, c) { return c.toUpperCase(); }); } /** * * @param {String} s * @returns {String} */ function pascalCaseToKebabCase(s) { return s.replace(/[A-Z][^A-Z]*/g, function (full, index) { if (index == 0) return full.toLowerCase(); return '-' + full.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function camelCaseToKebabCase(s) { return s.replace(/(^|[A-Z])[^A-Z]*/g, function (full, index) { if (index == 0) return full.toLowerCase(); return '-' + full.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function underScoreToKebabCase(s) { return s.replace(/(^|_+)([^_]+)/g, function (full, score, word, index) { if (index == 0) return word.toLowerCase(); return '-' + word.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function pascalCaseToUnderScore(s) { return s.replace(/[A-Z][^A-Z]*/g, function (full, index) { if (index == 0) return full.toLowerCase(); return '_' + full.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function pascalCaseToUpperUnderScore(s) { return s.replace(/[A-Z][^A-Z]*/g, function (full, index) { if (index == 0) return full.toUpperCase(); return '_' + full.toUpperCase() }); } /** * * @param {String} s * @returns {String} */ function camelCaseToUnderScore(s) { return s.replace(/(^|[A-Z])[^A-Z]*/g, function (full, index) { if (index == 0) return full.toLowerCase(); return '_' + full.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function camelCaseToUpperUnderScore(s) { return s.replace(/(^|[A-Z])[^A-Z]*/g, function (full, index) { if (index == 0) return full.toUpperCase(); return '_' + full.toUpperCase() }); } /** * * @param {String} s * @returns {String} */ function kebabCaseToUnderScore(s) { return s.replace(/(-+|^)([^-]+)/g, function (full, u, word, index) { if (index == 0) return word.toLowerCase(); return '_' + word.toLowerCase() }); } /** * * @param {String} s * @returns {String} */ function kebabCaseToUpperUnderScore(s) { return s.replace(/(-+|^)([^-]+)/g, function (full, u, word, index) { if (index == 0) return word.toUpperCase(); return '_' + word.toUpperCase() }); } /*** * * @param {String} text */ function normalizeIdent(text, opt) { var spaces = '_'; if (opt && ('spaces' in opt)) { spaces = opt.spaces || ''; } var symbols = '_'; if (opt && ('symbols' in opt)) { symbols = opt.symbols || ''; } var startsWithDigit = false; if (opt && ('startsWithDigit' in opt)) { startsWithDigit = opt.startsWithDigit || false; } var res = nonAccentVietnamese(text); if (typeof spaces === "string") { res = res.replace(/\s+/g, spaces); } if (typeof symbols === 'string') { if (spaces === '_') res = res.replace(/[^a-zA-Z0-9_$]+/g, symbols); else if (spaces === '-') { res = res.replace(/[^a-zA-Z0-9_$\-]+/g, symbols); } } if (spaces) { res = res.replace(new RegExp(`([${spaces}]+)`, 'g'), spaces); } if (symbols && symbols !== spaces) { res = res.replace(new RegExp(`([${symbols}]+)`, 'g'), spaces); } if (spaces) { res = res.replace(new RegExp(`([${spaces}]+$)|(^[${spaces}]+)`, 'g'), ''); } if (symbols && symbols !== spaces) { res = res.replace(new RegExp(`([${symbols}]+$)|(^[${symbols}]+$)`, 'g'), ''); } if (!startsWithDigit && res.match(/^[0-9]/)) { res = '$' + res; } return res; } function breakTextToLineByLength(text, limitLength) { limitLength = limitLength || 256; var lines = text.split(/\n/); var newLines = []; var breakLine = line => { var testLine = nonAccentVietnamese(line).toLowerCase(); var wordRgx = /(\(?(\d+([.]\d*)?([eE][+-]?\d+)?|[.]\d+([eE][+-]?\d+)?)\)?)|([()_a-z0-9,.]+)|([^\sa-z0-9,._()])/g; var poss = []; var matched = wordRgx.exec(testLine); while (matched) { poss.push(matched.index); matched = wordRgx.exec(testLine); } if (poss[0] !== 0) poss.unshift(0); poss.push(testLine.length); poss.push(testLine.length); var start = poss[0] || 0; var end, pend = start; var newLine; var chars; for (var i = 1; i < poss.length; ++i) { end = poss[i]; if (end - start > limitLength || i + 1 === poss.length) { newLine = line.substring(start, pend).trimEnd(); if (newLine.length > limitLength) { chars = newLine.split(''); while (chars.length > 0) { newLine = chars.splice(0, limitLength).join(''); newLines.push(newLine); } } else if (newLine.length > 0) { newLines.push(newLine); } start = pend; } pend = end; } }; lines.forEach(line => breakLine(line)); return newLines.join('\n'); } // window.t = `Sử dụng công thức tính: (Luong_Gio OT150 0.5) + (Luong_Gio OT200 1.0) + (Luong_Gio OT210 1.1) + (Luong_Gio OT270 1.7) + (Luong_Gio OT300 2.0)`; // console.log(breakTextToLineByLength(t, 50)) String.nonAccentVietnamese = nonAccentVietnamese; String.prototype.nonAccentVietnamese = function () { return String.nonAccentVietnamese(this); }; /***/ }), /***/ 1334: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "identCharacters": () => (/* binding */ identCharacters), /* harmony export */ "randomIdent": () => (/* binding */ randomIdent), /* harmony export */ "parallelMatch": () => (/* binding */ parallelMatch), /* harmony export */ "ipsumLoremWord": () => (/* binding */ ipsumLoremWord), /* harmony export */ "randomWord": () => (/* binding */ randomWord), /* harmony export */ "randomPhrase": () => (/* binding */ randomPhrase), /* harmony export */ "randomSentence": () => (/* binding */ randomSentence), /* harmony export */ "randomParagraph": () => (/* binding */ randomParagraph) /* harmony export */ }); /* harmony import */ var _Math_random__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7848); var identCharacters = function () { var chars = 'qwertyuiopasdfghjklzxcvbnm'; chars = chars + chars.toUpperCase(); var num = '0123456789'; var spect = '_'; return (chars + spect + num).split(''); }(); function randomIdent(length) { if (!(length > 0)) length = 4; var factor = identCharacters; return [factor[(Math.random() * (factor.length - 10)) >> 0]].concat(Array(length - 1).fill('').map(function () { return factor[(Math.random() * factor.length) >> 0]; })).join(''); } function parallelMatch(a, b) { var l = Math.min(a.length, b.length); var res = 0; for (var i = 0; i < l; ++i) { if (a[i] == b[i]) ++res; } return res; } var ipsumLoremWord = ['lorem', 'ipsum', 'dolor', 'sit', 'amet', 'consectetur', 'adipiscing', 'elit', 'sed', 'do', 'eiusmod', 'tempor', 'incididunt', 'ut', 'labore', 'et', 'dolore', 'magna', 'aliqua', 'enim', 'ad', 'minim', 'veniam', 'quis', 'nostrud', 'exercitation', 'ullamco', 'laboris', 'nisi', 'aliquip', 'ex', 'ea', 'commodo', 'consequat', 'duis', 'aute', 'irure', 'in', 'reprehenderit', 'voluptate', 'velit', 'esse', 'cillum', 'eu', 'fugiat', 'nulla', 'pariatur', 'excepteur', 'sint', 'occaecat', 'cupidatat', 'non', 'proident', 'sunt', 'culpa', 'qui', 'officia', 'deserunt', 'mollit', 'anim', 'id', 'est', 'laborum', 'perspiciatis', 'unde', 'omnis', 'iste', 'natus', 'error', 'voluptatem', 'accusantium', 'doloremque', 'laudantium', 'totam', 'rem', 'aperiam', 'eaque', 'ipsa', 'quae', 'ab', 'illo', 'inventore', 'veritatis', 'quasi', 'architecto', 'beatae', 'vitae', 'dicta', 'explicabo', 'nemo', 'ipsam', 'quia', 'voluptas', 'aspernatur', 'aut', 'odit', 'fugit', 'consequuntur', 'magni', 'dolores', 'eos', 'ratione', 'sequi', 'nesciunt', 'neque', 'porro', 'quisquam', 'dolorem', 'adipisci', 'numquam', 'eius', 'modi', 'tempora', 'incidunt', 'magnam', 'aliquam', 'quaerat', 'minima', 'nostrum', 'exercitationem', 'ullam', 'corporis', 'suscipit', 'laboriosam', 'aliquid', 'commodi', 'consequatur', 'autem', 'vel', 'eum', 'iure', 'quam', 'nihil', 'molestiae', 'illum', 'quo', 'at', 'vero', 'accusamus', 'iusto', 'odio', 'dignissimos', 'ducimus', 'blanditiis', 'praesentium', 'voluptatum', 'deleniti', 'atque', 'corrupti', 'quos', 'quas', 'molestias', 'excepturi', 'occaecati', 'cupiditate', 'provident', 'similique', 'mollitia', 'animi', 'dolorum', 'fuga', 'harum', 'quidem', 'rerum', 'facilis', 'expedita', 'distinctio', 'nam', 'libero', 'tempore', 'sum', 'soluta', 'nobis', 'eligendi', 'optio', 'cumque', 'impedit', 'minus', 'quod', 'maxime', 'placeat', 'facere', 'possimus', 'assumenda', 'repellendus', 'temporibus', 'quibusdam', 'officiis', 'debitis', 'necessitatibus', 'saepe', 'eveniet', 'voluptates', 'repudiandae', 'recusandae', 'itaque', 'earum', 'hic', 'tenetur', 'a', 'sapiente', 'delectus', 'reiciendis', 'voluptatibus', 'maiores', 'alias', 'perferendis', 'doloribus', 'asperiores', 'repellat', 'integer', 'nec', 'praesent', 'cursus', 'ante', 'dapibus', 'diam', 'sem', 'nibh', 'elementum', 'imperdiet', 'sagittis', 'mauris', 'fusce', 'tellus', 'augue', 'semper', 'porta', 'massa', 'vestibulum', 'lacinia', 'arcu', 'eget', 'class', 'aptent', 'taciti', 'sociosqu', 'litora', 'torquent', 'per', 'conubia', 'nostra', 'inceptos', 'himenaeos', 'curabitur', 'sodales', 'ligula', 'dignissim', 'nunc', 'tortor', 'pellentesque', 'aenean', 'scelerisque', 'maecenas', 'mattis', 'convallis', 'tristique', 'proin', 'egestas', 'porttitor', 'morbi', 'lectus', 'risus', 'iaculis', 'luctus', 'ac', 'turpis', 'aliquet', 'metus', 'ullamcorper', 'tincidunt', 'euismod', 'quisque', 'volutpat', 'condimentum', 'urna', 'facilisi', 'fringilla', 'suspendisse', 'potenti', 'feugiat', 'mi', 'sapien', 'etiam', 'ultrices', 'justo', 'lacus', 'pharetra', 'auctor', 'interdum', 'primis', 'faucibus', 'orci', 'posuere', 'cubilia', 'curae', 'molestie', 'dui', 'blandit', 'congue', 'pede', 'facilisis', 'laoreet', 'donec', 'viverra', 'malesuada', 'pulvinar', 'sollicitudin', 'cras', 'nisl', 'felis', 'venenatis', 'ultricies', 'accumsan', 'pretium', 'fermentum', 'nullam', 'purus', 'mollis', 'vivamus', 'consectetuer' ]; function randomWord() { var arr = ipsumLoremWord; var idx = (0,_Math_random__WEBPACK_IMPORTED_MODULE_0__/* .randomInt */ .Iy)(0, arr.length - 1); return arr[idx]; } /** * @param {number}arg1 * @param {number=}arg2 * @also * @param {number} arg1 * @returns {string} */ function randomPhrase(arg1, arg2) { var limitLength = arguments[arguments.length - 1]; var minLength = 1; if (arguments.length > 1) minLength = arguments[0]; if (!limitLength) limitLength = 50; var length = Math.ceil((Math.random() * (limitLength - minLength) + minLength) / 7); return new Array(length) .fill(null) .map(randomWord) .reduce(function (ac, cr) { if (ac.length + cr.length < limitLength || ac.length < minLength) { ac.parts.push(cr); } return ac; }, { parts: [], length: 0 }).parts .join(' '); } function randomSentence(limitLenght) { if (!limitLenght) limitLenght = 300; var length = Math.ceil(Math.random() * limitLenght / 70); var res = new Array(length) .fill(null) .map(function (value) { return randomPhrase(value); }) .reduce(function (ac, cr) { if (ac.length + cr.length < limitLenght) { ac.parts.push(cr); } return ac; }, { parts: [], length: 0 }).parts .join(', '); if (Math.random() < 0.03) { res = res.replace(/\,/i, ':'); } res = res.replace(/^./, function (x) { return x.toUpperCase(); }); res += '.'; return res; } function randomParagraph(limitLength) { if (!limitLength) limitLength = 1000; var length = Math.ceil(Math.random() * limitLength / 200); return new Array(length).fill(null) .map(function (value) { return randomSentence(value); }) .reduce(function (ac, cr) { if (ac.length + cr.length < limitLength) { ac.parts.push(cr); } return ac; }, { parts: [], length: 0 }).parts .join(' '); } /***/ }), /***/ 991: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "wordLike": () => (/* binding */ wordLike), /* harmony export */ "wordsMatch": () => (/* binding */ wordsMatch), /* harmony export */ "phraseMatch": () => (/* binding */ phraseMatch), /* harmony export */ "phraseLike": () => (/* binding */ phraseLike), /* harmony export */ "exportStringMatchingCode": () => (/* binding */ exportStringMatchingCode) /* harmony export */ }); /* harmony import */ var _Math_int__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7988); /** * * @param {String} a * @param {String} b */ function wordLike(a, b) { var m = a.length; var n = b.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) if (a.charAt(i) == b.charAt(j)) { if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + 1) Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + 1; } else Q[map(i + 1, j + 1)] = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); return Q[map(m, n)] / (0,_Math_int__WEBPACK_IMPORTED_MODULE_0__.harmonicMean)(m, n); } /** * * @param {Array<String>} sq1 * @param {Array<String>} sq2 * @param {number=} matchWordPow */ function wordsMatch(sq1, sq2, matchWordPow) { matchWordPow = matchWordPow === undefined ? 1 : matchWordPow; var m = sq1.length; var n = sq2.length; function map(i, j) { return i * (n + 1) + j; } var Q = Array((m + 1) * (n + 1)).fill(0); var e = 0.0; for (var i = 0; i < m; ++i) for (var j = 0; j < n; ++j) { e = Math.pow(wordLike(sq1[i], sq2[j]), matchWordPow); if (Q[map(i + 1, j + 1)]) { if (Q[map(i + 1, j + 1)] < Q[map(i, j)] + e) Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; } else Q[map(i + 1, j + 1)] = Q[map(i, j)] + e; e = Math.max(Q[map(i + 1, j)], Q[map(i, j + 1)]); if (e > Q[map(i + 1, j + 1)]) Q[map(i + 1, j + 1)] = e; } return Q[map(m, n)]; } function phraseMatch(a, b, matchWordPow) { matchWordPow = matchWordPow || 1; var spliter = /[\s,-\.+?\_]+/; var notEmp = function (e) { return e.length > 0; }; var sq1 = a.toLowerCase().split(spliter).filter(notEmp); var sq2 = b.toLowerCase().split(spliter).filter(notEmp); var wordsMatchScore = wordsMatch(sq1, sq2); var m = sq1.length; var n = sq2.length; return wordsMatchScore / Math.max((0,_Math_int__WEBPACK_IMPORTED_MODULE_0__.harmonicMean)(m, n), 1); }; function phraseLike(a, b, matchWordPow) { matchWordPow = matchWordPow || 1; var spliter = /[\s,-\.+?\_]+/; var notEmp = function (e) { return e.length > 0; }; var sq1 = a.toLowerCase().split(spliter).filter(notEmp); var sq2 = b.toLowerCase().split(spliter).filter(notEmp); var m = sq1.length; var n = sq2.length; var wordsMatchScore = wordsMatch(sq1, sq2); return wordsMatchScore / Math.max((0,_Math_int__WEBPACK_IMPORTED_MODULE_0__.harmonicMean)(m, n), 1); } function exportStringMatchingCode() { return [_Math_int__WEBPACK_IMPORTED_MODULE_0__.harmonicMean, phraseLike, phraseMatch, wordLike, wordsMatch].map(f => f + '').join('\n') +'\nvar _stringFormat = {harmonicMean, phraseLike, wordLike, wordsMatch};'; } /***/ }), /***/ 2973: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "$": () => (/* binding */ stringHashCode) /* harmony export */ }); function stringHashCode(st) { var hash = 0, i, chr; if (st.length === 0) return hash; for (i = 0; i < st.length; i++) { chr = st.charCodeAt(i); hash = ((hash << 5) - hash) + chr; hash |= 0; // Convert to 32bit integer } return hash; } function crc16($str) { var $CRC16_Lookup = [ 0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50A5, 0x60C6, 0x70E7, 0x8108, 0x9129, 0xA14A, 0xB16B, 0xC18C, 0xD1AD, 0xE1CE, 0xF1EF, 0x1231, 0x0210, 0x3273, 0x2252, 0x52B5, 0x4294, 0x72F7, 0x62D6, 0x9339, 0x8318, 0xB37B, 0xA35A, 0xD3BD, 0xC39C, 0xF3FF, 0xE3DE, 0x2462, 0x3443, 0x0420, 0x1401, 0x64E6, 0x74C7, 0x44A4, 0x5485, 0xA56A, 0xB54B, 0x8528, 0x9509, 0xE5EE, 0xF5CF, 0xC5AC, 0xD58D, 0x3653, 0x2672, 0x1611, 0x0630, 0x76D7, 0x66F6, 0x5695, 0x46B4, 0xB75B, 0xA77A, 0x9719, 0x8738, 0xF7DF, 0xE7FE, 0xD79D, 0xC7BC, 0x48C4, 0x58E5, 0x6886, 0x78A7, 0x0840, 0x1861, 0x2802, 0x3823, 0xC9CC, 0xD9ED, 0xE98E, 0xF9AF, 0x8948, 0x9969, 0xA90A, 0xB92B, 0x5AF5, 0x4AD4, 0x7AB7, 0x6A96, 0x1A71, 0x0A50, 0x3A33, 0x2A12, 0xDBFD, 0xCBDC, 0xFBBF, 0xEB9E, 0x9B79, 0x8B58, 0xBB3B, 0xAB1A, 0x6CA6, 0x7C87, 0x4CE4, 0x5CC5, 0x2C22, 0x3C03, 0x0C60, 0x1C41, 0xEDAE, 0xFD8F, 0xCDEC, 0xDDCD, 0xAD2A, 0xBD0B, 0x8D68, 0x9D49, 0x7E97, 0x6EB6, 0x5ED5, 0x4EF4, 0x3E13, 0x2E32, 0x1E51, 0x0E70, 0xFF9F, 0xEFBE, 0xDFDD, 0xCFFC, 0xBF1B, 0xAF3A, 0x9F59, 0x8F78, 0x9188, 0x81A9, 0xB1CA, 0xA1EB, 0xD10C, 0xC12D, 0xF14E, 0xE16F, 0x1080, 0x00A1, 0x30C2, 0x20E3, 0x5004, 0x4025, 0x7046, 0x6067, 0x83B9, 0x9398, 0xA3FB, 0xB3DA, 0xC33D, 0xD31C, 0xE37F, 0xF35E, 0x02B1, 0x1290, 0x22F3, 0x32D2, 0x4235, 0x5214, 0x6277, 0x7256, 0xB5EA, 0xA5CB, 0x95A8, 0x8589, 0xF56E, 0xE54F, 0xD52C, 0xC50D, 0x34E2, 0x24C3, 0x14A0, 0x0481, 0x7466, 0x6447, 0x5424, 0x4405, 0xA7DB, 0xB7FA, 0x8799, 0x97B8, 0xE75F, 0xF77E, 0xC71D, 0xD73C, 0x26D3, 0x36F2, 0x0691, 0x16B0, 0x6657, 0x7676, 0x4615, 0x5634, 0xD94C, 0xC96D, 0xF90E, 0xE92F, 0x99C8, 0x89E9, 0xB98A, 0xA9AB, 0x5844, 0x4865, 0x7806, 0x6827, 0x18C0, 0x08E1, 0x3882, 0x28A3, 0xCB7D, 0xDB5C, 0xEB3F, 0xFB1E, 0x8BF9, 0x9BD8, 0xABBB, 0xBB9A, 0x4A75, 0x5A54, 0x6A37, 0x7A16, 0x0AF1, 0x1AD0, 0x2AB3, 0x3A92, 0xFD2E, 0xED0F, 0xDD6C, 0xCD4D, 0xBDAA, 0xAD8B, 0x9DE8, 0x8DC9, 0x7C26, 0x6C07, 0x5C64, 0x4C45, 0x3CA2, 0x2C83, 0x1CE0, 0x0CC1, 0xEF1F, 0xFF3E, 0xCF5D, 0xDF7C, 0xAF9B, 0xBFBA, 0x8FD9, 0x9FF8, 0x6E17, 0x7E36, 0x4E55, 0x5E74, 0x2E93, 0x3EB2, 0x0ED1, 0x1EF0 ] var $crc16 = 0xFFFF; // the CRC var $len = $str.length; var $t; for (var $i = 0; $i < $len; $i++) { $t = ($crc16 >> 8) ^ $str.charCodeAt($i); // High byte Xor Message Byte to get index $crc16 = (($crc16 << 8) & 0xffff) ^ $CRC16_Lookup[$t]; // Update the CRC from table } $crc16 = $crc16.toString(16).toUpperCase(); return $crc16; } /***/ }), /***/ 7807: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "MILLIS_PER_DAY": () => (/* binding */ MILLIS_PER_DAY), /* harmony export */ "MILLIS_PER_HOUR": () => (/* binding */ MILLIS_PER_HOUR), /* harmony export */ "MILLIS_PER_MINUTE": () => (/* binding */ MILLIS_PER_MINUTE), /* harmony export */ "getDefaultFirstDayOfWeek": () => (/* binding */ getDefaultFirstDayOfWeek), /* harmony export */ "setDefaultFirstDayOfWeek": () => (/* binding */ setDefaultFirstDayOfWeek), /* harmony export */ "ddmmyyyy": () => (/* binding */ ddmmyyyy), /* harmony export */ "language2LocalDateFormat": () => (/* binding */ language2LocalDateFormat), /* harmony export */ "dateFormat2LocationList": () => (/* binding */ dateFormat2LocationList), /* harmony export */ "dateFormatList": () => (/* binding */ dateFormatList), /* harmony export */ "yyymmdd": () => (/* binding */ yyymmdd), /* harmony export */ "dayNames": () => (/* binding */ dayNames), /* harmony export */ "shortDayNames": () => (/* binding */ shortDayNames), /* harmony export */ "monthNames": () => (/* binding */ monthNames), /* harmony export */ "shortMonthNames": () => (/* binding */ shortMonthNames), /* harmony export */ "formatTokenRegex": () => (/* binding */ formatTokenRegex), /* harmony export */ "DATE_TIME_TOKEN_RGX": () => (/* binding */ DATE_TIME_TOKEN_RGX), /* harmony export */ "formatDateString": () => (/* binding */ formatDateString), /* harmony export */ "LOCAL_DATE_FORMAT": () => (/* binding */ LOCAL_DATE_FORMAT), /* harmony export */ "LOCAL_DATE_TIME_FORMAT": () => (/* binding */ LOCAL_DATE_TIME_FORMAT), /* harmony export */ "formartDateString": () => (/* binding */ formartDateString), /* harmony export */ "parseDateString": () => (/* binding */ parseDateString), /* harmony export */ "addDate": () => (/* binding */ addDate), /* harmony export */ "prevDate": () => (/* binding */ prevDate), /* harmony export */ "nextDate": () => (/* binding */ nextDate), /* harmony export */ "weekIndexOf": () => (/* binding */ weekIndexOf), /* harmony export */ "weekInYear": () => (/* binding */ weekInYear), /* harmony export */ "beginOfSecond": () => (/* binding */ beginOfSecond), /* harmony export */ "beginOfMinute": () => (/* binding */ beginOfMinute), /* harmony export */ "beginOfDay": () => (/* binding */ beginOfDay), /* harmony export */ "beginOfHour": () => (/* binding */ beginOfHour), /* harmony export */ "beginOfWeek": () => (/* binding */ beginOfWeek), /* harmony export */ "addWeek": () => (/* binding */ addWeek), /* harmony export */ "nextWeek": () => (/* binding */ nextWeek), /* harmony export */ "prevWeek": () => (/* binding */ prevWeek), /* harmony export */ "beginOfMonth": () => (/* binding */ beginOfMonth), /* harmony export */ "beginOfQuarter": () => (/* binding */ beginOfQuarter), /* harmony export */ "addQuarter": () => (/* binding */ addQuarter), /* harmony export */ "nextQuarter": () => (/* binding */ nextQuarter), /* harmony export */ "prevQuarter": () => (/* binding */ prevQuarter), /* harmony export */ "beginOfYear": () => (/* binding */ beginOfYear), /* harmony export */ "addYear": () => (/* binding */ addYear), /* harmony export */ "nextYear": () => (/* binding */ nextYear), /* harmony export */ "prevYear": () => (/* binding */ prevYear), /* harmony export */ "compareDate": () => (/* binding */ compareDate), /* harmony export */ "compareMonth": () => (/* binding */ compareMonth), /* harmony export */ "compareYear": () => (/* binding */ compareYear), /* harmony export */ "addMonth": () => (/* binding */ addMonth), /* harmony export */ "addMonthKeepDate": () => (/* binding */ addMonthKeepDate), /* harmony export */ "addMonthKeepDateTime": () => (/* binding */ addMonthKeepDateTime), /* harmony export */ "nextMonth": () => (/* binding */ nextMonth), /* harmony export */ "prevMonth": () => (/* binding */ prevMonth), /* harmony export */ "monthOfTwoDate": () => (/* binding */ monthOfTwoDate), /* harmony export */ "daysInMonth": () => (/* binding */ daysInMonth), /* harmony export */ "parseDateTime": () => (/* binding */ parseDateTime), /* harmony export */ "formatDateTime": () => (/* binding */ formatDateTime), /* harmony export */ "implicitDate": () => (/* binding */ implicitDate), /* harmony export */ "formatTimeRange24": () => (/* binding */ formatTimeRange24), /* harmony export */ "getTimeRangeFromStep": () => (/* binding */ getTimeRangeFromStep) /* harmony export */ }); /* harmony import */ var _String_stringFormat__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6382); /* harmony import */ var _Math_int__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7988); var MILLIS_PER_DAY = 24 * 3600000; var MILLIS_PER_HOUR = 3600000; var MILLIS_PER_MINUTE = 60000; var _default_first_day_of_week = 1; function getDefaultFirstDayOfWeek() { return _default_first_day_of_week; } function setDefaultFirstDayOfWeek(value) { if (isNaN(value) || !isFinite(value)) return; value = Math.floor(value) % 7; _default_first_day_of_week = value; } /** * * @param {Date} date * @returns {String} */ function ddmmyyyy(date) { return formatDateTime(date, 'dd/MM/yyyy'); } var language2LocalDateFormat = { "af-ZA": "yyyy/mm/dd", "am-ET": "d/m/yyyy", "ar-AE": "dd/mm/yyyy", "ar-BH": "dd/mm/yyyy", "ar-DZ": "dd-mm-yyyy", "ar-EG": "dd/mm/yyyy", "ar-IQ": "dd/mm/yyyy", "ar-JO": "dd/mm/yyyy", "ar-KW": "dd/mm/yyyy", "ar-LB": "dd/mm/yyyy", "ar-LY": "dd/mm/yyyy", "ar-MA": "dd-mm-yyyy", "ar-OM": "dd/mm/yyyy", "ar-QA": "dd/mm/yyyy", "ar-SA": "dd/mm/yy", "ar-SY": "dd/mm/yyyy", "ar-TN": "dd-mm-yyyy", "ar-YE": "dd/mm/yyyy", "arn-CL": "dd-mm-yyyy", "as-IN": "dd-mm-yyyy", "az-Cyrl-AZ": "dd.mm.yyyy", "az-Latn-AZ": "dd.mm.yyyy", "ba-RU": "dd.mm.yy", "be-BY": "dd.mm.yyyy", "bg-BG": "dd.m.yyyy", "bn-BD": "dd-mm-yy", "bn-IN": "dd-mm-yy", "bo-CN": "yyyy/m/d", "br-FR": "dd/mm/yyyy", "bs-Cyrl-BA": "d.m.yyyy", "bs-Latn-BA": "d.m.yyyy", "ca-ES": "dd/mm/yyyy", "co-FR": "dd/mm/yyyy", "cs-CZ": "d.m.yyyy", "cy-GB": "dd/mm/yyyy", "da-DK": "dd-mm-yyyy", "de-AT": "dd.mm.yyyy", "de-CH": "dd.mm.yyyy", "de-DE": "dd.mm.yyyy", "de-LI": "dd.mm.yyyy", "de-LU": "dd.mm.yyyy", "dsb-DE": "d. m. yyyy", "dv-MV": "dd/mm/yy", "el-GR": "d/m/yyyy", "en-029": "mm/dd/yyyy", "en-AU": "d/mm/yyyy", "en-BZ": "dd/mm/yyyy", "en-CA": "dd/mm/yyyy", "en-GB": "dd/mm/yyyy", "en-IE": "dd/mm/yyyy", "en-IN": "dd-mm-yyyy", "en-JM": "dd/mm/yyyy", "en-MY": "d/m/yyyy", "en-NZ": "d/mm/yyyy", "en-PH": "m/d/yyyy", "en-SG": "d/m/yyyy", "en-TT": "dd/mm/yyyy", "en-US": "m/d/yyyy", "en-ZA": "yyyy/mm/dd", "en-ZW": "m/d/yyyy", "es-AR": "dd/mm/yyyy", "es-BO": "dd/mm/yyyy", "es-CL": "dd-mm-yyyy", "es-CO": "dd/mm/yyyy", "es-CR": "dd/mm/yyyy", "es-DO": "dd/mm/yyyy", "es-EC": "dd/mm/yyyy", "es-ES": "dd/mm/yyyy", "es-GT": "dd/mm/yyyy", "es-HN": "dd/mm/yyyy", "es-MX": "dd/mm/yyyy", "es-NI": "dd/mm/yyyy", "es-PA": "mm/dd/yyyy", "es-PE": "dd/mm/yyyy", "es-PR": "dd/mm/yyyy", "es-PY": "dd/mm/yyyy", "es-SV": "dd/mm/yyyy", "es-US": "m/d/yyyy", "es-UY": "dd/mm/yyyy", "es-VE": "dd/mm/yyyy", "et-EE": "d.mm.yyyy", "eu-ES": "yyyy/mm/dd", "fa-IR": "mm/dd/yyyy", "fi-FI": "d.m.yyyy", "fil-PH": "m/d/yyyy", "fo-FO": "dd-mm-yyyy", "fr-BE": "d/mm/yyyy", "fr-CA": "yyyy-mm-dd", "fr-CH": "dd.mm.yyyy", "fr-FR": "dd/mm/yyyy", "fr-LU": "dd/mm/yyyy", "fr-MC": "dd/mm/yyyy", "fy-NL": "d-m-yyyy", "ga-IE": "dd/mm/yyyy", "gd-GB": "dd/mm/yyyy", "gl-ES": "dd/mm/yy", "gsw-FR": "dd/mm/yyyy", "gu-IN": "dd-mm-yy", "ha-Latn-NG": "d/m/yyyy", "he-IL": "dd/mm/yyyy", "hi-IN": "dd-mm-yyyy", "hr-BA": "d.m.yyyy.", "hr-HR": "d.m.yyyy", "hsb-DE": "d. m. yyyy", "hu-HU": "yyyy. mm. dd.", "hy-AM": "dd.mm.yyyy", "id-ID": "dd/mm/yyyy", "ig-NG": "d/m/yyyy", "ii-CN": "yyyy/m/d", "is-IS": "d.m.yyyy", "it-CH": "dd.mm.yyyy", "it-IT": "dd/mm/yyyy", "iu-Cans-CA": "d/m/yyyy", "iu-Latn-CA": "d/mm/yyyy", "ja-JP": "yyyy/mm/dd", "ka-GE": "dd.mm.yyyy", "kk-KZ": "dd.mm.yyyy", "kl-GL": "dd-mm-yyyy", "km-KH": "yyyy-mm-dd", "kn-IN": "dd-mm-yy", "ko-KR": "yyyy-mm-dd", "kok-IN": "dd-mm-yyyy", "ky-KG": "dd.mm.yy", "lb-LU": "dd/mm/yyyy", "lo-LA": "dd/mm/yyyy", "lt-LT": "yyyy.mm.dd", "lv-LV": "yyyy.mm.dd.", "mi-NZ": "dd/mm/yyyy", "mk-MK": "dd.mm.yyyy", "ml-IN": "dd-mm-yy", "mn-MN": "yy.mm.dd", "mn-Mong-CN": "yyyy/m/d", "moh-CA": "m/d/yyyy", "mr-IN": "dd-mm-yyyy", "ms-BN": "dd/mm/yyyy", "ms-MY": "dd/mm/yyyy", "mt-MT": "dd/mm/yyyy", "nb-NO": "dd.mm.yyyy", "ne-NP": "m/d/yyyy", "nl-BE": "d/mm/yyyy", "nl-NL": "d-m-yyyy", "nn-NO": "dd.mm.yyyy", "nso-ZA": "yyyy/mm/dd", "oc-FR": "dd/mm/yyyy", "or-IN": "dd-mm-yy", "pa-IN": "dd-mm-yy", "pl-PL": "yyyy-mm-dd", "prs-AF": "dd/mm/yy", "ps-AF": "dd/mm/yy", "pt-BR": "d/m/yyyy", "pt-PT": "dd-mm-yyyy", "qut-GT": "dd/mm/yyyy", "quz-BO": "dd/mm/yyyy", "quz-EC": "dd/mm/yyyy", "quz-PE": "dd/mm/yyyy", "rm-CH": "dd/mm/yyyy", "ro-RO": "dd.mm.yyyy", "ru-RU": "dd.mm.yyyy", "rw-RW": "m/d/yyyy", "sa-IN": "dd-mm-yyyy", "sah-RU": "mm.dd.yyyy", "se-FI": "d.m.yyyy", "se-NO": "dd.mm.yyyy", "se-SE": "yyyy-mm-dd", "si-LK": "yyyy-mm-dd", "sk-SK": "d. m. yyyy", "sl-SI": "d.m.yyyy", "sma-NO": "dd.mm.yyyy", "sma-SE": "yyyy-mm-dd", "smj-NO": "dd.mm.yyyy", "smj-SE": "yyyy-mm-dd", "smn-FI": "d.m.yyyy", "sms-FI": "d.m.yyyy", "sq-AL": "yyyy-mm-dd", "sr-Cyrl-BA": "d.m.yyyy", "sr-Cyrl-CS": "d.m.yyyy", "sr-Cyrl-ME": "d.m.yyyy", "sr-Cyrl-RS": "d.m.yyyy", "sr-Latn-BA": "d.m.yyyy", "sr-Latn-CS": "d.m.yyyy", "sr-Latn-ME": "d.m.yyyy", "sr-Latn-RS": "d.m.yyyy", "sv-FI": "d.m.yyyy", "sv-SE": "yyyy-mm-dd", "sw-KE": "m/d/yyyy", "syr-SY": "dd/mm/yyyy", "ta-IN": "dd-mm-yyyy", "te-IN": "dd-mm-yy", "tg-Cyrl-TJ": "dd.mm.yy", "th-TH": "d/m/yyyy", "tk-TM": "dd.mm.yy", "tn-ZA": "yyyy/mm/dd", "tr-TR": "dd.mm.yyyy", "tt-RU": "dd.mm.yyyy", "tzm-Latn-DZ": "dd-mm-yyyy", "ug-CN": "yyyy-m-d", "uk-UA": "dd.mm.yyyy", "ur-PK": "dd/mm/yyyy", "uz-Cyrl-UZ": "dd.mm.yyyy", "uz-Latn-UZ": "dd/mm yyyy", "vi-VN": "dd/mm/yyyy", "wo-SN": "dd/mm/yyyy", "xh-ZA": "yyyy/mm/dd", "yo-NG": "d/m/yyyy", "zh-CN": "yyyy/m/d", "zh-HK": "d/m/yyyy", "zh-MO": "d/m/yyyy", "zh-SG": "d/m/yyyy", "zh-TW": "yyyy/m/d", "zu-ZA": "yyyy/mm/dd", }; var dateFormat2LocationList = Object.keys(language2LocalDateFormat).reduce(function (ac, cr) { ac[language2LocalDateFormat[cr]] = ac[language2LocalDateFormat[cr]] || []; ac[language2LocalDateFormat[cr]].push(cr); return ac; }, {}); var dateFormatList = Object.keys(dateFormat2LocationList); /** * * @param {Date} date * @returns {String} */ function yyymmdd(date) { return formatDateTime(date, 'yyyy/MM/dd'); } var dayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']; var shortDayNames = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']; var monthNames = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" ]; var shortMonthNames = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]; var formatTokenRegex = /([,.\-\/])|([a-zA-Z0-9]+)/g;//more var DATE_TIME_TOKEN_RGX = /([^\s.\/:\-,]+)|([.\/:\-,]+)/i; /** * * @param {Date} date * @param {String=} format * @returns {String} */ function formatDateString(date, format) { format = format || 'dd/mm/yyyy'; var dt = date.getDate(); var day = date.getDay(); var month = date.getMonth(); var year = date.getFullYear() return format.replace(formatTokenRegex, function (x) { switch (x) { case "dddd": return dayNames[day]; case "ddd": return shortDayNames[day]; case "dd": return dt < 10 ? '0' + dt : '' + dt; case "d": return '' + dt; case "mmmm": return monthNames[month]; case "mmm": return shortMonthNames[month]; case "mm": return (month + 1) < 10 ? '0' + (month + 1) : '' + (month + 1); case "m": return '' + (month + 1); case 'yy': return (year + '').match(/..$/)[0]; case 'yyyy': return year + ''; default: return x; } }); } var LOCAL_DATE_FORMAT = (function () { var d = new Date(2021, 4, 4); var s = d.toLocaleDateString(); var fm = s.replace(new RegExp(DATE_TIME_TOKEN_RGX.source, 'g'), function (token) { switch (token) { case '2021': return 'yyyy'; case '5': return 'M'; case '05': return 'MM'; case '4': return 'd'; case '04': return 'dd'; default: return token; } }); return fm; })(); var LOCAL_DATE_TIME_FORMAT = (function () { var d = new Date(2021, 4, 4, 6, 7, 3); var s = d.toLocaleString(); var fm = s.replace(new RegExp(DATE_TIME_TOKEN_RGX.source, 'g'), function (token) { switch (token) { case '2021': return 'yyyy'; case '5': return 'M'; case '05': return 'MM'; case '4': return 'd'; case '04': return 'dd'; case '06': if (new Date(2021, 4, 4, 18, 7, 3).toLocaleString().indexOf(18) >= 0) return 'HH'; return 'hh'; case '6': return 'h'; case '07': return 'mm'; case '7': return 'm'; case '03': return 'ss'; case '3': return 's'; case 'AM': return 'a' default: return token; } }); return fm; })(); function formartDateString() { window.ALogger.warn("spelled incorrectly: formartDateString"); return formatDateString.apply(null, arguments); } /** * * @param {String} text * @param {String} format * @returns {Date} */ function parseDateString(text, format) { text = (0,_String_stringFormat__WEBPACK_IMPORTED_MODULE_0__.nonAccentVietnamese)(text).toLowerCase(); format = (0,_String_stringFormat__WEBPACK_IMPORTED_MODULE_0__.nonAccentVietnamese)(format).toLowerCase(); var textTokens = text.match(formatTokenRegex) || []; var formatTokens = format.match(formatTokenRegex) || []; var year = new Date().getFullYear(); var month = 0; var day = 1; var n = Math.min(textTokens.length, formatTokens.length); var textToken; var formatToken; for (var i = 0; i < n; ++i) { textToken = textTokens[i]; formatToken = formatTokens[i]; switch (formatToken) { case "dd": day = parseInt(textToken); break; case "d": day = parseInt(textToken); break; case "mmmm": month = monthNames.indexOf(textToken.substr(0, 1).toUpperCase() + textToken.substr(1).toLowerCase()); break; case "mmm": month = shortMonthNames.indexOf(textToken.substr(0, 1).toUpperCase() + textToken.substr(1).toLowerCase()); break; case "mm": case 'MM': month = parseInt(textToken) - 1; break; case "m": case 'M': month = parseInt(textToken) - 1; break; case 'yy': year = Math.floor((new Date().getFullYear()) / 100) * 100 + parseInt(textToken); break; case 'yyyy': year = parseInt(textToken); break; default: if (textToken !== formatToken) throw new Error('Unexpected token ' + textToken); } } if (isNaN(year)) throw new Error('Invalid year'); if (isNaN(month) && month !== -1) { throw new Error('Invalid month'); } else { month = Math.max(0, Math.min(11, month)); } if (!isNaN(day)) { day = Math.max(1, Math.min(31, day)); if (!isNaN(month)) { day = Math.min(daysInMonth(2000, month), day); if (!isNaN(year)) day = Math.min(daysInMonth(year, month), day); } } else { throw new Error('Invalid day'); } return new Date(year, month, day); } /*** * * @param date * @param {number} delta - must be a integer * @param {boolean=} gmt * @returns {Date} */ function addDate(date, delta, gmt) { delta = Math.round(delta); var res = beginOfDay(date, gmt); if (gmt) { res.setUTCDate(date.getUTCDate() + delta); } else { res.setDate(date.getDate() + delta); } return beginOfDay(res, gmt); } /** * @param {Date} date * @param {boolean=} gmt * @return {Date} */ function prevDate(date, gmt) { return addDate(date, -1, gmt); } /** * @param {Date} date * @param {boolean=} gmt * @return {Date} */ function nextDate(date, gmt) { return addDate(date, 1, gmt); } /**** * * @param {Date} date * @param {boolean=} gmt * @param {number=} startDayOfWeek * @returns {number} */ function weekIndexOf(date, gmt, startDayOfWeek) { if (typeof startDayOfWeek !== "number") startDayOfWeek = getDefaultFirstDayOfWeek(); var by = beginOfYear(date, gmt); var byw = beginOfWeek(by, gmt, startDayOfWeek); return Math.floor(compareDate(date, byw, gmt) / 7) ; } /*** * * @param {number} year * @param {number} weekIdx * @param {boolean=} gmt * @param {number=} startDayOfWeek * @returns {Date} */ function weekInYear(year, weekIdx, gmt, startDayOfWeek) { if (typeof startDayOfWeek !== "number") startDayOfWeek = getDefaultFirstDayOfWeek(); var bg = new Date(year, 0, 1, 0, 0, 0, 0); if (gmt) bg.setUTCHours(0); var byw = beginOfWeek(bg, gmt, startDayOfWeek); if (weekIdx === 0) return bg; return new Date(byw.getTime() + weekIdx * 7 * MILLIS_PER_DAY); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at xx:xx:xx:00 */ function beginOfSecond(date, gmt) { var res = new Date(date.getTime()); if (gmt) res.setUTCMilliseconds(0); else res.setMilliseconds(0); return res; } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at xx:xx:00 */ function beginOfMinute(date, gmt) { var res = new Date(date.getTime()); if (gmt) res.setUTCSeconds(0, 0); else res.setSeconds(0, 0); return res; } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 */ function beginOfDay(date, gmt) { var res = new Date(date.getTime()); if (gmt) res.setUTCHours(0, 0, 0, 0); else res.setHours(0, 0, 0, 0) return res; } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at xx:00 */ function beginOfHour(date, gmt) { var res = new Date(date.getTime()); if (gmt) res.setUTCMinutes(0, 0, 0); else res.setMinutes(0, 0, 0); return res; } /** * @param {Date} date * @param {Boolean=} gmt default:false * @param {number=} startDayOfWeek default:0 * @return {Date} date at 00:00 */ function beginOfWeek(date, gmt, startDayOfWeek) { if (typeof startDayOfWeek !== "number") startDayOfWeek = getDefaultFirstDayOfWeek(); var res = beginOfDay(date, gmt); if (isNaN(res.getTime())) return res; while ((gmt ? res.getUTCDay() : res.getDay()) !== startDayOfWeek) { res = prevDate(res, gmt); } return res; } /*** * * @param {Date} date * @param {number} delta * @param {boolean=} gmt */ function addWeek(date, delta, gmt) { date = beginOfWeek(date, gmt); delta = Math.round(delta); return addDate(date, delta * 7, gmt); } /**** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function nextWeek(date, gmt) { return addWeek(date, 1, gmt); } /**** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function prevWeek(date, gmt) { return addWeek(date, -1, gmt); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function beginOfMonth(date, gmt) { var m = gmt ? date.getUTCMonth() : date.getMonth(); var y = gmt ? date.getUTCFullYear() : date.getFullYear(); var res = new Date(); if (gmt) res.setUTCFullYear(y, m, 1); else res.setFullYear(y, m, 1); return beginOfDay(res, gmt); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function beginOfQuarter(date, gmt) { var y = gmt ? date.getUTCFullYear() : date.getFullYear(); var m = gmt ? date.getUTCMonth() : date.getMonth(); m = Math.floor(m / 3) * 3; var res = new Date(); if (gmt) res.setUTCFullYear(y, m, 1); else res.setFullYear(y, m, 1); return beginOfDay(res, gmt); } /*** * * @param {Date} date * @param {number=} delta * @param {boolean=} gmt */ function addQuarter(date, delta, gmt) { delta = Math.round(delta); date = beginOfQuarter(date, gmt); return addMonth(date, delta * 3, gmt); } /*** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function nextQuarter(date, gmt) { date = beginOfQuarter(date); return nextMonth(nextMonth(nextMonth(date, gmt), gmt), gmt); } /*** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function prevQuarter(date, gmt) { date = beginOfQuarter(date, gmt); return prevMonth(prevMonth(prevMonth(date, gmt), gmt), gmt); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function beginOfYear(date, gmt) { var y = gmt ? date.getUTCFullYear() : date.getFullYear(); var res = new Date(); if (gmt) res.setUTCFullYear(y, 0, 1); else res.setFullYear(y, 0, 1); return beginOfDay(res, gmt); } /** * @param {Date} date * @param {number} delta * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function addYear(date, delta, gmt) { delta = Math.round(delta); var y = gmt ? date.getUTCFullYear() : date.getFullYear(); var res = new Date(); if (gmt) res.setUTCFullYear(y + delta, 0, 1); else res.setFullYear(y + delta, 0, 1); return beginOfDay(res, gmt); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function nextYear(date, gmt) { return addYear(date, 1, gmt); } /** * @param {Date} date * @param {Boolean=} gmt default:false * @return {Date} date at 00:00 AM */ function prevYear(date, gmt) { return addYear(date, -1, gmt); } /** * @param {Date} date0 * @param {Date} date1 * @param {Boolean=} gmt default:false * @return {number} */ function compareDate(date0, date1, gmt) { date0 = beginOfDay(date0, gmt); date1 = beginOfDay(date1, gmt); //Date(1975, 5, 12) has 1 hour extend return Math.floor((date0.getTime() - date1.getTime()) / 86400000); } /** * @param {Date} date0 * @param {Date} date1 * @param {Boolean=} gmt default:false * @return {number} */ function compareMonth(date0, date1, gmt) { var m0 = gmt ? date0.getUTCMonth() : date0.getMonth(); var y0 = gmt ? date0.getUTCFullYear() : date0.getFullYear(); var m1 = gmt ? date1.getUTCMonth() : date1.getMonth(); var y1 = gmt ? date1.getUTCFullYear() : date1.getFullYear(); return (y0 - y1) * 12 + (m0 - m1); } /*** * * @param {Date} date0 * @param {Date} date1 * @param {boolean=}gmt * @returns {number} */ function compareYear(date0, date1, gmt) { var y0 = gmt ? date0.getUTCFullYear() : date0.getFullYear(); var y1 = gmt ? date1.getUTCFullYear() : date1.getFullYear(); return y0 - y1; } /** * * @param {Date} date * @param {number} delta * @param {boolean=} gmt * @returns {Date} */ function addMonth(date, delta, gmt) { var res = beginOfMonth(date, gmt); if (gmt) { res.setUTCMonth(res.getUTCMonth() + delta); } else { res.setMonth(res.getMonth() + delta); } return beginOfDay(res, gmt); } /** * * @param {Date} date * @param {number} delta * @param {boolean=} gmt * @returns {Date} */ function addMonthKeepDate(date, delta, gmt) { var res = addMonth(date, delta, gmt); var dateNum = gmt ? date.getUTCDate() : date.getDate(); var dim = daysInMonth(gmt ? date.getUTCFullYear() : date.getFullYear(), gmt ? date.getUTCFullYear() : date.getFullYear()); dateNum = Math.min(dateNum, dim); res = addDate(res, dateNum - 1, gmt); return res; } /** * * @param {Date} date * @param {number} delta * @param {boolean=} gmt * @returns {Date} */ function addMonthKeepDateTime(date, delta, gmt) { var dayOffset = date.getTime() - beginOfDay(date, gmt).getTime(); var res = addMonthKeepDate(date, delta, gmt); res = new Date(res.getTime() + dayOffset); return res; } /** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function nextMonth(date, gmt) { return addMonth(date, 1, gmt); } /** * * @param {Date} date * @param {boolean=} gmt * @returns {Date} */ function prevMonth(date, gmt) { return addMonth(date, -1, gmt); } /** * note:argument will be converted to 00h00 * @param date0 * @param date1 */ function monthOfTwoDate(date0, date1) { date0 = beginOfDay(date0); date1 = beginOfDay(date1); var temp; var sign = 1; var res = 0; var cmdv = compareDate(date0, date1); if (cmdv > 0) { sign = -1; temp = date0; date0 = date1; date1 = temp; } else if (cmdv === 0) return 0; var d1 = date0.getDate(); var d2 = date1.getDate(); var y0 = date0.getFullYear(); var y1 = date1.getFullYear(); var m0 = date0.getMonth(); var m1 = date1.getMonth(); var nextMD0; if (d1 <= d2) { res += (y1 - y0) * 12 + (m1 - m0); res += 2 * (d2 - d1) / (daysInMonth(y0, m0) + daysInMonth(y1, m1)); } else { res += (y1 - y0) * 12 + (m1 - m0) - 1; nextMD0 = beginOfMonth(nextMonth(date0)); res += 2 * (compareDate(nextMD0, date0) + compareDate(date1, beginOfMonth(date1))) / (daysInMonth(y0, m0) + daysInMonth(y1, m1)) } return sign * res; } /** * * @param {Number} year * @param {Number} month * @returns {Number} */ function daysInMonth(year, month) { var start = new Date(year, month, 1); var end = nextMonth(start); return compareDate(end, start); } /**** * * @param text * @param format support d, M, Y, Q * @param {*=} opt * @returns {Date} */ function parseDateTime(text, format, opt) { opt = Object.assign({ startDayOfWeek: 0 }, opt); var tokenMap = {}; var txtRgx = new RegExp(DATE_TIME_TOKEN_RGX.source, 'g'); var fmRgx = new RegExp(DATE_TIME_TOKEN_RGX.source, 'g'); var tkMatched, fmMatched; tkMatched = txtRgx.exec(text); fmMatched = fmRgx.exec(format); var tkText, fmText; while (tkMatched && fmMatched) { tkText = tkMatched[0]; fmText = fmMatched[0]; switch (fmText) { case 'd': case 'dd': tokenMap.day = parseInt(tkText, 10); break; case 'w': case 'ww': tokenMap.week = parseInt(tkText, 10) - 1; break; case 'M': case 'MM': tokenMap.month = parseInt(tkText, 10) - 1; break; case 'y': case 'yyyy': tokenMap.year = parseInt(tkText, 10); break; case 'h': case 'hh': case 'H': case 'HH': tokenMap.hour = parseInt(tkText, 10); break; case 'm': case 'mm': tokenMap.minute = parseInt(tkText, 10); break; case 'a': if (tkText === 'AM' || tkText === 'PM') tokenMap.period = tkText; else throw new Error('Invalid period(a):' + tkText) break; case 'Q': case 'QQ': tokenMap.month = (parseInt(tkText, 10) - 1) * 3; break; default: if (tkText !== fmText) { throw new Error('Unexpected token ' + JSON.stringify(tkText) + ' at ' + tkMatched.index + ', expected ' + fmText); } } tkMatched = txtRgx.exec(text); fmMatched = fmRgx.exec(format); } if (tokenMap.period) { if (tokenMap.period === 'AM' && tokenMap.hour === 12) tokenMap.hour = 0; else if (tokenMap.period === "PM" && tokenMap.hour < 12) tokenMap.hour += 12; } var paramNames = ['year', 'month', 'day', 'hour', 'minute', 'second']; var paramShortNames = ['y', 'M', 'd', 'h', 'm', 's']; var paramDefaultValues = [new Date().getFullYear(), 0, 1, 0, 0, 0]; var resParam = paramDefaultValues.slice(); var paramList = paramNames.reduce(function (ac, cr, i) { var sN = paramShortNames[i]; if (cr in tokenMap) { ac += sN; } return ac; }, ''); var paramName; for (var i = 0; i < paramNames.length; ++i) { paramName = paramNames[i]; resParam[i] = tokenMap[paramName] === undefined ? paramDefaultValues[i] : tokenMap[paramName]; } var weekDate; if ('week' in tokenMap && !isNaN(tokenMap.week)) { weekDate = weekInYear(resParam[0], tokenMap.week, false, opt.startDayOfWeek); resParam[1] = weekDate.getMonth(); resParam[2] = weekDate.getDate(); } switch (paramList) { case 'hm': resParam.splice(1, 2, new Date().getMonth(), new Date().getDate()); break; } return new Date(resParam[0], resParam[1], resParam[2], resParam[3], resParam[4], resParam[5]); } /*** * * @param {Date} date * @param {string} format * @param {*=} opt * @return {string} */ function formatDateTime(date, format, opt) { opt = Object.assign({ startDayOfWeek: 0 }, opt); var fmRgx = new RegExp(DATE_TIME_TOKEN_RGX.source, 'g'); return format.replace(fmRgx, function (s) { var res = s; switch (s) { case 'd': case 'dd': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getDate(), s.length); break; case 'w': case 'ww': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(weekIndexOf(date, false, opt.startDayOfWeek || getDefaultFirstDayOfWeek()) + 1, s.length); break; case 'M': case 'MM': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getMonth() + 1, s.length); break; case 'MMM': res = shortMonthNames[date.getMonth()]; break; case 'MMMM': res = monthNames[date.getMonth()]; break; case 'y': case 'yyyy': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getFullYear(), s.length); break; case 'yy': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getFullYear() % 100, s.length); break; case 'a': res = date.getHours() < 12 ? "AM" : "PM"; break; case "H": case 'HH': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getHours(), s.length); break; case 'h': case 'hh': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(1 + (date.getHours() - 1) % 12, s.length); break; case 'm': case 'mm': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getMinutes(), s.length); break; case 's': case 'ss': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(date.getSeconds(), s.length); break; case 'Q': case 'QQ': res = (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(Math.floor(date.getMonth() / 3) + 1, s.length) break; } return res; }); } var number = [/[+-]?\d+$/, matched => new Date(parseInt(matched[0]))]; var reISO = [/^(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2}(?:\.\d*))(?:Z|(\+|-)([\d|:]*))?$/, matched => new Date(matched[0])]; var reMsAjax = [/^\/Date\((d|-|.*)\)[\/|\\]$/, matched => new Date(parseInt(matched[1]))]; var reString = [/^(Mon|Tue|Wed|Thu|Fri|Sat|Sun)\s+([a-zA-Z]{3})\s+[\d\s:]+GMT[\d+]+\s*\([^)]+\)$/, matched => new Date(matched[0])]; function implicitDate(o) { var res = null; if (o instanceof Date) { res = new Date(o.getTime()); } else if (typeof o === "number") { res = new Date(o); } else if (typeof o === 'string') { [reString, reISO, reMsAjax, number].some(rule => { var matched = o.match(rule[0]); if (matched) { res = rule[1](matched); return true; } return false; }); } if (res && isNaN(res.getTime())) res = null; return res; } /*** * * @param {null|{dayOffset?: number, duration?: number}}range * @param opt */ function formatTimeRange24(range, opt) { opt = Object.assign({ nextDayText: (!window.systemconfig || (typeof window.systemconfig.language !== "string") || (window.systemconfig.language.toLowerCase().indexOf('vn') >= 0 || window.systemconfig.language.toLowerCase().indexOf('vi') >= 0)) ? 'Hôm sau' : 'Next day' }, opt || {}); range = range || {}; var m0 = Math.floor(range.dayOffset / MILLIS_PER_MINUTE); var h0 = Math.floor(m0 / 60); var d0 = Math.floor(h0 / 24); m0 = m0 % 60; h0 = h0 % 24; var endOffset = range.dayOffset + range.duration; var m1 = Math.floor(endOffset / MILLIS_PER_MINUTE); var h1 = Math.floor(m1 / 60); var d1 = Math.floor(h1 / 24); m1 = m1 % 60; h1 = h1 % 24; var res = h0 + ':' + (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(m0, 2) + ' - ' + h1 + ':' + (0,_Math_int__WEBPACK_IMPORTED_MODULE_1__.integerZeroPadding)(m1, 2); if (d0 !== d1) res += ' (' + opt.nextDayText + ')'; return res; } /** * * @param {Date} date * @param type * @param {number} n * @returns {{expireddate: Date, startdate: Date}} */ function getTimeRangeFromStep(date, type, n) { var startDate, expiredDate; var initHandlers = { month: x => beginOfMonth(x), quarter: x => beginOfQuarter(x), year: x => beginOfYear(x) } var addHandlers = { month: (x, d) => addMonth(x, d), quarter: (x, d) => addQuarter(x, d), year: (x, d) => addYear(x, d) } startDate = initHandlers[type](addHandlers[type](date, n)); expiredDate = addHandlers[type](startDate, 1); return { startdate: startDate, expireddate: expiredDate }; } /***/ }), /***/ 9892: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { /* module decorator */ module = __webpack_require__.nmd(module); (function (w) { "use strict"; function findBest(atobNative) { // normal window if ('function' === typeof atobNative) { return atobNative; } // browserify (web worker) if ('function' === typeof Buffer) { return function atobBrowserify(a) { //!! Deliberately using an API that's deprecated in node.js because //!! this file is for browsers and we expect them to cope with it. //!! Discussion: github.com/node-browser-compat/atob/pull/9 return new Buffer(a, 'base64').toString('binary'); }; } // ios web worker with base64js if ('object' === typeof w.base64js) { // bufferToBinaryString // https://git.coolaj86.com/coolaj86/unibabel.js/blob/master/index.js#L50 return function atobWebWorker_iOS(a) { var buf = w.base64js.b64ToByteArray(a); return Array.prototype.map.call(buf, function (ch) { return String.fromCharCode(ch); }).join(''); }; } return function () { // ios web worker without base64js throw new Error("You're probably in an old browser or an iOS webworker." + " It might help to include beatgammit's base64-js."); }; } var atobBest = findBest(w.atob); w.atob = atobBest; if (( true) && module && module.exports) { module.exports = atobBest; } }(window)); /***/ }), /***/ 706: /***/ ((module) => { (function () { "use strict"; function btoa(str) { var buffer; if (str instanceof Buffer) { buffer = str; } else { buffer = Buffer.from(str.toString(), 'binary'); } return buffer.toString('base64'); } module.exports = btoa; }()); /***/ }), /***/ 2634: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-autocomplete-input {\r\n display: inline-block;\r\n position: relative;\r\n box-sizing: border-box;\r\n border: solid 1px #d6d6d6;\r\n}\r\n\r\n.absol-autocomplete-input.absol-disabled {\r\n pointer-events: none;\r\n color: rgb(84, 84, 84);\r\n background-color: rgb(235, 235, 228);\r\n}\r\n\r\n.absol-autocomplete-input>input {\r\n min-width: 100%;\r\n min-height: 100%;\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border: none;\r\n outline: none;\r\n}\r\n\r\n\r\n.absol-autocomplete-input-dropdown {\r\n position: absolute;\r\n left: 0;\r\n top: 100%;\r\n min-width: 100%;\r\n z-index: 1005;\r\n border: solid 1px rgb(169, 169, 169);\r\n box-sizing: border-box;\r\n background-color: white;\r\n}\r\n\r\n.absol-autocomplete-input-dropdown .as-bscroller{\r\n overflow-y: auto;\r\n}\r\n\r\n.absol-autocomplete-input-dropdown.top {\r\n top: auto;\r\n bottom: 100%;\r\n}\r\n\r\n.absol-autocomplete-input-item {\r\n height: 30px;\r\n}\r\n\r\n.absol-autocomplete-input-item:hover {\r\n background-color: rgba(169, 169, 169, 0.18605);\r\n cursor: pointer;\r\n}\r\n\r\n.absol-autocomplete-input-item.active,\r\n.absol-autocomplete-input-item.active:hover {\r\n background-color: rgba(169, 169, 169, 0.37209);\r\n}\r\n\r\n.absol-autocomplete-input-item-text {\r\n line-height: 30px;\r\n margin-left: 5px;\r\n margin-right: 5px;\r\n}", ""]); /***/ }), /***/ 6773: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-has-board-table-drag,\r\n.as-has-board-table-drag * {\r\n cursor: grabbing;\r\n -webkit-user-select: none !important;\r\n -moz-user-select: none !important;\r\n -ms-user-select: none !important;\r\n user-select: none !important;\r\n}\r\n\r\n\r\n\r\n.as-board-table {\r\n overflow: visible;\r\n position: relative;\r\n\r\n}\r\n\r\n.as-board-drag-zone {\r\n -webkit-user-select: none !important;\r\n -moz-user-select: none !important;\r\n -ms-user-select: none !important;\r\n user-select: none !important;\r\n}\r\n\r\n\r\n.as-board {\r\n white-space: normal;\r\n box-sizing: border-box;\r\n position: relative;\r\n vertical-align: middle;\r\n}\r\n\r\n/**\r\nBug note: don't put fixed position element to a element which has transform\r\n */\r\n.as-board-moving {\r\n transform-origin: 30% 55%;\r\n transform: rotate(5deg);\r\n transition: transform 0.05s;\r\n user-select: none;\r\n pointer-events: none;\r\n position: fixed !important;\r\n z-index: 2000;\r\n}\r\n\r\n\r\n.as-board-place-holder {\r\n opacity: 0.3;\r\n}\r\n\r\n.as-board-table-prevent-context {\r\n position: fixed;\r\n --x: -10000px;\r\n --y: -10000px;\r\n left: calc(var(--x) - 100px);\r\n top: calc(var(--y) - 100px);\r\n opacity: 0;\r\n z-index: 100000000;\r\n width: 200px;\r\n height: 200px;\r\n cursor: default;\r\n -webkit-user-select: none;\r\n -webkit-touch-callout: none;\r\n -khtml-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n -o-user-select: none;\r\n}", ""]); /***/ }), /***/ 8020: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/* OLD module */\r\n\r\n.absol-bscroller {\r\n scrollbar-width: thin;\r\n scrollbar-color: rgba(151, 151, 151, 0.4) rgba(220, 220, 220, 0.4);\r\n overflow: auto;\r\n}\r\n\r\n\r\n.absol-bscroller::-webkit-scrollbar {\r\n width: 6px;\r\n height: 6px;\r\n}\r\n\r\n.absol-bscroller::-webkit-scrollbar-track {\r\n background: rgba(220, 220, 220, 0.4);\r\n}\r\n\r\n.absol-bscroller::-webkit-scrollbar-thumb {\r\n background: rgba(182, 182, 182, 0.4);\r\n}\r\n\r\n.absol-bscroller::-webkit-scrollbar-thumb:hover {\r\n background: rgba(32, 32, 32, 0.4);\r\n}\r\n\r\n.absol-bscroller::-webkit-scrollbar-thumb:active {\r\n background: rgba(13, 13, 13, 0.6);\r\n}\r\n\r\n.absol-bscroller.dark,\r\n.dark .absol-bscroller {\r\n scrollbar-color: rgba(104, 104, 104, 0.4) rgba(35, 35, 35, 0.4);\r\n}\r\n\r\n\r\n.absol-bscroller.dark::-webkit-scrollbar-track,\r\n.dark .absol-bscroller::-webkit-scrollbar-track {\r\n background: rgba(35, 35, 35, 0.4);\r\n}\r\n\r\n.absol-bscroller.dark::-webkit-scrollbar-thumb,\r\n.dark .absol-bscroller::-webkit-scrollbar-thumb {\r\n background: rgba(73, 73, 73, 0.4);\r\n}\r\n\r\n.absol-bscroller.dark::-webkit-scrollbar-thumb:hover,\r\n.dark .absol-bscroller::-webkit-scrollbar-thumb:hover {\r\n background: rgba(223, 223, 223, 0.4);\r\n}\r\n\r\n.absol-bscroller.dark::-webkit-scrollbar-thumb:active,\r\n.dark .absol-bscroller::-webkit-scrollbar-thumb:active {\r\n background: rgba(242, 242, 242, 0.6);\r\n}\r\n\r\n/*******************************************/\r\n.as-bscroller {\r\n scrollbar-width: thin;\r\n scrollbar-color: rgba(151, 151, 151, 0.4) rgba(220, 220, 220, 0.4);\r\n}\r\n\r\n\r\n.as-bscroller::-webkit-scrollbar {\r\n width: 6px;\r\n height: 6px;\r\n}\r\n\r\n.as-bscroller::-webkit-scrollbar-track {\r\n background: rgba(220, 220, 220, 0.4);\r\n}\r\n\r\n.as-bscroller::-webkit-scrollbar-thumb {\r\n background: rgba(182, 182, 182, 0.4);\r\n}\r\n\r\n.as-bscroller::-webkit-scrollbar-thumb:hover {\r\n background: rgba(32, 32, 32, 0.4);\r\n}\r\n\r\n.as-bscroller::-webkit-scrollbar-thumb:active {\r\n background: rgba(13, 13, 13, 0.6);\r\n}\r\n\r\n.as-bscroller.dark,\r\n.dark .as-bscroller,\r\n.as-dark .as-bscroller,\r\n.as-dark.as-bscroller\r\n{\r\n scrollbar-color: rgba(104, 104, 104, 0.4) rgba(150, 150, 150, 0.4);\r\n}\r\n\r\n\r\n.as-bscroller.dark::-webkit-scrollbar-track,\r\n.dark .as-bscroller::-webkit-scrollbar-track,\r\n.as-dark .as-bscroller::-webkit-scrollbar-track,\r\n.as-dark.as-bscroller::-webkit-scrollbar-track\r\n{\r\n background: rgba(150, 150, 150, 0.4);\r\n}\r\n\r\n.as-bscroller.dark::-webkit-scrollbar-thumb,\r\n.dark .as-bscroller::-webkit-scrollbar-thumb,\r\n.as-dark .as-bscroller::-webkit-scrollbar-thumb,\r\n.as-dark.as-bscroller::-webkit-scrollbar-thumb\r\n{\r\n background: rgba(104, 104, 104, 0.4);\r\n}\r\n\r\n.as-bscroller.dark::-webkit-scrollbar-thumb:hover,\r\n.dark .as-bscroller::-webkit-scrollbar-thumb:hover,\r\n.as-dark .as-bscroller::-webkit-scrollbar-thumb:hover,\r\n.as-dark.as-bscroller::-webkit-scrollbar-thumb:hover\r\n{\r\n background: rgba(223, 223, 223, 0.4);\r\n}\r\n\r\n.as-bscroller.dark::-webkit-scrollbar-thumb:active,\r\n.dark .as-bscroller::-webkit-scrollbar-thumb:active,\r\n.as-dark .as-bscroller::-webkit-scrollbar-thumb:active,\r\n.as-dark.as-bscroller::-webkit-scrollbar-thumb:active\r\n{\r\n background: rgba(242, 242, 242, 0.6);\r\n}", ""]); /***/ }), /***/ 3220: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-button-array {\r\n font-size: 1rem;\r\n border: 1px solid #006ce5;\r\n display: inline-block;\r\n border-radius: 0.2em;\r\n overflow: hidden;\r\n}\r\n\r\n.as-button-array-item {\r\n text-align: center;\r\n font-size: inherit;\r\n height: 2em;\r\n border: none;\r\n box-sizing: border-box;\r\n padding-left: 0.35714em;\r\n padding-right: 0.35714em;\r\n outline: none;\r\n color: #006ce5;\r\n background-color: white;\r\n border-radius: 0;\r\n transition: background-color 0.1s, color 0.1s;\r\n margin: 0;\r\n}\r\n\r\n.as-button-array-item:not(:first-child) {\r\n border-left: 1px solid #006ce5;\r\n border-right: none;\r\n}\r\n\r\n\r\n.as-button-array-item.as-active {\r\n color: white;\r\n background-color: #006ce5;\r\n}", ""]); /***/ }), /***/ 5224: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-button-range-wrapper {\r\n border-top: 1px solid rgb(209, 209, 213);\r\n border-bottom: 1px solid rgb(209, 209, 213);\r\n}\r\n\r\n.as-button-range {\r\n position: relative;\r\n overflow-y: hidden;\r\n height: var(--height);\r\n box-sizing: border-box;\r\n font-family: Arial, Helvetica, sans-serif;\r\n --underline-left: 0;\r\n --underline-width: 0;\r\n --height: 2em;\r\n}\r\n\r\n.as-button-range-scroller {\r\n font-size: inherit;\r\n height: calc(var(--height) + 17px);\r\n box-sizing: border-box;\r\n overflow-x: scroll;\r\n position: absolute;\r\n top: 0;\r\n left: 0.5em;\r\n right: 0.5em;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-button-range-scroller::after {\r\n content: \"\";\r\n position: absolute;\r\n left: var(--underline-left);\r\n width: var(--underline-width);\r\n height: 0.2em;\r\n top: calc(var(--height) - 0.2em);\r\n background-color: rgb(0, 106, 255);\r\n transition: left 0.2s, width 0.2s;\r\n}\r\n\r\n.as-button-range-left-ctn,\r\n.as-button-range-right-ctn {\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-button-range-right-ctn::after,\r\n.as-button-range-left-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-button-range-left-ctn {\r\n left: 0;\r\n}\r\n\r\n.as-button-range-right-ctn {\r\n right: 0;\r\n}\r\n\r\n.as-button-range-right-btn,\r\n.as-button-range-left-btn {\r\n font-size: inherit;\r\n padding: 0;\r\n margin: 0;\r\n display: inline-block;\r\n vertical-align: middle;\r\n border: none;\r\n outline: none;\r\n color: rgb(0, 106, 266);\r\n background-color: rgba(255, 255, 255, 0.5);\r\n border-radius: 0.5em;\r\n overflow: hidden;\r\n}\r\n\r\n.as-button-range-left-btn {\r\n -webkit-box-shadow: 1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n -moz-box-shadow: 1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n box-shadow: 1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n}\r\n\r\n.as-button-range-right-btn {\r\n -webkit-box-shadow: -1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n -moz-box-shadow: -1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n box-shadow: -1em 2px 1.5em -1em rgba(255, 255, 255, 0.62);\r\n}\r\n\r\n.as-button-range-right-btn polygon,\r\n.as-button-range-left-btn polygon {\r\n fill: #2488FF;\r\n}\r\n\r\n.as-button-range-right-btn:disabled,\r\n.as-button-range-left-btn:disabled {\r\n display: none;\r\n}\r\n\r\n.as-button-range-left-btn > svg,\r\n.as-button-range-right-btn > svg {\r\n width: 1.25em;\r\n height: 1.25em;\r\n margin-left: -0.25em;\r\n margin-right: -0.25em;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-button-range-item {\r\n outline: none;\r\n font-size: inherit;\r\n padding: 0 0.5em;\r\n margin: 0;\r\n height: var(--height);\r\n border: none;\r\n background-color: transparent;\r\n color: black;\r\n}\r\n\r\n.as-button-range-item.as-active {\r\n color: rgb(87, 157, 255);\r\n}", ""]); /***/ }), /***/ 9278: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-calendar-input {\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n width: 7em;\r\n height: 2em;\r\n box-sizing: content-box;\r\n display: inline-block;\r\n vertical-align: middle;\r\n border: solid 1px #d6d6d6;\r\n border-radius: 0.2em;\r\n}\r\n\r\n.absol-calendar-input.as-border-none {\r\n border: none;\r\n}\r\n\r\n.absol-calendar-input.as-border-none > input {\r\n text-align: left;\r\n padding-left: 0;\r\n}\r\n\r\n.absol-calendar-input > input {\r\n text-align: center;\r\n width: 100%;\r\n height: 100%;\r\n outline: none;\r\n border: none;\r\n background: transparent;\r\n padding: 0;\r\n font: inherit;\r\n}\r\n\r\n.absol-calendar-input:not(.as-read-only) input {\r\n cursor: pointer;\r\n}\r\n\r\n.absol-calendar-input:not(.as-read-only) > input:hover,\r\n.absol-calendar-input:not(.as-read-only) > input:focus {\r\n color: red;\r\n}\r\n\r\n.absol-calendar-input.absol-disabled {\r\n pointer-events: none;\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.absol-calendar-input.absol-disabled input {\r\n color: var(--as-disabled-text-color);\r\n}\r\n", ""]); /***/ }), /***/ 9362: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/** align middle in table cell **/\r\n.KPIsimpletableclass td > .absol-checkbox:first-child:last-child,\r\n.KPIsimpletableclass td > .absol-checkbox.as-no-label:first-child:last-child .as-checkbox-input {\r\n display: block;\r\n margin: auto;\r\n}\r\n\r\n.cardsimpletableclass > table > tbody > tr > td > .absol-checkbox:first-child:last-child {\r\n display: block;\r\n}\r\n\r\n.absol-checkbox {\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 16px;\r\n}\r\n\r\n.absol-checkbox:not(.as-read-only):not(.as-disabled) {\r\n cursor: pointer;\r\n user-select: none;\r\n}\r\n\r\n.absol-checkbox.right > .absol-checkbox-label.as-right {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-checkbox:not(.right) > .absol-checkbox-label.as-left {\r\n display: none;\r\n}\r\n\r\n.absol-checkbox-label {\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.absol-checkbox-label.as-left {\r\n padding-right: 0.3em;\r\n}\r\n\r\n\r\n.absol-checkbox-label.as-right {\r\n padding-left: 0.3em;\r\n}\r\n\r\n.absol-checkbox.as-no-label {\r\n width: calc(1em + 2px);\r\n height: calc(1em + 2px);\r\n}\r\n\r\n\r\n.absol-checkbox.as-no-label .absol-checkbox-label {\r\n display: none;\r\n}\r\n\r\n.absol-checkbox.as-no-label .as-checkbox-input {\r\n display: block;\r\n}\r\n\r\n.absol-checkbox.as-disabled .absol-checkbox-label {\r\n color: var(--as-disabled-text-color);\r\n}\r\n\r\n\r\n.absol-checkbox.as-wrap-text {\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-checkbox.as-wrap-text .absol-checkbox-label {\r\n white-space: normal;\r\n}\r\n\r\n.absol-checkbox.as-wrap-text > * {\r\n vertical-align: top;\r\n}\r\n\r\n.absol-checkbox.as-wrap-text .absol-checkbox-label {\r\n max-width: calc(100% - 24px);\r\n}\r\n\r\n.absol-checkbox.as-read-only .as-checkbox-input {\r\n pointer-events: none;\r\n}\r\n\r\n.absol-checkbox.as-read-only.as-border-none .bound {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 141: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-checkbox-button{\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-checkbox-button .absol-checkbox-icon{\r\n display: block;\r\n}", ""]); /***/ }), /***/ 5288: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --candy-border-color: #929292;\r\n --candy-hover-background-color: #eeeee9;\r\n --candy-disabled-background-color: #ebebe4;\r\n}\r\n\r\nlabel.as-checkbox-input {\r\n display: inline-block;\r\n position: relative;\r\n width: calc(1em + 2px);\r\n height: calc(1em + 2px);\r\n font-size: inherit;\r\n box-sizing: border-box;\r\n vertical-align: middle;\r\n border-radius: 0.25em;\r\n padding: 0;\r\n margin: 0; /*fix boostrap override*/\r\n overflow: hidden;\r\n}\r\n\r\n.as-checkbox-input:not(.as-read-only):not(.as-disabled){\r\n cursor: pointer;\r\n}\r\n\r\n\r\nlabel.as-checkbox-input:hover:not(.as-read-only) .bound,\r\n.absol-checkbox:hover:not(.as-read-only) .bound {\r\n fill: var(--candy-hover-background-color);\r\n}\r\n\r\n.as-checkbox-input .tick,\r\n.as-checkbox-input .minus {\r\n fill: #606060;\r\n}\r\n\r\n\r\n.as-checkbox-input input.as-checkbox-input-value {\r\n font-size: inherit;\r\n position: absolute;\r\n right: 100%;\r\n top: 0;\r\n opacity: 0.0;\r\n z-index: -100000000000;\r\n}\r\n\r\ninput.as-checkbox-input-value:not(:checked) ~ svg .tick {\r\n opacity: 0;\r\n}\r\n\r\n.as-checkbox-input.as-has-minus .minus {\r\n opacity: 1;\r\n}\r\n\r\n.as-checkbox-input .minus,\r\ninput.as-checkbox-input-value:checked ~ svg .minus {\r\n opacity: 0;\r\n}\r\n\r\n\r\nlabel.as-checkbox-input .bound {\r\n stroke: var(--candy-border-color);\r\n fill: white;\r\n}\r\n\r\nlabel.as-checkbox-input .tick {\r\n opacity: 1;\r\n transition: opacity 0.1s;\r\n}\r\n\r\nlabel.as-checkbox-input .minus {\r\n transition: opacity 0.1s;\r\n}\r\n\r\nlabel.as-checkbox-input.as-disabled > svg .bound,\r\nlabel.as-checkbox-input.as-disabled:hover > svg .bound {\r\n stroke: #929292;\r\n fill: #ebebe4;\r\n}\r\n\r\n\r\n.as-checkbox-input > svg {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-checkbox-input.as-read-only.as-border-none .bound{\r\n display: none;\r\n}", ""]); /***/ }), /***/ 2896: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-check-list-box.as-select-list-box {\r\n width: calc(var(--select-list-estimate-width) + 2px + 5px + 23px + 7px);\r\n --as-width-limit: calc(100vw - 20px);\r\n}\r\n\r\n.as-check-list-box.as-select-list-box.as-enable-search .as-select-list-box-scroller {\r\n max-height: calc(var(--max-height) - 2em - 10px - 2em - 1px);\r\n}\r\n\r\n.as-check-list-box.as-select-list-box .as-select-list-box-scroller {\r\n max-height: calc(var(--max-height) - 2em - 1px);\r\n}\r\n\r\n\r\n.as-check-list-box.as-select-list-box .absol-selectlist-item-text {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n max-width: calc(var(--as-width-limit) - 0.7em - 2.5em);\r\n}\r\n", ""]); /***/ }), /***/ 8949: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-check-list-item {\r\n padding-left: 0.35em;\r\n height: calc(30rem / 14);\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.as-check-list-item-checkbox {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-check-list-item-checkbox .as-checkbox-input-check-icon{\r\n display: block;\r\n\r\n}\r\n\r\n.absol-selectlist-item.as-check-list-item > span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: calc(30rem / 14);\r\n}\r\n\r\n.absol-selectlist-item.as-check-list-item .absol-selectlist-item-desc {\r\n line-height: calc(25rem / 14);\r\n}\r\n\r\n.as-check-list-item.as-no-select .as-check-list-item-checkbox {\r\n visibility: hidden;\r\n}\r\n\r\n.as-check-list-item.as-no-select {\r\n pointer-events: none;\r\n}", ""]); /***/ }), /***/ 4014: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-select-list-box-page > .as-check-tree-item {\r\n width: 100%;\r\n}\r\n\r\n.as-check-tree-box {\r\n min-width: 18em;\r\n}\r\n\r\n.as-check-tree-box.as-no-transition label.as-checkbox-input .minus,\r\n.as-check-tree-box.as-no-transition label.as-checkbox-input .tick {\r\n transition: none;\r\n}\r\n\r\n\r\n.as-check-tree-box.as-select-list-box.as-enable-search .as-select-list-box-scroller {\r\n max-height: calc(var(--max-height) - 2em - 10px - 2em - 1px);\r\n}\r\n\r\n.as-check-tree-box.as-select-list-box .as-select-list-box-scroller {\r\n max-height: calc(var(--max-height) - 2em - 1px);\r\n}\r\n\r\n/***********************************************************************************************************************/\r\n\r\n.am-check-tree-box .as-dropdown-box-footer,\r\n.am-check-tree-box\r\n{\r\n min-width: 18em;\r\n}\r\n\r\n.am-check-tree-box-list {\r\n --text-width: 100%;\r\n --desc-width: 0;\r\n}\r\n\r\n.am-check-tree-box-modal:not(.as-enable-search) .absol-search-text-input {\r\n visibility: hidden;\r\n opacity: 0;\r\n pointer-events: none;\r\n}\r\n\r\n.am-check-tree-box .as-check-tree-box-scroller {\r\n max-height: calc(100vh - var(--modal-margin-top) - 100px);\r\n}\r\n\r\n.am-check-tree-box {\r\n width: var(--select-list-estimate-width);\r\n /*max-width: calc(100vw - 20px);*/\r\n}\r\n\r\n.am-check-tree-box .as-check-tree-box-content {\r\n /*max-width: calc(100vw - 20px);*/\r\n}\r\n\r\n.am-check-tree-box.as-has-desc {\r\n --text-width: 50%;\r\n --desc-width: 50%;\r\n}\r\n\r\n\r\n.am-check-tree-box-body {\r\n overflow-y: auto;\r\n max-height: calc(80vh - 2em);\r\n}\r\n\r\n.am-check-tree-box.as-enable-search .am-check-tree-box-body {\r\n max-height: calc(80vh - 4em - 10px);\r\n}\r\n\r\n.am-check-tree-item {\r\n display: block;\r\n white-space: nowrap;\r\n position: relative;\r\n width: 100%;\r\n overflow: hidden;\r\n --level: 0;\r\n --icon-width: 0px;\r\n}\r\n\r\n\r\n.am-check-tree-item.as-has-icon {\r\n --icon-width: 2.7em;\r\n}\r\n\r\n\r\n.am-check-tree-item-toggle-ctn,\r\n.am-check-tree-item-icon-ctn,\r\n.am-check-tree-item-checkbox-ctn {\r\n position: absolute;\r\n white-space: nowrap;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.am-check-tree-item-toggle-ctn {\r\n left: calc(2em * var(--level) + 0.2em);\r\n width: 1.5em;\r\n text-align: center;\r\n}\r\n\r\n.am-check-tree-item-toggle-ctn > svg {\r\n width: 0.7em;\r\n height: 0.7em;\r\n}\r\n\r\n\r\n.am-check-tree-item-icon-ctn {\r\n left: calc(2em * var(--level) + 3.2em);\r\n}\r\n\r\n.am-check-tree-item-checkbox-ctn {\r\n left: calc(2em * var(--level) + 1.7em)\r\n}\r\n\r\n.am-check-tree-item-icon-ctn > svg {\r\n display: inline-block;\r\n vertical-align: middle;\r\n\r\n}\r\n\r\n\r\n.am-check-tree-item.as-status-open svg .toggle-close,\r\n.am-check-tree-item.as-status-close svg .toggle-open,\r\n.am-check-tree-item:not(.as-status-close):not(.as-status-open) .am-check-tree-item-toggle-ctn {\r\n display: none;\r\n}\r\n\r\n.am-check-tree-item-icon-ctn::before,\r\n.am-check-tree-item-toggle-ctn::before,\r\n.am-check-tree-item-checkbox-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n.am-check-tree-item-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n.am-check-tree-item-icon-ctn > span {\r\n font-size: 1.8em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.am-check-tree-item-icon-ctn img,\r\n.am-check-tree-item-icon-ctn svg {\r\n width: 1.8em;\r\n height: 1.8em;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.am-check-tree-item-text {\r\n width: var(--text-width);\r\n box-sizing: border-box;\r\n padding: 0.3em 0.5em 0.3em calc(3em + 2em * var(--level) + var(--icon-width));\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1.5;\r\n white-space: normal;\r\n}\r\n\r\n\r\n.am-check-tree-item-desc {\r\n display: none;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.am-check-tree-leaf-item:not(.as-is-leaf) .am-check-tree-item-checkbox-ctn {\r\n display: none;\r\n}\r\n\r\n.am-check-tree-leaf-item:not(.as-is-leaf) .am-check-tree-item-text {\r\n padding: 0.3em 0.5em 0.3em calc(2em * var(--level) + var(--icon-width) + 1em);\r\n}\r\n\r\n.am-check-tree-leaf-item:not(.as-is-leaf) .am-check-tree-item-icon-ctn {\r\n left: calc(2em * var(--level) + 1.5em);\r\n}\r\n\r\n.am-check-tree-box-list.as-has-desc .am-check-tree-item-desc {\r\n display: inline-block;\r\n}\r\n\r\n.am-check-tree-box.as-leaf-only .am-check-tree-item:not(.as-has-leaf) .as-checkbox-input {\r\n pointer-events: none;\r\n opacity: 0.2;\r\n}\r\n\r\n\r\n.am-check-tree-box.as-leaf-only:not(.as-has-leaf) .as-select-list-box-check-all {\r\n pointer-events: none;\r\n color: var(--as-disabled-text-color);\r\n}\r\n\r\n.am-check-tree-box.as-leaf-only:not(.as-has-leaf) .as-select-list-box-check-all label.as-checkbox-input .bound {\r\n stroke: #929292;\r\n fill: #ebebe4;\r\n}\r\n\r\n.as-multi-select-menu-item-ctn:empty::before {\r\n position: absolute;\r\n left: 0;\r\n top: calc(50% - 1em);\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-family: Arial, Helvetica, sans-serif;\r\n padding: 0 5px;\r\n line-height: 2;\r\n}\r\n\r\n.as-multi-select-menu-item-ctn:not(:empty):before,\r\n.as-multi-select-menu.as-read-only .as-multi-select-menu-item-ctn::before,\r\n.as-multi-select-menu.as-disabled .as-multi-select-menu-item-ctn::before {\r\n display: none;\r\n}\r\n\r\n.as-multi-select-menu-item-ctn[data-placeholder]:empty::before {\r\n content: attr(data-placeholder);\r\n}\r\n", ""]); /***/ }), /***/ 7586: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-check-tree-item {\r\n font-size: inherit;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n height: 2em;\r\n}\r\n\r\n.as-check-tree-item:focus {\r\n background-color: unset;\r\n}\r\n\r\n.as-check-tree-item:hover:focus {\r\n background-color: rgba(169, 169, 172, 0.1);\r\n}\r\n\r\n.as-check-tree-item .as-checkbox-input {\r\n margin-right: 0.35em;\r\n}\r\n\r\n.as-check-tree-item.as-no-select .as-checkbox-input,\r\n.absol-checkbox.as-no-select {\r\n pointer-events: none;\r\n opacity: 0.3;\r\n}\r\n\r\n.as-check-tree-item.as-no-select .as-checkbox-input .bound,\r\n.absol-checkbox.as-no-select .bound {\r\n stroke: #929292;\r\n fill: #ebebe4;\r\n}\r\n\r\n.as-check-tree-item.as-no-select .as-checkbox-input .tick,\r\n.as-check-tree-item.as-no-select .as-checkbox-input .minus,\r\n.absol-checkbox.as-no-select .tick,\r\n.absol-checkbox.as-no-select .minus {\r\n display: none;\r\n opacity: 0;\r\n visibility: hidden;\r\n}\r\n\r\n.as-check-tree-item.as-check-unsafe-tree-item {\r\n padding-right: 45px;\r\n}\r\n\r\n.as-check-unsafe-tree-item .as-check-unsafe-tree-item-action-ctn {\r\n display: none;\r\n position: absolute;\r\n height: 20px;\r\n right: 5px;\r\n top: calc(50% - 10px);\r\n --as-transparent-button-text-color: rgba(107, 107, 108, 0.3);\r\n}\r\n\r\n/*.as-check-unsafe-tree-item.status-close .as-check-unsafe-tree-item-action-ctn,*/\r\n/*.as-check-unsafe-tree-item.status-open .as-check-unsafe-tree-item-action-ctn*/\r\n/*{*/\r\n/* display: block;*/\r\n/*}*/\r\n\r\n\r\n.as-check-unsafe-tree-item-action-ctn >button{\r\n width: 25px;\r\n height: 20px;\r\n}\r\n\r\n/*.as-check-unsafe-tree-item-action-ctn >button:not(:first-child) {*/\r\n/* margin-left: 5px;*/\r\n/*}*/\r\n\r\n.absol-checkbox.as-no-select {\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 8363: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-chrome-calendar {\r\n display: inline-block;\r\n font-family: Helvetica, Arial, sans-serif;\r\n font-size: 1rem;\r\n padding: 0.6em;\r\n border: solid 1px rgb(191, 191, 191);\r\n box-shadow: 1px 1px 2px rgb(240, 240, 240);\r\n z-index: 100;\r\n touch-action: manipulation;\r\n user-select: none;\r\n background-color: rgb(255, 255, 255);\r\n white-space: initial;\r\n outline: none;\r\n}\r\n\r\n.absol-chrome-calendar * {\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-header {\r\n white-space: nowrap;\r\n position: relative;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-title {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-chrome-calendar-header-buttons {\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n}\r\n\r\n.absol-chrome-calendar-header-buttons > button {\r\n font-size: 1em;\r\n width: 1.5em;\r\n height: 1.5em;\r\n padding: 0;\r\n border-radius: 0.2em;\r\n border: solid 1px rgb(167, 167, 167);\r\n background: linear-gradient(rgb(240, 240, 240), rgb(233, 233, 233), rgb(223, 223, 223));\r\n cursor: pointer;\r\n outline: none;\r\n box-shadow: 1px 1px 2px #aaa;\r\n color: rgb(110, 110, 110);\r\n}\r\n\r\n.absol-chrome-calendar-header-buttons > button:nth-child(2) {\r\n margin-left: 0.2em;\r\n margin-right: 0.2em;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-header-buttons > button:active {\r\n box-shadow: 0px 0px 2px #aaa;\r\n\r\n}\r\n\r\n.absol-chrome-calendar:not(.view-era) .absol-chrome-calendar-title {\r\n cursor: pointer;\r\n}\r\n\r\n.absol-chrome-calendar-title::after {\r\n content: \"\\25BC\";\r\n}\r\n\r\n.absol-chrome-calendar[data-view=\"era\"] .absol-chrome-calendar-title::after {\r\n content: \"\";\r\n}\r\n\r\n.absol-chrome-calendar-title > span {\r\n line-height: 1.5em;\r\n min-width: 5em;\r\n display: inline-block;\r\n}\r\n\r\n.absol-chrome-calendar-instance {\r\n margin-top: 1em;\r\n border: solid 1px rgb(140, 140, 140);\r\n width: calc(14em + 2px);\r\n position: relative;\r\n height: calc(8.4em + 3px);\r\n overflow: hidden;\r\n box-sizing: border-box;\r\n /*border*/\r\n}\r\n\r\n.absol-chrome-calendar-dayofweek {\r\n background-color: rgb(241, 241, 241);\r\n height: 1.2em;\r\n white-space: nowrap;\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n z-index: 10;\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-dayofweek::before {\r\n content: \"wk\";\r\n text-align: center;\r\n line-height: 1.2;\r\n display: inline-block;\r\n color: rgb(130, 130, 255);\r\n border-bottom: solid 1px rgb(191, 191, 191);\r\n border-right: solid 1px rgb(191, 191, 191);\r\n box-sizing: border-box;\r\n width: 12.5%;\r\n}\r\n\r\n.absol-chrome-calendar-dayofweek > div {\r\n text-align: center;\r\n line-height: 1.2;\r\n display: inline-block;\r\n width: calc(100% / 7);\r\n border-bottom: solid 1px rgb(191, 191, 191);\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-dayofweek > div {\r\n width: 12.5%;\r\n}\r\n\r\n.absol-chrome-calendar-month-animation-container {\r\n position: absolute;\r\n transition: top 0.2s;\r\n}\r\n\r\n.absol-chrome-calendar-month-animation-container.old {\r\n z-index: 7;\r\n /* background: red; */\r\n}\r\n\r\n.absol-chrome-calendar-month-animation-container.new {\r\n z-index: 8;\r\n /* background: blue; */\r\n}\r\n\r\n.absol-chrome-calendar-month-animation-container > .absol-chrome-calendar-month {\r\n width: 100%;\r\n height: 100%;\r\n margin-top: -1px;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-month {\r\n width: 100%;\r\n margin-top: 1.2em;\r\n background-color: white;\r\n /*for header*/\r\n}\r\n\r\n.absol-chrome-calendar-month.as-animation {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n margin: 0;\r\n z-index: 8;\r\n transition: top 0.2s;\r\n /*opacity: 0.5;*/\r\n}\r\n\r\n.absol-chrome-calendar-month.as-animation div {\r\n pointer-events: none;\r\n transition: color 0.2s;\r\n}\r\n\r\n.absol-chrome-calendar[data-view=\"month\"] .absol-chrome-calendar-month {\r\n display: table;\r\n}\r\n\r\n.absol-chrome-calendar[data-view=\"month\"] .absol-chrome-calendar-dayofweek {\r\n display: block;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-week-in-month {\r\n display: table-row;\r\n height: 1.2em;\r\n}\r\n\r\n.absol-chrome-calendar-week-in-month > div::before {\r\n content: attr(data-date);\r\n}\r\n\r\n\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month::before {\r\n content: attr(data-week-idx-text);\r\n display: table-cell;\r\n text-align: right;\r\n padding-right: 0.4em;\r\n color: rgb(130, 130, 255);\r\n text-shadow: 1px 0 0 currentColor;\r\n border-right: solid 1px rgb(191, 191, 191);\r\n width: 12.5%;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-week-in-month > div {\r\n display: table-cell;\r\n text-align: right;\r\n padding-right: 0.4em;\r\n cursor: pointer;\r\n box-sizing: border-box;\r\n width: calc(100% / 7);\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month > div {\r\n width: calc(100% / 8);\r\n}\r\n\r\n\r\n.absol-chrome-calendar[data-level=\"day\"] .absol-chrome-calendar-week-in-month > div:hover,\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month.as-hover-in-year > div:not(.as-not-in-year),\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month.as-hover-in-year::before,\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month.as-hover-not-in-year > .as-not-in-year\r\n{\r\n background-color: rgb(224, 245, 256);\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"day\"] .absol-chrome-calendar-not-in-month:not(.as-disabled),\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-not-in-month:not(.as-disabled) {\r\n color: rgb(140, 140, 140);\r\n}\r\n\r\n.absol-chrome-calendar-today {\r\n border: inset 1px rgb(191, 191, 191);\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-chrome-calendar-selected,\r\n.absol-chrome-calendar[data-level=\"week\"] .as-week-selected,\r\n.absol-chrome-calendar[data-level=\"quarter\"] .as-quarter-selected,\r\n.absol-chrome-calendar[data-level=\"week\"] .absol-chrome-calendar-week-in-month.as-selected::before\r\n{\r\n background-color: rgb(188, 205, 236) !important;\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"week\"] .as-week-selected .absol-chrome-calendar-selected {\r\n background-color: transparent;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-years {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n height: 100%;\r\n z-index: 1;\r\n}\r\n\r\n.absol-chrome-calendar:not([data-view=\"year\"]) .absol-chrome-calendar-years {\r\n z-index: -10000;\r\n opacity: 0;\r\n visibility: hidden;\r\n}\r\n\r\n.absol-chrome-calendar.view-year .absol-chrome-calendar-instance {\r\n border-color: rgb(77, 114, 254)\r\n}\r\n\r\n.absol-chrome-calendar-month,\r\n.absol-chrome-calendar-dayofweek,\r\n.absol-chrome-calendar-era {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-chrome-calendar:not(.view-month) .absol-chrome-calendar-title {\r\n color: rgb(191, 191, 191);\r\n}\r\n\r\n\r\n.absol-chrome-calendar-year {\r\n overflow: hidden;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-year-head {\r\n background-color: rgb(241, 241, 241);\r\n border-bottom: solid 1px rgb(191, 191, 191);\r\n height: 1.5em;\r\n text-align: center;\r\n line-height: 1.5em;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.absol-chrome-calendar-year:last-child .absol-chrome-calendar-year-head {\r\n border-bottom: solid 1px rgb(191, 191, 191);\r\n}\r\n\r\n.absol-chrome-calendar-year.start-opening .absol-chrome-calendar-year-months,\r\n.absol-chrome-calendar-year.closing .absol-chrome-calendar-year-months {\r\n margin-bottom: -6em;\r\n transition: margin-bottom linear 0.1s;\r\n}\r\n\r\n.absol-chrome-calendar-year.opening .absol-chrome-calendar-year-months,\r\n.absol-chrome-calendar-year.start-closing .absol-chrome-calendar-year-months {\r\n margin-bottom: 0;\r\n transition: margin-bottom linear 0.1s;\r\n\r\n}\r\n\r\n.absol-chrome-calendar-year-months {\r\n width: 100%;\r\n display: table;\r\n height: calc(6em + 1px);\r\n border-bottom: solid 1px rgb(191, 191, 191);\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-chrome-calendar-year-row-months {\r\n display: table-row;\r\n line-height: 1.5;\r\n height: 2em;\r\n}\r\n\r\n.absol-chrome-calendar-year-month {\r\n text-align: center;\r\n display: table-cell;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-chrome-calendar-year-month:hover,\r\n.absol-chrome-calendar-era-year:hover,\r\n.absol-chrome-calendar[data-level=\"quarter\"] .absol-chrome-calendar-years-content[data-hover-quarter=\"0\"] .absol-chrome-calendar-year-month[data-quarter=\"0\"],\r\n.absol-chrome-calendar[data-level=\"quarter\"] .absol-chrome-calendar-years-content[data-hover-quarter=\"1\"] .absol-chrome-calendar-year-month[data-quarter=\"1\"],\r\n.absol-chrome-calendar[data-level=\"quarter\"] .absol-chrome-calendar-years-content[data-hover-quarter=\"2\"] .absol-chrome-calendar-year-month[data-quarter=\"2\"],\r\n.absol-chrome-calendar[data-level=\"quarter\"] .absol-chrome-calendar-years-content[data-hover-quarter=\"3\"] .absol-chrome-calendar-year-month[data-quarter=\"3\"] {\r\n background-color: rgb(224, 245, 256);\r\n}\r\n\r\n\r\n.absol-chrome-calendar-years:hover .absol-scrollbar {\r\n opacity: 1;\r\n\r\n}\r\n\r\n.absol-chrome-calendar-years .absol-scrollbar {\r\n background-color: rgba(169, 169, 172, 0.2);\r\n opacity: 0;\r\n transition: opacity 0.2s;\r\n}\r\n\r\n.absol-chrome-calendar-week-in-month > div.as-disabled,\r\n.absol-chrome-calendar-date-disabled,\r\n.absol-chrome-calendar-era-year.absol-chrome-calendar-date-disabled {\r\n color: rgb(240, 230, 230);\r\n pointer-events: none;\r\n cursor: not-allowed;\r\n}\r\n\r\nbutton.absol-chrome-calendar-button-disabled,\r\n.absol-chrome-calendar button:disabled {\r\n color: rgb(220, 210, 210);\r\n pointer-events: none;\r\n box-shadow: none;\r\n cursor: not-allowed;\r\n}\r\n\r\n.absol-chrome-calendar-era {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n z-index: 1000000;\r\n /*width: 100%;*/\r\n /*height: 100%; */\r\n width: calc(14em + 17px);\r\n box-sizing: border-box;\r\n height: 100%;\r\n background-color: white;\r\n box-shadow: 0px 0px 1px 0 black;\r\n overflow-y: scroll;\r\n overflow-x: hidden;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-chrome-calendar[data-view=\"era\"] .absol-chrome-calendar-era {\r\n display: block;\r\n}\r\n\r\n.absol-chrome-calendar[data-level=\"year\"] .absol-chrome-calendar-era {\r\n display: block;\r\n}\r\n\r\n.absol-chrome-calendar-era-row {\r\n width: 14em;\r\n height: 25%;\r\n white-space: nowrap;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-chrome-calendar-era-year {\r\n display: inline-block;\r\n vertical-align: top;\r\n height: 100%;\r\n width: 25%;\r\n text-align: center;\r\n line-height: 2.1em;\r\n font-size: inherit;\r\n color: rgb(140, 140, 140);\r\n}\r\n\r\n\r\n.absol-chrome-calendar-in-decade:not(.absol-chrome-calendar-date-disabled) {\r\n color: black;\r\n}\r\n\r\n/*.absol-chrome-calendar-era*/", ""]); /***/ }), /***/ 7767: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".ac-time-input.as-time-24-input {\r\n width: 13em;\r\n}\r\n\r\n.as-chrome-time-24-picker {\r\n --next-day-h24-width : 120px;\r\n --minute-width: 60px;\r\n font-size: 14px;\r\n\r\n}\r\n\r\n.as-chrome-time-24-picker .as-chrome-time-picker-h24 {\r\n width: var(--next-day-h24-width);\r\n}\r\n\r\n.as-chrome-time-24-picker .as-chrome-time-picker-list.as-chrome-time-picker-m60 {\r\n width: var(--minute-width);\r\n}\r\n\r\n.as-chrome-time-24-picker-tomorrow-text {\r\n display: none;\r\n}\r\n\r\n.as-in-tomorrow.as-chrome-time-picker-btn .as-chrome-time-24-picker-tomorrow-text {\r\n display: initial;\r\n}\r\n\r\n.as-chrome-time-24-picker .as-chrome-time-picker-btn:disabled {\r\n pointer-events: none;\r\n}", ""]); /***/ }), /***/ 5663: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-chrome-time-picker {\r\n box-sizing: border-box;\r\n vertical-align: top;\r\n display: inline-block;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n padding: 0.6em;\r\n border: solid 1px rgb(191, 191, 191);\r\n box-shadow: 1px 1px 2px rgb(240, 240, 240);\r\n z-index: 100;\r\n touch-action: manipulation;\r\n user-select: none;\r\n -webkit-user-select: none; /* Safari */\r\n -moz-user-select: none; /* Firefox */\r\n -ms-user-select: none;\r\n background-color: rgb(255, 255, 255);\r\n /*width: calc(160px + 1.2em);*/\r\n height: 12.38em;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-chrome-time-picker.as-24h-clock .as-chrome-time-picker-scroller-h12,\r\n.as-chrome-time-picker:not(.as-24h-clock) .as-chrome-time-picker-scroller-h24,\r\n.as-chrome-time-picker.as-24h-clock .as-chrome-time-picker-period {\r\n display: none;\r\n}\r\n\r\n.as-chrome-time-picker-period {\r\n padding-top: 1.43em;\r\n padding-bottom: 1.43em;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-chrome-time-picker > div:not(:first-child) {\r\n margin-left: 5px;\r\n}\r\n\r\n\r\n.as-chrome-time-picker-scroller {\r\n position: relative;\r\n padding-top: 1.43em;\r\n padding-bottom: 1.43em;\r\n display: inline-block;\r\n vertical-align: top;\r\n height: 100%;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-chrome-time-picker-scroller-up,\r\n.as-chrome-time-picker-scroller-down {\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n height: 1.43em;\r\n padding: 0;\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border-radius: 3px;\r\n border: none;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.as-chrome-time-picker-scroller-up > span,\r\n.as-chrome-time-picker-scroller-down > span {\r\n font-size: 1.5em;\r\n}\r\n\r\n.as-chrome-time-picker-scroller-up:hover,\r\n.as-chrome-time-picker-scroller-down:hover {\r\n background-color: rgba(169, 169, 169, 0.2);\r\n}\r\n\r\n.as-chrome-time-picker-scroller-up {\r\n top: -5px;\r\n}\r\n\r\n.as-chrome-time-picker-scroller-down {\r\n bottom: -5px;\r\n}\r\n\r\n\r\n.as-chrome-time-picker-viewport {\r\n width: 3.6em;\r\n height: 100%;\r\n overflow: hidden;\r\n white-space: normal;\r\n display: inline-block;\r\n vertical-align: top;\r\n}\r\n\r\n\r\n.as-chrome-time-picker-list.as-chrome-time-picker-m60,\r\n.as-chrome-time-picker-list.as-chrome-time-picker-h24 {\r\n width: 120px;\r\n overflow: hidden;\r\n position: relative;\r\n}\r\n\r\n.as-chrome-time-picker-list.as-chrome-time-picker-m60>button,\r\n.as-chrome-time-picker-list.as-chrome-time-picker-h24>button{\r\n display: block;\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n font-size: inherit;\r\n}\r\n\r\n.as-chrome-time-picker-list {\r\n height: 100%;\r\n overflow-y: scroll;\r\n width: calc(100% + 18px);\r\n}\r\n\r\n.as-chrome-time-picker-btn {\r\n font-size: inherit;\r\n height: 2em;\r\n width: 100%;\r\n padding: 0;\r\n border: none;\r\n background-color: transparent;\r\n color: black;\r\n}\r\n\r\n.as-chrome-time-picker-btn:disabled {\r\n color: #dddddd;\r\n}\r\n\r\n.as-chrome-time-picker-btn:hover {\r\n background-color: rgb(224, 245, 256);\r\n}\r\n\r\n.as-chrome-time-picker-btn.as-selected {\r\n background-color: rgb(188, 205, 236);\r\n border-radius: 3px;\r\n}\r\n\r\n.as-chrome-time-picker-btn > span {\r\n font-size: calc(16em / 14);\r\n}\r\n\r\n\r\n\r\n", ""]); /***/ }), /***/ 458: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-circle-section-label {\r\n position: relative;\r\n -webkit-print-color-adjust: exact;\r\n /*friendly print*/\r\n}\r\n\r\n.as-circle-section-label-text {\r\n position: relative;\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: 1em;\r\n padding-right: 2.5em;\r\n color: white;\r\n font-weight: bold;\r\n z-index: 2;\r\n}\r\n\r\n\r\n.as-circle-section-label-index {\r\n position: relative;\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-align: center;\r\n color: rgb(30, 162, 245);\r\n font-weight: 900;\r\n z-index: 2;\r\n}\r\n\r\n\r\n@media print {\r\n .as-circle-section-label-text {\r\n color: white !important;\r\n }\r\n\r\n .as-circle-section-label-index {\r\n color: rgb(30, 162, 245) !important;\r\n }\r\n}\r\n\r\n\r\n.as-circle-section-label-background {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n bottom: 0;\r\n z-index: 1;\r\n}\r\n\r\n.as-circle-section-label-background>svg {\r\n display: block;\r\n}\r\n\r\n.as-circle-section-label-index-box {\r\n stroke: rgb(129, 211, 246);\r\n fill: white;\r\n stroke-width: 2.5;\r\n}\r\n\r\n.as-circle-section-label-arrow {\r\n stroke: rgb(30, 162, 245);\r\n fill: none;\r\n stroke-linecap: round;\r\n}\r\n\r\n.as-circle-section-label-text-box {\r\n fill: rgb(30, 162, 245);\r\n stroke: none;\r\n}\r\n\r\n.as-circle-section-label-arrow-marker-path {\r\n fill: rgb(30, 162, 245);\r\n stroke: none;\r\n}", ""]); /***/ }), /***/ 8453: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".cke_panel {\r\n z-index: 1000000000 !important;\r\n}\r\n\r\n\r\nspan.cke_button_icon.cke_button__as-variable-box-ico_icon {\r\n background-size: cover;\r\n background-image: url(\"\");\r\n}\r\n\r\nspan.cke_button_icon.cke_button__as-expression-box-ico_icon {\r\n background-size: cover;\r\n background-image: url(\"\");\r\n}\r\n\r\nspan.cke_button_icon.cke_button__insert_video_icon {\r\n background-size: cover;\r\n background-image: url(\"\");\r\n}\r\n\r\n\r\ndiv.as-ck-inline-short-text {\r\n border: 1px solid #dddddd;\r\n height: 30px;\r\n line-height: 28px;\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n padding-left: var(--as-input-horizontal-padding);\r\n padding-right: var(--as-input-horizontal-padding);\r\n outline: none;\r\n overflow: hidden;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-ck-inline-short-text p {\r\n padding: 0;\r\n margin: 0;\r\n}\r\n\r\n.as-ck-inline-short-text p::after {\r\n content: \"\";\r\n}\r\n\r\n.as-ck-inline-short-text .cke_reset.cke_widget_drag_handler_container {\r\n visibility: hidden;\r\n opacity: 0;\r\n display: none;\r\n}\r\n\r\n.cke.cke_browser_webkit {\r\n z-index: 2000000 !important;\r\n}\r\n\r\n.cke.cke_browser_webkit.as-hidden {\r\n opacity: 0;\r\n visibility: hidden;\r\n pointer-events: none;\r\n}\r\n\r\n.cke.as-has-sticky-toolbar {\r\n border-top: none;\r\n}\r\n\r\n.cke.as-has-sticky-toolbar > .cke_inner > .cke_top {\r\n border-top: 1px solid #d1d1d1;\r\n z-index: 100;\r\n}\r\n\r\n\r\n.as-mdi-picker {\r\n background-color: white;\r\n border: 1px solid #dddddd;\r\n padding: 10px 0 10px 10px;\r\n min-width: 267px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-mdi-picker-body {\r\n max-height: 40vh;\r\n overflow-y: auto;\r\n margin-top: 10px;\r\n}\r\n\r\n.as-mdi-picker button {\r\n width: 30px;\r\n height: 30px;\r\n}\r\n", ""]); /***/ }), /***/ 790: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-form-cmd-tool-window .absol-onscreen-window-body-container {\r\n overflow-y: auto;\r\n}\r\n\r\n\r\n.as-from-tool-button:not(:disabled) > span.mdi-delete-variant {\r\n color: red;\r\n}\r\n\r\n.as-from-tool-button:disabled > span {\r\n color: #c4c4c4 !important;\r\n}\r\n\r\n.as-from-tool-button:disabled > svg > path {\r\n fill: #c4c4c4;\r\n}\r\n\r\n.as-form-cmd-tool .as-from-tool-ribbon-button,\r\n.bsc-white .as-form-cmd-tool .as-from-tool-ribbon-button,\r\n.as-form-cmd-tool .as-from-tool-ribbon-button {\r\n font-size: 12px;\r\n height: 2em;\r\n width: 3em;\r\n padding-right: 0.2em;\r\n /**override theme*/\r\n min-width: unset !important;\r\n white-space: nowrap;\r\n border: none !important;\r\n background-color: transparent;\r\n}\r\n\r\n.as-form-cmd-tool .as-ribbon-button,\r\n.as-form-cmd-tool .as-ribbon-split-button {\r\n font-size: 12px;\r\n width: 6.5em;\r\n vertical-align: top;\r\n}\r\n\r\n\r\n.as-form-cmd-tool .as-ribbon-button.as-checked.as-type-toggle-switch,\r\n.as-form-cmd-tool .as-ribbon-button.as-checked.as-type-color {\r\n -webkit-box-shadow: inset 0px 0px 2px 0px rgba(0, 0, 0, 0.6);\r\n box-shadow: inset 0px 0px 2px 0px rgba(0, 0, 0, 0.6);\r\n background-color: rgba(0, 0, 0, 0.05);\r\n color: #1e65ea;\r\n}\r\n\r\n\r\n.as-from-tool-group-buttons {\r\n margin-right: 2px;\r\n\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-from-tool-group-buttons .as-from-tool-group-buttons:not(:last-child) {\r\n border-right: 0.5px solid #ddd;\r\n}\r\n\r\n.as-from-tool-group-buttons .as-from-tool-group-buttons:not(:first-child) {\r\n border-left: 0.5px solid #ddd;\r\n}\r\n\r\n.absol-tooltip-root {\r\n z-index: 100;\r\n}\r\n\r\n.as-from-tool-group-buttons:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.as-form-cmd-tool-menu-trigger {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n color: #ddd;\r\n}\r\n\r\n.as-form-cmd-tool-window .absol-onscreen-window-head-bar-button-dock {\r\n display: none;\r\n}\r\n\r\n\r\n.as-form-cmd-tool-window .as-form-cmd-tool-menu-trigger {\r\n display: none;\r\n}\r\n\r\n.as-cmd-tool-group-x2 {\r\n display: inline-block;\r\n vertical-align: top;\r\n position: relative;\r\n}\r\n\r\n.as-cmd-tool-tab .as-cmd-tool-group-x2 {\r\n min-height: 60px;\r\n}\r\n\r\n\r\n.as-cmd-tool-group-x2::before {\r\n content: '';\r\n display: block;\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n left: -1px;\r\n border: 1px solid #ddd;\r\n}\r\n\r\n.as-cmd-tool-tab {\r\n overflow: hidden;\r\n}", ""]); /***/ }), /***/ 2043: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-collapsible-tree-navigator {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n border-bottom: 1px solid #aaaaaa;\r\n /*border-left: 1px solid #aaaaaa;*/\r\n user-select: none;\r\n padding-right: 4px;\r\n position: relative;\r\n box-sizing: border-box;\r\n --node-content-height: 30px;\r\n --level: 0;\r\n --selected-y: 0;\r\n}\r\n\r\n.as-collapsible-tree-navigator::after {\r\n content: \"\";\r\n position: absolute;\r\n transition: top 0.2s;\r\n top: var(--selected-y);\r\n height: var(--node-content-height);\r\n border-right: 4px solid rgb(20, 100, 246);\r\n right: 0;\r\n}\r\n\r\n\r\n.as-ctn-collapse-node {\r\n --children-height: 1000px;\r\n}\r\n\r\n\r\n.as-ctn-right > span.mdi {\r\n font-size: 20px;\r\n vertical-align: middle;\r\n transition: transform 0.2s ease-in-out;\r\n transform: rotate(0deg);\r\n visibility: hidden;\r\n display: inline-block;\r\n}\r\n\r\n.as-ctn-collapse-node.as-close .as-ctn-right > span.mdi-chevron-right {\r\n visibility: visible;\r\n}\r\n\r\n.as-ctn-collapse-node.as-open .as-ctn-right > span.mdi-chevron-right {\r\n visibility: visible;\r\n transform: rotate(90deg);\r\n}\r\n\r\n.as-ctn-collapse-node-content {\r\n height: calc(var(--node-content-height) + 1px);\r\n box-sizing: border-box;\r\n padding: 0 50px 0 8px;\r\n position: relative;\r\n background-color: rgb(240, 240, 242);\r\n border-top: 1px solid #aaaaaa;\r\n /*border-right: 1px solid #aaaaaa;*/\r\n}\r\n\r\n\r\n.as-ctn-collapse-node-content:hover::after,\r\n.as-ctn-node-content:hover::after {\r\n content: \"\";\r\n pointer-events: none;\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n height: 100%;\r\n z-index: 5;\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-ctn-collapse-node-content::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-ctn-collapse-node.as-open .as-ctn-collapse-node-children-ctn {\r\n /*max-height: calc(var(--children-height) + 1px);*/\r\n}\r\n\r\n\r\n.as-ctn-collapse-node.as-close .as-ctn-collapse-node-children-ctn,\r\n.as-ctn-node.as-close .as-ctn-node-children-ctn {\r\n /*max-height: 0;*/\r\n display: none;\r\n}\r\n\r\n\r\n.as-ctn-collapse-node-children-ctn,\r\n.as-ctn-node-children-ctn {\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.as-ctn-collapse-node.as-open .as-ctn-collapse-node-content,\r\n.as-ctn-collapse-node:not(:last-child) {\r\n /*border-bottom: 1px solid rgb(60, 60, 62);*/\r\n}\r\n\r\n.as-ctn-right {\r\n position: absolute;\r\n right: 10px;\r\n top: 0;\r\n height: 100%;\r\n}\r\n\r\n.as-ctn-right > button {\r\n width: 30px;\r\n height: 30px;\r\n\r\n}\r\n\r\n.as-ctn-right > button * {\r\n font-size: 20px;\r\n}\r\n\r\n\r\n.as-ctn-right::after {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-ctn-right > button:hover {\r\n background-color: var(--icon-background-cover-hover);\r\n\r\n}\r\n\r\n.as-ctn-text {\r\n margin-left: 7px;\r\n}\r\n\r\n.as-ctn-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.as-ctn-icon-ctn > * {\r\n font-size: 1.5em;\r\n}\r\n\r\n.as-ctn-icon-ctn > img,\r\n.as-ctn-icon-ctn > svg {\r\n width: 1em;\r\n height: 1em;\r\n}\r\n\r\n\r\n.as-ctn-text, .as-ctn-icon-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-ctn-count {\r\n font-size: 14px;\r\n box-sizing: border-box;\r\n text-align: center;\r\n display: inline-block;\r\n vertical-align: middle;\r\n background-color: rgb(113, 148, 169);\r\n line-height: 20px;\r\n min-width: 20px;\r\n padding-left: 5px;\r\n padding-right: 5px;\r\n height: 20px;\r\n border-radius: 10px;\r\n margin-left: 5px;\r\n color: white;\r\n}\r\n\r\n\r\n.as-ctn-node {\r\n position: relative;\r\n}\r\n\r\n\r\n.as-ctn-node-children-ctn:empty,\r\n.as-ctn-node-children-ctn:empty {\r\n display: none;\r\n}\r\n\r\n.as-ctn-node-children-ctn .as-ctn-node:first-child::before {\r\n top: -15px;\r\n height: 30px;\r\n}\r\n\r\n.as-ctn-node:not(:last-child)::before {\r\n height: 100%;\r\n}\r\n\r\n\r\n.as-ctn-node-content {\r\n position: relative;\r\n height: var(--node-content-height);\r\n padding-right: 10px;\r\n box-sizing: border-box;\r\n padding-left: calc(25px * var(--level) - 20px); /*5 is padding in level 0*/\r\n}\r\n\r\n\r\n.as-ctn-node-content::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-ctn-node-children-ctn {\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n\r\n.as-ctn-collapse-node.as-selected > .as-ctn-collapse-node-content .as-ctn-text,\r\n.as-ctn-node.as-selected > .as-ctn-node-content .as-ctn-text {\r\n text-shadow: 1px 0 0 currentColor;\r\n}\r\n\r\n\r\n.as-ctn-collapse-node-content .toggler-ico,\r\n.as-ctn-node-content .toggler-ico {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 1em;\r\n height: 1em;\r\n}\r\n\r\n.as-ctn-collapse-node-content .toggler-ico g,\r\n.as-ctn-node-content .toggler-ico g {\r\n visibility: hidden;\r\n}\r\n\r\n.as-ctn-collapse-node.as-open > .as-ctn-collapse-node-content .toggler-ico .toggle-open,\r\n.as-ctn-collapse-node.as-close > .as-ctn-collapse-node-content .toggler-ico .toggle-close,\r\n.as-ctn-node.as-open > .as-ctn-node-content .toggler-ico .toggle-open,\r\n.as-ctn-node.as-close > .as-ctn-node-content .toggler-ico .toggle-close {\r\n visibility: visible;\r\n}\r\n", ""]); /***/ }), /***/ 1294: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-color-picker-button {\r\n width: 45px;\r\n height: 30px;\r\n border-radius: 3px;\r\n border: 1px solid #d6d6d6;\r\n background-color: transparent;\r\n padding: 5px;\r\n outline: none;\r\n}\r\n\r\n.as-color-picker-button-inner {\r\n height: 100%;\r\n width: 100%;\r\n background-image: url('');\r\n background-size: 1.5em;\r\n image-rendering: optimizeSpeed;\r\n /* STOP SMOOTHING, GIVE ME SPEED */\r\n image-rendering: -moz-crisp-edges;\r\n /* Firefox */\r\n image-rendering: -o-crisp-edges;\r\n /* Opera */\r\n image-rendering: -webkit-optimize-contrast;\r\n /* Chrome (and eventually Safari) */\r\n image-rendering: pixelated;\r\n /* Chrome */\r\n image-rendering: optimize-contrast;\r\n /* CSS3 Proposed */\r\n -ms-interpolation-mode: nearest-neighbor;\r\n /* IE8+ */\r\n}\r\n\r\n.as-color-picker-button-inner-value {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-color-picker-button-fol {\r\n z-index: 1000;\r\n}\r\n\r\n.as-color-picker-button[data-mode=\"HEX6\"] .as-null .as-color-cell-value {\r\n display: none;\r\n}\r\n\r\n.as-color-picker-button.as-border-none{\r\n border: none;\r\n}\r\n\r\n.as-select-color-scheme-menu-dropdown {\r\n font-size: 14px;\r\n padding: 5px;\r\n}\r\n\r\n.as-select-color-scheme-menu {\r\n box-sizing: border-box;\r\n padding-right: 30px;\r\n padding-left: 5px;\r\n}\r\n\r\n.as-select-color-scheme-menu::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-select-color-scheme-menu-selected-item {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-select-color-scheme-menu-selected-item .as-scsm-item-cell {\r\n width: 20px;\r\n height: 20px;\r\n}\r\n\r\n.as-scsm-item-list-row {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-scsm-item-wrapper {\r\n display: inline-block;\r\n vertical-align: top;\r\n padding: 7px;\r\n}\r\n\r\n.as-scsm-item {\r\n\r\n border-radius: 4px;\r\n overflow: hidden;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-scsm-item-wrapper:hover .as-scsm-item:not(.as-selected) {\r\n box-shadow: 0px 0px 0px 2px rgba(107, 159, 255, 0.5);\r\n}\r\n\r\n.as-scsm-item.as-selected {\r\n box-shadow: 0px 0px 0px 2px #1464f6;\r\n}\r\n\r\n.as-scsm-item-row {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-scsm-item-cell {\r\n width: 1.2em;\r\n height: 1.2em;\r\n display: inline-block;\r\n vertical-align: top;\r\n}", ""]); /***/ }), /***/ 2974: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-text-input {\r\n border-style: solid;\r\n border-width: 1px;\r\n border-radius: var(--as-input-border-radius);\r\n border-color: var(--as-input-border-color);\r\n outline: none;\r\n height: var(--as-input-height);\r\n padding-left: var(--as-input-vertical-padding);\r\n font-size: inherit;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-text-input[readonly].as-border-none {\r\n border: none;\r\n padding-left: 0;\r\n padding-right: 0;\r\n}\r\n\r\ninput[type=\"text\"].as-text-input:disabled,\r\ntextarea.as-text-input:disabled {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n\r\n.as-blink-text {\r\n --blink-duration: 1s;\r\n --text-color: black;\r\n animation-name: as-anim-text-blink-1-1;\r\n animation-duration: var(--blink-duration);\r\n animation-iteration-count: infinite;\r\n}\r\n\r\n\r\n@keyframes as-anim-text-blink-1-1 {\r\n 0% {\r\n color: var(--text-color);\r\n }\r\n 49% {\r\n color: var(--text-color);\r\n }\r\n 50% {\r\n color: transparent;\r\n }\r\n 99% {\r\n color: transparent;\r\n }\r\n 100% {\r\n color: var(--text-color);\r\n }\r\n}\r\n\r\n.as-mti-star {\r\n font-family: 'Material Icons';\r\n color: #ffa834;\r\n font-size: var(--icon-font-size);\r\n -webkit-font-smoothing: antialiased;\r\n}\r\n\r\n.as-mti-star::before {\r\n content: \"star\";\r\n}\r\n\r\n.as-cursor-pointer {\r\n cursor: pointer;\r\n}\r\n\r\n\r\n.as-table-grid {\r\n display: table;\r\n}\r\n\r\n.as-table-grid.as-inline {\r\n display: inline-table;\r\n}\r\n\r\n.as-table-grid-row {\r\n display: table-row;\r\n}\r\n\r\n\r\n.as-table-grid-cell {\r\n display: table-cell;\r\n}\r\n\r\n\r\n.as-pseudo-align-child-center {\r\n text-align: center;\r\n}\r\n\r\n.as-pseudo-align-child-center::before {\r\n height: 100%;\r\n content: \"\";\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n.as-pseudo-align-child-center > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-transparent-button {\r\n background-color: transparent;\r\n border: none;\r\n padding: 0;\r\n margin: 0;\r\n font-size: inherit;\r\n color: var(--as-transparent-button-text-color);\r\n}\r\n\r\n.as-transparent-button:hover {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n\r\n.as-transparent-button:active {\r\n color: var(--as-transparent-button-text-active-color);\r\n}\r\n\r\n.as-transparent-button .mdi {\r\n font-size: 1.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-transparent-button > svg,\r\n.as-transparent-button > img {\r\n width: 1.5em;\r\n height: 1.5em;\r\n}\r\n\r\n\r\n.as-transparent-button.as-variant-danger {\r\n color: var(--variant-color-danger);\r\n}\r\n\r\n.as-transparent-button.as-variant-danger:hover {\r\n color: #c03542;\r\n}\r\n\r\n\r\n\r\n.as-transparent-button.as-variant-danger:active{\r\n color: #ef0d23;\r\n}\r\n\r\nbutton.as-transparent-button:disabled {\r\n color: #dddddd;\r\n}\r\n\r\n.as-section-text-n-line {\r\n position: relative;\r\n display: block;\r\n padding-bottom: 5px;\r\n}\r\n\r\n.as-section-text-n-line span {\r\n background-color: white;\r\n position: relative;\r\n z-index: 2;\r\n padding-right: 5px;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.as-section-text-n-line::after {\r\n content: \"\";\r\n position: absolute;\r\n z-index: 1;\r\n left: 0;\r\n right: 0;\r\n top: calc(50% - 1px);\r\n border-top: 1px solid #dddddd;\r\n}\r\n", ""]); /***/ }), /***/ 2652: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-compact-data-grid-editor {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n border: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n\r\n.as-cag-var-mng {\r\n padding: 10px;\r\n border-bottom: 1px solid #dddddd;\r\n background-color: #fefefe;\r\n}\r\n\r\n.as-cag-var {\r\n display: inline-block;\r\n padding: 5px 10px;\r\n background-color: #0a90eb;\r\n border-radius: 5px;\r\n\r\n color: white;\r\n cursor: move;\r\n user-select: none;\r\n}\r\n\r\n.as-cag-var::after {\r\n content: attr(data-default-title);\r\n font-weight: inherit;\r\n font-style: inherit;\r\n}\r\n\r\n.as-cag-var:not([data-default-title]) {\r\n display: none;\r\n}\r\n\r\n\r\n.as-cag-var.as-focus {\r\n box-shadow: 0px 0px 2px 2px rgba(255, 153, 0, 0.75);\r\n}\r\n\r\n/*.as-cag-var::before {*/\r\n/* content: \"[title]: \";*/\r\n/*}*/\r\n\r\n.as-cag-var[data-title]::before {\r\n content: attr(data-title) \": \";\r\n font-style: italic;\r\n\r\n}\r\n\r\n.as-cag-var[data-title=\"\"]::before {\r\n display: none;\r\n}\r\n\r\n.as-clone-var {\r\n box-shadow: 0px 0px 0px 4px rgba(70, 70, 90, 0.95) !important;\r\n background-color: rgba(255, 255, 255, 0.7);\r\n color: rgba(0, 0, 0, 0.7);\r\n}\r\n\r\n.as-cag-var-mng .as-cag-var {\r\n margin-bottom: 5px;\r\n}\r\n\r\n.as-cag-var:not(:last-child) {\r\n margin-right: 10px;\r\n}\r\n\r\n\r\n.as-cdg-table {\r\n margin: 15px;\r\n border-collapse: collapse;\r\n user-select: none;\r\n}\r\n\r\n.as-cdg-table > thead {\r\n background-color: #e3e2e2;\r\n}\r\n\r\n.as-cdg-table > thead.as-hidden {\r\n display: none;\r\n}\r\n\r\n.as-cdg-table > thead th {\r\n border-color: #aaaaaa;\r\n height: 40px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-cdg-table > thead pre{\r\n white-space: pre-wrap;\r\n font-family: inherit;\r\n outline: none;\r\n line-height: 1.5;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-cdg-table > thead pre:focus {\r\n background-color: rgba(255, 255, 255, 0.5);\r\n}\r\n\r\n.as-ca-cell:empty {\r\n padding: 10px 30px;\r\n text-align: center;\r\n}\r\n\r\n.as-cdg-table > tbody .as-ca-cell:empty::before {\r\n content: \"+\";\r\n font-size: 1.1em;\r\n color: #1da1ff;\r\n pointer-events: none;\r\n}\r\n\r\n.as-ca-cell {\r\n /*border: 1px dashed rgba(150, 150, 250, 0.3);*/\r\n border: 1px solid #dddddd;\r\n white-space: nowrap;\r\n padding: 5px 20px;\r\n position: relative;\r\n}\r\n\r\n.as-ca-cell.as-hovering,\r\n.as-ca-cell.as-hovering.as-selected {\r\n background-color: rgba(78, 246, 162, 0.15);\r\n}\r\n\r\n\r\n.as-ca-cell.as-selected {\r\n background-color: rgba(78, 222, 246, 0.25);\r\n}\r\n\r\n.as-ca-cell.as-drag-over::before {\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n display: block;\r\n border: 2px solid #ff922a;\r\n pointer-events: none;\r\n}\r\n\r\n.as-ca-cell.as-drag-over.as-bf {\r\n --hover-x: 20px;\r\n\r\n}\r\n\r\n.as-ca-cell.as-drag-over.as-bf::after {\r\n content: \"\";\r\n position: absolute;\r\n top: 4px;\r\n bottom: 4px;\r\n width: 6px;\r\n border-radius: 3px;\r\n background-color: #0a90eb;\r\n left: calc(var(--hover-x) - 8px);\r\n animation-name: as_ca_bf_blink;\r\n animation-duration: 0.5s;\r\n animation-iteration-count: infinite;\r\n}\r\n\r\n\r\n@keyframes as_ca_bf_blink {\r\n 0% {\r\n background-color: #0a90eb;\r\n }\r\n 50% {\r\n background-color: transparent;\r\n }\r\n 100% {\r\n background-color: #0a90eb;\r\n }\r\n}\r\n\r\n\r\n.as-cdg-variable-edit-dialog .as-table-grid-cell {\r\n padding: 5px 10px;\r\n}\r\n\r\n.as-cdg-variable-edit-dialog button {\r\n min-width: 100px;\r\n}\r\n\r\n\r\n.as-cdg-variable-edit-dialog input[type=\"text\"] {\r\n width: 200px;\r\n}\r\n\r\n\r\n.as-compact-data-grid-editor-body {\r\n overflow: auto;\r\n}\r\n\r\n.as-compact-data-grid-editor .as-table-of-text-input-tool .as-ribbon-button {\r\n width: 80px;\r\n}\r\n\r\n.as-compact-data-grid-editor .as-table-of-text-input-tool .as-ribbon-button svg {\r\n width: 24px;\r\n height: 24px;\r\n}\r\n\r\n.as-toggle-header-ico:not(.as-show-header) .as-icon-add {\r\n display: none;\r\n}\r\n\r\n.as-toggle-header-ico .as-icon-minus {\r\n stroke: red !important;\r\n}\r\n\r\n.as-toggle-header-ico.as-show-header .as-icon-minus,\r\n.as-toggle-header-ico.as-show-header .as-icon-add {\r\n stroke: blue !important;\r\n}", ""]); /***/ }), /***/ 8832: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-context-menu-hook {\r\n position: absolute;\r\n z-index: -100000;\r\n width: 14px;\r\n height: 14px;\r\n top: 0;\r\n opacity: 0;\r\n resize: none;\r\n cursor: default;\r\n}\r\n\r\n.absol-context-hinge-fixed-container {\r\n position: fixed;\r\n left: 0;\r\n top: 0;\r\n z-index: 1000000001;\r\n}\r\n\r\n.absol-context-hinge {\r\n position: relative;\r\n width: 0;\r\n height: 0;\r\n}\r\n\r\n.absol-context-hinge > .absol-context-menu {\r\n position: absolute;\r\n top: -10000px;\r\n left: -10000px;\r\n visibility: hidden;\r\n z-index: 1000000000;\r\n display: inline-block;\r\n}\r\n\r\n.absol-context-hinge .absol-vmenu,\r\n.absol-context-hinge .absol-hmenu {\r\n padding-top: 0.4em;\r\n padding-bottom: 0.4em;\r\n /* background-color: rgb(37, 37, 38);\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(7, 7, 7, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgb(7, 7, 7, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(7, 7, 7, 1); */\r\n color: black;\r\n background-color: rgb(252, 252, 255);\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n}\r\n\r\n.absol-context-menu-anchor.dark .absol-hmenu,\r\n.absol-context-menu-anchor.dark .absol-vmenu,\r\n.dark .absol-context-menu-anchor .absol-hmenu,\r\n.dark .absol-context-menu-anchor .absol-vmenu {\r\n background-color: rgb(37, 37, 38);\r\n}\r\n\r\n\r\n.absol-context-menu-anchor {\r\n position: fixed;\r\n z-index: -1000;\r\n left: 0;\r\n top: 0;\r\n display: block;\r\n opacity: 0;\r\n visibility: hidden;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-context-menu-anchor > textarea {\r\n width: 160px;\r\n height: 160px;\r\n margin: 0;\r\n resize: none;\r\n border: none;\r\n opacity: 0;\r\n cursor: default;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.absol-context-menu-anchor.absol-active {\r\n z-index: 1000000000 !important;\r\n opacity: 1;\r\n visibility: visible;\r\n}\r\n\r\n\r\n.absol-context-menu-anchor .absol-vmenu,\r\n.absol-context-menu-anchor .absol-hmenu {\r\n padding-top: 0.4em;\r\n padding-bottom: 0.4em;\r\n color: black;\r\n background-color: rgb(252, 252, 255);\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n}\r\n\r\n\r\n.absol-context-menu-anchor .absol-dropright > .absol-dropright-content {\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n}\r\n\r\n\r\n.as-system-context-menu {\r\n /** nothing here, to define use system context menu**/\r\n}\r\n\r\n.as-context-menu-ctn {\r\n font-size: var(--as-context-menu-font-size);\r\n font-family: var(--as-input-font-family);\r\n}\r\n\r\n.as-context-menu-ctn.as-anchor-modal,\r\n.absol-context-menu-anchor.as-anchor-modal {\r\n position: fixed;\r\n z-index: 800000000;\r\n left: 0 !important;\r\n right: 0 !important;;\r\n top: 0 !important;;\r\n bottom: 0 !important;;\r\n box-sizing: border-box;\r\n text-align: center;\r\n background-color: rgba(155, 155, 155, 0.3);\r\n}\r\n\r\n.as-context-menu-ctn.as-anchor-modal::before,\r\n.as-context-menu-ctn.as-anchor-modal > .absol-vmenu,\r\n.absol-context-menu-anchor.as-anchor-modal::before,\r\n.absol-context-menu-anchor.as-anchor-modal > .absol-vmenu {\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-context-menu-ctn.as-anchor-modal > .absol-vmenu,\r\n.absol-context-menu-anchor.as-anchor-modal > .absol-vmenu {\r\n text-align: left;\r\n}\r\n\r\n\r\n.as-context-menu-ctn.as-anchor-modal::before,\r\n.absol-context-menu-anchor.as-anchor-modal::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-context-menu-ctn.as-anchor-modal > .absol-vmenu,\r\n.absol-context-menu-anchor.as-anchor-modal > .absol-vmenu {\r\n min-width: 70%;\r\n max-width: calc(100% - 10px);\r\n max-height: calc(100% - 10px);\r\n}\r\n\r\n.as-quick-menu {\r\n font-size: 1rem;\r\n}\r\n\r\n.as-quick-menu {\r\n --available-height: calc(100vh - 20px);\r\n max-height: var(--available-height);\r\n}\r\n\r\n.absol-context-menu-anchor.as-anchor-modal .as-quick-menu {\r\n max-height: calc(100vh - 20px);\r\n}", ""]); /***/ }), /***/ 3637: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-countdown-clock {\r\n width: 7em;\r\n height: 7em;\r\n border-radius: 50%;\r\n position: relative;\r\n display:inline-block;\r\n font-family: Consolas;\r\n}\r\n\r\n.as-countdown-clock-border-wrapper{\r\n pointer-events:none;\r\n position: absolute;\r\n box-sizing: border-box;\r\n left: 0.2em;\r\n right: 0.2em;\r\n top: 0.2em;\r\n bottom: 0.2em;\r\n filter: drop-shadow(0 0px 1px rgb(100, 200, 255));\r\n}\r\n\r\n.as-countdown-clock-border {\r\n width: 100%;\r\n height: 100%;\r\n border: solid 0.2em rgb(100, 200, 255);\r\n border-radius: 50%;\r\n object-fit: cover;\r\n}\r\n\r\n.as-countdown-clock-text {\r\n position: absolute;\r\n left: 50%;\r\n top: 50%;\r\n transform:translate(-50%, -50%);\r\n font-size: 2em;\r\n}\r\n\r\n.as-countdown-clock div,\r\n.as-countdown-clock span\r\n{\r\n font-family: inherit;\r\n}", ""]); /***/ }), /***/ 1535: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-countdown-text {\r\n\r\n}\r\n", ""]); /***/ }), /***/ 875: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-cpu-viewer{\r\n position: fixed;\r\n bottom: 5px;\r\n right: 5px;\r\n box-sizing: border-box;\r\n z-index: 1000000000;\r\n border: 1px solid black;\r\n display: inline-block;\r\n}\r\n\r\n.as-cpu-viewer canvas{\r\n display: block;\r\n}\r\n\r\n.as-pending-attachhook-count{\r\n padding: 10px;\r\n border-radius: 4px;\r\n position: fixed;\r\n z-index: 1000000;\r\n right: 10px;\r\n top: 10px;\r\n background: white;\r\n border: 1px solid red;\r\n opacity: 0.5;\r\n pointer-events: none;\r\n}\r\n\r\n.as-pending-attachhook-count:hover {\r\n opacity: 0.0;\r\n}", ""]); /***/ }), /***/ 9008: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-date-input {\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n border: 1px solid #ddd;\r\n border-radius: 3px;\r\n height: calc(2em + 2px);\r\n width: 10.5em;\r\n box-sizing: border-box;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n background-color: white;\r\n overflow: hidden;\r\n}\r\n\r\n.as-date-input[data-format] {\r\n --format-width: 8.5em;\r\n width: calc(var(--format-width) + 2em + 1em);\r\n}\r\n\r\n.as-date-input-text {\r\n outline: none;\r\n width: calc(100% - 29px);\r\n height: 100%;\r\n border: none;\r\n background-color: transparent;\r\n display: block;\r\n padding: 0 0 0 var(--as-input-horizontal-padding);\r\n font: inherit;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.as-date-input-icon-ctn {\r\n font-size: inherit;\r\n border-left: 1px solid #ddd;\r\n border-right: none;\r\n border-top: none;\r\n border-bottom: none;\r\n text-align: center;\r\n position: absolute;\r\n right: 0;\r\n width: calc(2em + 1px);\r\n box-sizing: border-box;\r\n top: 0;\r\n height: 100%;\r\n background-color: rgba(169, 169, 169, 0.1);\r\n cursor: pointer;\r\n color: black;\r\n padding: 0;\r\n}\r\n\r\n\r\n.as-date-input-icon-ctn:hover {\r\n background-color: rgba(169, 169, 169, 0.25);\r\n}\r\n\r\n.as-date-input-icon-ctn:active {\r\n background-color: rgba(169, 169, 169, 0.5);\r\n}\r\n\r\n\r\n.as-date-input-icon-ctn > span {\r\n line-height: 28px;\r\n font-size: calc(16em / 14);\r\n display: inline-block;\r\n padding: 0;\r\n}\r\n\r\n.as-date-input.as-read-only .as-date-input-icon-ctn {\r\n pointer-events: none;\r\n}\r\n\r\n.as-date-input.as-disabled {\r\n color: var(--as-disabled-text-color);\r\n pointer-events: none;\r\n}\r\n\r\n.as-date-input.as-disabled input {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-date-input.as-value-null .as-date-input-clear-btn,\r\n.as-date-input.as-must-not-null .as-date-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n.as-date-input-clear-btn {\r\n font-size: inherit;\r\n position: absolute;\r\n right: 2em;\r\n height: 2em;\r\n padding: 0 0.3em;\r\n top: calc(50% - 1em);\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border: none;\r\n color: #bbb;\r\n visibility: hidden;\r\n}\r\n\r\n.as-date-input.as-read-only .as-date-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n.as-date-input-clear-btn:hover {\r\n color: rgb(132, 132, 132)\r\n}\r\n\r\n.as-date-input-clear-btn:active {\r\n color: #525555;\r\n}\r\n\r\n.as-date-input-text:focus + .as-date-input-clear-btn,\r\n.as-date-input:hover .as-date-input-clear-btn {\r\n visibility: visible;\r\n}\r\n\r\n.as-date-input.as-border-none {\r\n border: transparent;\r\n background-color: transparent;\r\n}\r\n\r\n.as-date-input.as-border-none .as-date-input-icon-ctn {\r\n display: none;\r\n}\r\n\r\n.as-date-input.as-border-none .as-date-input-text {\r\n width: 100%;\r\n padding-left: 0;\r\n}\r\n\r\n.as-date-n-level-input {\r\n white-space: nowrap;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n width: 13.5em;\r\n height: calc(2em + 2px);\r\n}\r\n\r\n.as-date-n-level-input .as-date-input {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-date-n-level-input-select-level {\r\n position: absolute;\r\n left: 1px;\r\n top: 1px;\r\n width: 2em;\r\n height: 2em;\r\n padding: 0;\r\n}\r\n\r\n\r\n.as-date-n-level-input.as-disabled .as-date-n-level-input-select-level {\r\n opacity: 0.5;\r\n pointer-events: none;\r\n}\r\n\r\n.as-date-n-level-input.as-read-only .as-date-n-level-input-select-level {\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-date-n-level-input .as-date-input-text {\r\n padding-left: calc(var(--as-input-horizontal-padding) + 2em);\r\n width: calc(100% - 2em - 1px);\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-date-n-level-input.as-border-none.as-read-only .as-date-input {\r\n border: none;\r\n}\r\n\r\n\r\n.as-date-n-level-input.as-border-none.as-read-only .as-date-input-text {\r\n width: 100%;\r\n text-align: left;\r\n padding-left: 0;\r\n}\r\n.as-date-n-level-input.as-border-none.as-read-only button {\r\n display: none;\r\n}\r\n", ""]); /***/ }), /***/ 7256: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-date-in-year-follower {\r\n z-index: 900000000;\r\n}\r\n\r\n.as-date-in-year-picker {\r\n font-size: 1rem;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n /*width: 20em;*/\r\n box-sizing: border-box;\r\n border: 1px solid #dddddd;\r\n display: inline-block;\r\n padding: calc(10em / 14) calc(5rem / 14);\r\n box-shadow: 1px 1px 2px rgb(240, 240, 240);\r\n background-color: white;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-table {\r\n display: table;\r\n}\r\n\r\n.as-date-in-year-picker-row {\r\n display: table-row;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-row:first-child {\r\n text-align: center;\r\n line-height: 1.5;\r\n}\r\n\r\n.as-date-in-year-picker-cell {\r\n display: table-cell;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-cell:first-child {\r\n padding-right: 10px;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-month-col {\r\n position: relative;\r\n padding-top: calc(25em / 14);\r\n padding-bottom: calc(25em / 14);\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-date-in-year-picker-month-viewport {\r\n width: calc(50em / 14);\r\n overflow: hidden;\r\n\r\n}\r\n\r\n.as-date-in-year-picker-month-scroller {\r\n width: calc(100% + 17px);\r\n height: 8em;\r\n overflow-y: scroll;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\nbutton.as-date-in-year-picker-month {\r\n font-size: inherit;\r\n height: 2em;\r\n width: calc(50em / 14);\r\n padding: 0;\r\n border: none;\r\n background-color: transparent;\r\n}\r\n\r\nbutton.as-date-in-year-picker-month:hover {\r\n background-color: rgb(224, 245, 256);\r\n}\r\n\r\nbutton.as-date-in-year-picker-month.as-selected {\r\n background-color: rgb(188, 205, 236);\r\n border-radius: 3px;\r\n}\r\n\r\nbutton.as-date-in-year-picker-month > span {\r\n font-size: calc(16rem / 14);\r\n}\r\n\r\n\r\n.as-chrome-time-picker-scroller-up:hover,\r\n.as-chrome-time-picker-scroller-down:hover {\r\n background-color: rgba(169, 169, 169, 0.2);\r\n}\r\n\r\n\r\n.as-date-in-year-picker-month-btn {\r\n position: absolute;\r\n left: 0;\r\n font-size: inherit;\r\n height: calc(20em / 14);\r\n width: calc(50em / 14);\r\n padding: 0;\r\n border: none;\r\n background-color: transparent;\r\n box-sizing: border-box;\r\n border-radius: 3px;\r\n}\r\n\r\n.as-date-in-year-picker-month-btn.as-up {\r\n top: 0;\r\n}\r\n\r\n.as-date-in-year-picker-month-btn.as-down {\r\n bottom: 0;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-month-btn:hover {\r\n background-color: rgba(169, 169, 169, 0.2);\r\n}\r\n\r\n.as-date-in-year-picker-month-btn > span {\r\n font-size: 1.5em;\r\n user-select: none;\r\n -moz-user-select: none;\r\n -webkit-user-select: none;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-days {\r\n display: inline-table;\r\n vertical-align: middle;\r\n border: solid 1px rgb(190, 190, 190);\r\n}\r\n\r\n.as-date-in-year-picker-week {\r\n display: table-row;\r\n}\r\n\r\n.as-date-in-year-picker-day {\r\n display: table-cell;\r\n text-align: right;\r\n padding: calc(5em / 14);\r\n line-height: calc(20em / 14);\r\n font-size: inherit;\r\n user-select: none;\r\n -moz-user-select: none;\r\n -webkit-user-select: none;\r\n}\r\n\r\n\r\n.as-date-in-year-picker-day:hover {\r\n background-color: rgb(224, 245, 256);\r\n cursor: default;\r\n}\r\n\r\n.as-date-in-year-picker-day.as-selected {\r\n background-color: rgb(188, 205, 236);\r\n}\r\n\r\n\r\n.as-date-time-input.as-date-in-year-input {\r\n width: calc(8em + 2px);\r\n}\r\n\r\n.as-date-in-year-input.as-must-not-null .as-time-input-clear-btn,\r\n.as-date-in-year-input.as-empty .as-time-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n\r\n.as-date-in-year-follower {\r\n z-index: 1000000;\r\n}", ""]); /***/ }), /***/ 3892: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-date-time-input {\r\n border: 1px solid #ddd;\r\n border-radius: 3px;\r\n height: calc(2em + 2px);\r\n width: calc(14em + 2px);\r\n box-sizing: border-box;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n background-color: white;\r\n overflow: hidden;\r\n}\r\n\r\n.as-date-time-input.as-disabled {\r\n color: var(--as-disabled-text-color);\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-date-time-input input {\r\n font-size: inherit;\r\n outline: none;\r\n width: calc(100% - 2em - 1px);\r\n height: 100%;\r\n border: none;\r\n display: block;\r\n padding: 0 0 0 var(--as-input-horizontal-padding);\r\n -webkit-user-select: auto;\r\n user-select: auto;\r\n -webkit-user-drag: none;\r\n color: inherit;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-date-time-input.as-disabled input {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-date-time-input-icon-btn {\r\n border-right: none;\r\n border-top: none;\r\n border-bottom: none;\r\n border-left: 1px solid #ddd;\r\n position: absolute;\r\n right: 0;\r\n width: calc(2em + 1px);\r\n box-sizing: border-box;\r\n top: 0;\r\n bottom: 0;\r\n background-color: rgba(169, 169, 169, 0.1);\r\n cursor: pointer;\r\n border-radius: 0;\r\n color: inherit;\r\n font-size: inherit;\r\n padding: 0;\r\n}\r\n\r\n.as-date-time-input-icon-btn > span {\r\n font-size: calc(16em / 14);\r\n}\r\n\r\n\r\n.as-date-time-input-icon-btn:hover {\r\n background-color: rgba(169, 169, 169, 0.25);\r\n}\r\n\r\n.as-date-time-input-icon-btn:active {\r\n background-color: rgba(169, 169, 169, 0.5);\r\n}\r\n\r\n\r\n.as-date-time-input-icon-btn.as-disabled {\r\n color: rgb(102, 102, 102);\r\n pointer-events: none;\r\n}\r\n\r\n.as-date-time-input-follower {\r\n box-sizing: border-box;\r\n background-color: white;\r\n border: 1px solid #ddd;\r\n padding: 5px;\r\n}\r\n\r\n.as-date-time-input-date-picker {\r\n border: none;\r\n box-shadow: none;\r\n}\r\n\r\n.as-date-time-input-picker-header {\r\n text-align: right;\r\n padding-bottom: 5px;\r\n}\r\n\r\n\r\n.as-date-time-input-picker-btn {\r\n height: 20px;\r\n min-width: 25px;\r\n padding: 0 5px;\r\n box-sizing: border-box;\r\n font-size: inherit;\r\n border: 1px solid rgb(47, 82, 143);\r\n background-color: rgb(68, 144, 196);\r\n color: white;\r\n border-radius: 0;\r\n}\r\n\r\n.as-date-time-input-picker-btn:active {\r\n background-color: rgb(50, 122, 169);\r\n}\r\n\r\n\r\n.as-chrome-time-picker.as-date-time-input-time-picker {\r\n height: 11.8em;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-date-time-input-picker-ctn {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-date-time-input-picker-ctn > div {\r\n display: inline-block;\r\n white-space: initial;\r\n vertical-align: top;\r\n}\r\n\r\n.as-date-time-input-follower > div {\r\n border-color: white;\r\n}\r\n\r\n.as-date-time-input:hover .as-time-input-clear-btn {\r\n visibility: visible;\r\n}\r\n\r\n.as-date-time-input.as-must-not-null .as-time-input-clear-btn,\r\n.as-date-time-input.as-read-only .as-time-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n\r\n.as-date-time-input.as-read-only .as-date-time-input-icon-btn {\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-date-time-input.as-border-none {\r\n border: none;\r\n}\r\n\r\n\r\n.as-date-time-input.as-border-none .as-date-time-input-icon-btn {\r\n display: none;\r\n}\r\n\r\n.as-date-time-input.as-border-none input {\r\n width: 100%;\r\n padding-left: 0;\r\n}\r\n\r\n.as-date-time-input[data-text].as-read-only.as-border-none input {\r\n display: none;\r\n}\r\n\r\n\r\n.as-date-time-input[data-text].as-read-only.as-border-none {\r\n width: auto;\r\n}\r\n\r\n.as-date-time-input[data-text].as-read-only.as-border-none::before {\r\n content: attr(data-text);\r\n line-height: 30px;\r\n}\r\n\r\n\r\n.as-relative-time-text[data-time-text]::after {\r\n content: attr(data-time-text);\r\n}", ""]); /***/ }), /***/ 1097: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-debug-task {\r\n position: fixed;\r\n right: 10px;\r\n bottom: 10px;\r\n z-index: 999999;\r\n border-radius: 4px;\r\n background: rgba(169, 169, 171, 0.3);\r\n border: solid 1px rgba(21, 21, 214, 0.5);\r\n min-width: 45px;\r\n min-height: 30px;\r\n font-size: 12px;\r\n padding: 5px;\r\n pointer-events: none;\r\n}\r\n\r\n.absol-debug-task-name {\r\n color: darkcyan;\r\n}\r\n\r\n.absol-debug-task-value {\r\n color: rgb(159, 8, 197);\r\n}\r\n\r\n.as-debug-device-info {\r\n position: fixed;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n height: 100%;\r\n z-index: 999999;\r\n display: grid;\r\n grid-template-rows: auto 1fr;\r\n background: white;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n}\r\n\r\n.as-debug-device-info .as-header-bar-notification-action {\r\n display: none;\r\n}\r\n\r\n.as-debug-device-info-header {\r\n\r\n}\r\n\r\n.as-debug-device-info-body {\r\n overflow: auto;\r\n}\r\n\r\n\r\n.as-debug-device-info-content {\r\n align-content: start;\r\n padding: 10px;\r\n display: grid;\r\n grid-template-columns: auto auto;\r\n column-gap: 20px;\r\n row-gap: 10px;\r\n overflow: auto;\r\n}\r\n\r\n.as-debug-device-info-section {\r\n grid-column: span 2;\r\n font-weight: bold;\r\n}", ""]); /***/ }), /***/ 3486: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --as-input-height: calc(2rem + 2px);\r\n --as-input-font-size: 1rem;\r\n --as-input-font-family: Arial, Helvetica, sans-serif;\r\n --as-input-vertical-padding: 0.3571em;\r\n --as-input-horizontal-padding: 0.5em;\r\n --as-input-border-color: #ddd;\r\n --as-input-border-radius: 3px;\r\n --as-context-menu-font-size: 1rem;\r\n --as-context-font-family: Arial, Helvetica, sans-serif;\r\n --as-disabled-background-color: #ebebe4;\r\n --as-disabled-text-color: rgb(102, 102, 102);\r\n --icon-background-cover-hover: #91e4fb;\r\n --as-transparent-button-hover-color: rgba(169, 169, 172, 0.25);\r\n --as-transparent-button-focus-color: rgba(20, 185, 235, 0.3);\r\n --as-transparent-button-active-color: rgba(169, 169, 172, 0.2);\r\n --as-transparent-button-text-color: rgb(139, 139, 140);\r\n --as-transparent-button-text-hover-color: rgb(107, 107, 107);\r\n --as-transparent-button-text-active-color: rgb(0, 0, 0);\r\n\r\n --as-list-item-hover-background-color: #efefef;\r\n --as-list-item-selected-background-color: #dfdfdf;\r\n\r\n\r\n --modal-margin-top: 10vh;\r\n --icon-font-size: 1.42857142857rem;\r\n}\r\n\r\n", ""]); /***/ }), /***/ 4001: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-draggable-stack {\r\n position: relative;\r\n}\r\n\r\n.absol-draggable-stack .drag-zone {\r\n touch-action: none;\r\n}\r\n\r\n.absol-draggable-stack > .as-dragging {\r\n opacity: 0.2 !important;\r\n}\r\n\r\n.absol-draggable-stack-child-container.as-dragging {\r\n opacity: 0.2 !important;\r\n}\r\n\r\n.absol-draggable-stack-clone-container {\r\n position: fixed;\r\n left: 0;\r\n top: 0;\r\n z-index: 100000;\r\n user-select: none;\r\n -moz-user-select: none;\r\n -webkit-user-select: none;\r\n -ms-user-select: none;\r\n pointer-events: all;\r\n opacity: 0.5;\r\n background: white;\r\n}\r\n\r\n.absol-draggable-vstack > .absol-draggable-stack-clone-container {\r\n left: 0;\r\n right: 0;\r\n\r\n}\r\n\r\n.absol-draggable-stack-clone-container * {\r\n pointer-events: none !important;\r\n}\r\n\r\n.absol-draggable-stack-clone-container > * {\r\n width: 100% !important;\r\n height: 100% !important;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.absol-draggable-stack-clone-container.home-going {\r\n transition: top 0.2s;\r\n}\r\n\r\n.absol-draggable-stack-dest-line {\r\n position: absolute;\r\n z-index: 99;\r\n box-sizing: content-box;\r\n}\r\n\r\n.absol-draggable-vstack > .absol-draggable-stack-dest-line {\r\n transition: top 0.1s;\r\n left: 0;\r\n right: 0;\r\n border-top: solid 3px rgb(74, 174, 233);\r\n border-bottom: solid 3px rgb(74, 174, 233);\r\n}\r\n\r\n\r\n.absol-draggable-hstack {\r\n --dest-x: 0px;\r\n}\r\n\r\n.absol-draggable-hstack.as-has-dragging::after {\r\n content: \"\";\r\n position: absolute;\r\n transition: left 0.1s;\r\n top: 0;\r\n bottom: 0;\r\n left: calc(var(--dest-x) - 3px);\r\n border-left: solid 3px rgb(74, 174, 233);\r\n border-right: solid 3px rgb(74, 174, 233);\r\n}\r\n\r\n.absol-draggable-hstack.as-no-change::after {\r\n visibility: hidden;\r\n}\r\n\r\n\r\n.absol-draggable-hstack > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.absol-draggable-vstack {\r\n --dest-y: unset;\r\n}\r\n\r\n/**.as-state-drag*/\r\n.absol-draggable-vstack.as-state-drag::after {\r\n content: \"\";\r\n display: block;\r\n position: absolute;\r\n top: calc(var(--dest-y) - 3px);\r\n left: 0;\r\n right: 0;\r\n transition: top 0.1s;\r\n border-top: solid 3px rgb(74, 174, 233);\r\n border-bottom: solid 3px rgb(74, 174, 233);\r\n z-index: 999;\r\n}\r\n\r\n\r\n.absol-draggable-vstack.as-state-no-change::after {\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 6083: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n/**********************************************************************************************************************/\r\ndiv.as-dropdown-box-common-style {\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n border: solid 1px rgb(100, 100, 255);\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n background-color: white;\r\n}\r\n\r\n.as-dropdown-box-footer {\r\n height: calc(2em + 1px);\r\n border-top: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n padding-left: 0.35em;\r\n white-space: nowrap;\r\n position: relative;\r\n}\r\n\r\n\r\n.as-dropdown-box-footer > *,\r\n.as-dropdown-box-footer::before,\r\n.as-dropdown-box-footer-right::before,\r\n.as-dropdown-box-footer-right > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-dropdown-box-footer-right::before,\r\n.as-dropdown-box-footer::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-dropdown-box-footer > *:not(:last-child) {\r\n margin-right: 6.5em;\r\n}\r\n\r\n.as-dropdown-box-footer .absol-checkbox-label.as-right {\r\n padding-left: 0.35em;\r\n}\r\n\r\n.as-dropdown-box-footer-right {\r\n position: absolute;\r\n right: 10px;\r\n top: 0;\r\n height: 100%;\r\n}\r\n\r\n.as-dropdown-box-footer a {\r\n cursor: pointer;\r\n margin-left: 30px;\r\n}\r\n\r\n.as-dropdown-box-footer a:hover {\r\n color: #1da1ff;\r\n}\r\n\r\n.as-dropdown-box-footer a.as-select-list-box-cancel-btn {\r\n color: #888888;\r\n}\r\n\r\n.as-dropdown-box-footer a.as-select-list-box-close-btn {\r\n padding: 0 10px;\r\n}\r\n\r\n.as-dropdown-box-footer a.as-select-list-box-cancel-btn:hover {\r\n color: #ea2121;\r\n}\r\n\r\n/********** MOBILE ***************/\r\n\r\n.am-modal.am-dropdown-box-modal{\r\n z-index: 100001000;\r\n}\r\n\r\n.am-dropdown-box {\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n max-width: 95vw;\r\n}\r\n\r\n.am-dropdown-box.as-enable-search .absol-search-text-input,\r\n.am-dropdown-box-modal.as-enable-search .absol-search-text-input\r\n{\r\n visibility: visible;\r\n}\r\n\r\n.am-dropdown-box-header {\r\n height: calc(2em + 10px);\r\n display: block;\r\n white-space: nowrap;\r\n box-sizing: border-box;\r\n padding-top: 5px;\r\n padding-bottom: 5px;\r\n padding-left: 10px;\r\n border-bottom: solid 1px #dddddd;\r\n}\r\n\r\n.am-dropdown-box-header .absol-search-text-input {\r\n display: inline-block;\r\n width: calc(100% - 2em - 18px);\r\n vertical-align: middle;\r\n box-sizing: border-box;\r\n background-color: white;\r\n visibility: hidden;\r\n}\r\n\r\n.am-dropdown-box-close-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n border-radius: 50%;\r\n padding: 0;\r\n height: 2em;\r\n width: 2em;\r\n font-size: inherit;\r\n border: none;\r\n outline: none;\r\n margin-left: 10px;\r\n background-color: rgb(255, 255, 255);\r\n color: #7a7a7a;\r\n white-space: nowrap;\r\n}\r\n\r\n.am-dropdown-box-close-btn span {\r\n font-size: 1.5em;\r\n}\r\n\r\n.am-dropdown-box-close-btn:active {\r\n background-color: rgba(169, 169, 172, 0.3);\r\n}\r\n\r\n.am-dropdown-box-item {\r\n border-bottom: 1px solid #efefef;\r\n}\r\n", ""]); /***/ }), /***/ 9366: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.absol-drop-panel-head {\r\n height: 2.75em;\r\n line-height: 2.75em;\r\n -webkit-box-shadow: 0px 3px 4px -3px rgba(0, 0, 0, 0.75);\r\n -moz-box-shadow: 0px 3px 4px -3px rgba(0, 0, 0, 0.75);\r\n box-shadow: 0px 3px 4px -3px rgba(0, 0, 0, 0.75);\r\n background-color: rgba(240, 240, 242);\r\n color: black;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.absol-drop-panel-head .toggler-ico path {\r\n fill: rgb(104, 104, 104);\r\n}\r\n\r\n\r\n.dark .absol-drop-panel-head {\r\n background-color: rgba(54, 54, 56);\r\n color: rgb(204, 204, 204);\r\n}\r\n\r\n.absol-drop-panel.show .absol-drop-panel-body {\r\n height:auto;\r\n}\r\n\r\n.absol-drop-panel-body {\r\n transition: height 0.2s;\r\n height: 0;\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n}\r\n\r\n\r\n.absol-drop-panel.show>.absol-drop-panel-head .toggle-close{\r\n display: none;\r\n}\r\n\r\n.absol-drop-panel:not(.show)>.absol-drop-panel-head .toggle-open{\r\n display: none;\r\n}\r\n\r\n", ""]); /***/ }), /***/ 4517: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-drop-zone {\r\n}", ""]); /***/ }), /***/ 7008: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".am-dual-select-box {\r\n\r\n}\r\n\r\n\r\n.am-dual-select-box .absol-selectlist-item span {\r\n white-space: normal;\r\n display: inline-block;\r\n margin-right: 0;\r\n line-height: calc(30rem / 14);\r\n}\r\n\r\n.am-mobile-theme.bsc-white .am-dual-select-box .absol-selectlist-item span{\r\n line-height: calc(30rem / 14);\r\n}\r\n\r\n.am-dual-select-box .absol-selectlist-item {\r\n height: auto;\r\n}\r\n\r\n.am-mobile-theme.bsc-white .am-dual-select-box .absol-selectlist-item {\r\n height: auto;\r\n}\r\n\r\n.am-dual-select-box .absol-selectlist-item:not(:last-child) {\r\n border-bottom: 1px solid #efefef;\r\n}", ""]); /***/ }), /***/ 522: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-dual-select-box {\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n --max-height: 70vh;\r\n box-sizing: border-box;\r\n --dual-list-estimate-width: 0;\r\n width: var(--dual-list-estimate-width);\r\n z-index: 10000000;\r\n background-color: white;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n\r\n}\r\n\r\n.as-dual-select-box-search-ctn {\r\n padding: 5px;\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n}\r\n\r\n.as-dual-select-box.as-enable-search.as-anchor-6 .as-dual-select-box-search-ctn,\r\n.as-dual-select-box.as-enable-search.as-anchor-5 .as-dual-select-box-search-ctn {\r\n bottom: 0;\r\n}\r\n\r\n.as-dual-select-box.as-enable-search.as-anchor-6,\r\n.as-dual-select-box.as-enable-search.as-anchor-5 {\r\n padding-bottom: calc(2rem + 10px);\r\n}\r\n\r\n.as-dual-select-box.as-enable-search.as-anchor-1,\r\n.as-dual-select-box.as-enable-search.as-anchor-2 {\r\n padding-top: calc(2rem + 10px);\r\n}\r\n\r\n.as-dual-select-box.as-enable-search.as-anchor-1 .as-dual-select-box-search-ctn,\r\n.as-dual-select-box.as-enable-search.as-anchor-2 .as-dual-select-box-search-ctn {\r\n top: 0;\r\n}\r\n\r\n\r\n.as-dual-select-box-list-ctn {\r\n white-space: nowrap;\r\n display: flex;\r\n align-items: stretch;\r\n}\r\n\r\n.as-dual-select-box:not(.as-enable-search) .as-dual-select-box-search-ctn {\r\n display: none;\r\n}\r\n\r\n.as-dual-select-box-list {\r\n display: inline-block;\r\n vertical-align: top;\r\n max-height: calc(var(--max-height) - 2em - 2em - 11px);\r\n overflow-y: auto;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-dual-select-box.as-enable-search .as-dual-select-box-list {\r\n max-height: calc(var(--max-height) - 6rem - 11px);\r\n}\r\n\r\n.as-dual-select-box-arrow-ctn {\r\n display: inline-block;\r\n vertical-align: top;\r\n}\r\n\r\n.as-dual-select-box-arrow-ctn::before,\r\n.as-dual-select-box-arrow-ctn span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-dual-select-box-arrow-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n\r\n.as-dual-select-box-list:first-child {\r\n border-right: solid 1px #dddddd;\r\n}\r\n\r\n\r\n.as-dual-select-box-list:last-child {\r\n border-left: solid 1px #dddddd;\r\n flex-grow: 1;\r\n}\r\n\r\n.as-dual-select-menu.absol-selectmenu {\r\n min-width: calc(var(--dual-list-estimate-text-width) + 5.5em);\r\n --dual-list-estimate-text-width: 20px;\r\n}\r\n\r\n\r\n.am-dual-select-menu .absol-selectmenu-holder-item{\r\n position: relative;\r\n height: 100%;\r\n top: unset;\r\n bottom: unset;\r\n}\r\n\r\n.am-dual-select-menu{\r\n width: auto;\r\n}", ""]); /***/ }), /***/ 7078: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-dv-exp-tree {\r\n\r\n}\r\n\r\n.as-dv-exp-tree > .absol-exp-node > .absol-exp-node-level {\r\n}\r\n\r\n.as-dv-exp-tree > .absol-exp-node > .absol-radio-button {\r\n vertical-align: middle;\r\n display: inline-block;\r\n margin-right: 5px;\r\n /*margin-left: 5px;*/\r\n}\r\n\r\n\r\n.as-dv-exp-tree:not(.as-has-radio) > .absol-exp-node > .absol-radio-button {\r\n /*visibility: hidden;*/\r\n display: none;\r\n}\r\n\r\n\r\n.as-dv-exp-tree > .absol-exp-node > .as-dv-exp-tree-index {\r\n box-sizing: border-box;\r\n padding: 0 0 0 0.5em;\r\n margin-left: 0.5em;\r\n outline: none;\r\n height: 1.2em;\r\n min-width: 3em;\r\n box-shadow: 0 0 0 1px #dddddd;\r\n display: inline-block;\r\n vertical-align: middle;\r\n background-color: white;\r\n}\r\n\r\n.as-dv-exp-tree > .absol-exp-node > .as-dv-exp-tree-index:hover{\r\n box-shadow: 0 0 0 1px #aaaaaa;\r\n}\r\n\r\n.as-dv-exp-tree:not(.as-has-index-input) > .absol-exp-node > .as-dv-exp-tree-index {\r\n display: none;\r\n}\r\n\r\n/*.as-dv-exp-tree>.absol-exp-node:not(.status-open):not(.status-close)>.toggler-ico{*/\r\n/* display: none;*/\r\n/*}*/\r\n\r\n/*.as-dv-exp-tree .absol-exp-node-ext-icon{*/\r\n/* display: none;*/\r\n/*}*/", ""]); /***/ }), /***/ 6049: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --table-row-height: 40px;\r\n}\r\n\r\n\r\n.as-efficient-table-wrapper {\r\n box-sizing: border-box;\r\n position: relative;\r\n overflow: hidden;\r\n overflow-anchor: none !important;\r\n scroll-snap-stop: normal !important;\r\n overscroll-behavior: unset !important;\r\n scroll-behavior: unset !important;\r\n}\r\n\r\n.as-efficient-table-wrapper > .as-dynamic-table {\r\n position: relative;\r\n table-layout: auto;\r\n}\r\n\r\n.as-efficient-table-wrapper.as-headless .as-dynamic-table {\r\n table-layout: fixed;\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper {\r\n --dt-content-height: 0px;\r\n --dt-scroll-bar-width: 17px;\r\n --dt-content-width: 0;\r\n --dt-header-height: 0;\r\n --dt-fixed-x-width: 0;\r\n --dt-dragging-row-height: 0;\r\n position: relative;\r\n\r\n /*padding-right: 17px;*/\r\n /*padding-bottom: 17px;*/\r\n box-sizing: border-box;\r\n height: calc(var(--dt-content-height) + 1px);\r\n overflow: hidden;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-width-match-parent {\r\n\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-table-layout-fixed table.as-dynamic-table {\r\n table-layout: fixed;\r\n}\r\n\r\ntd .as-dynamic-table-wrapper .as-dt-header-cell {\r\n --as-force-min-width: 0;\r\n}\r\n\r\n.as-dynamic-table-wrapper .as-dt-header-cell.as-col-width-auto::before { /*table in table bug*/\r\n content: \"\";\r\n display: block;\r\n width: var(--as-force-min-width);\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-inline {\r\n max-width: calc(var(--dt-content-width) + var(--dt-scroll-bar-width));\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-x.as-has-fixed-col .as-dynamic-table-viewport::before {\r\n content: \"\";\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n border-right: 2px solid #aaa;\r\n left: calc(var(--dt-fixed-x-width) - 1px);\r\n z-index: 20;\r\n pointer-events: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-y .as-dynamic-table-viewport::after {\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n max-width: var(--dt-content-width);\r\n border-top: 2px solid #aaa;\r\n top: calc(var(--dt-header-height) - 1px);\r\n z-index: 20;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-has-fixed-col {\r\n max-width: var(--dt-content-width);\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-has-fixed-col.as-overflow-y {\r\n max-width: calc(var(--dt-content-width) + var(--dt-scroll-bar-width));\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-inline {\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-overflow-x {\r\n padding-bottom: var(--dt-scroll-bar-width);\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-x {\r\n height: calc(var(--dt-content-height) + var(--dt-scroll-bar-width));\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-x .as-dynamic-table-hb,\r\n.as-dynamic-table-wrapper.as-overflow-y .as-dynamic-table-vb {\r\n display: block;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-y {\r\n padding-right: var(--dt-scroll-bar-width);\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-y.as-width-auto {\r\n /*max-width: calc(var(--dt-content-width) + var(--dt-scroll-bar-width)); disable for resizer testing*/\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-y.as-has-fixed-col,\r\n.as-dynamic-table-wrapper.as-overflow-y:not(.as-width-match-parent) {\r\n /*max-width: calc(var(--dt-content-width) + var(--dt-scroll-bar-width));*/\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-adapt-infinity-grow.as-auto-height {\r\n height: calc(var(--dt-content-height) + 1px) !important;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-adapt-infinity-grow {\r\n max-height: unset !important;\r\n}\r\n\r\n\r\n.as-dynamic-table-viewport {\r\n width: 100%;\r\n height: 100%;\r\n overflow: hidden;\r\n position: relative;\r\n}\r\n\r\n\r\n.as-dynamic-table.as-dt-fixed-y,\r\n.as-dynamic-table.as-fixed-x {\r\n table-layout: fixed;\r\n width: auto;\r\n /*display: inline-block;*/\r\n}\r\n\r\n.as-dynamic-table-fixed-x-ctn {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n z-index: 6;\r\n display: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-has-fixed-col .as-dynamic-table-fixed-x-ctn {\r\n display: block;\r\n}\r\n\r\n.as-dynamic-table-fixed-xy-ctn {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n z-index: 9;\r\n}\r\n\r\n\r\n.as-dynamic-table-fixed-y-ctn {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n z-index: 6;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-headless .as-dynamic-table-fixed-x-ctn,\r\n.as-dynamic-table-wrapper.as-headless .as-dynamic-table-fixed-y-ctn,\r\n.as-dynamic-table-wrapper.as-headless .as-dynamic-table-fixed-xy-ctn {\r\n visibility: hidden;\r\n}\r\n\r\n.as-dynamic-table-space {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n}\r\n\r\n.as-dynamic-table-space > table {\r\n vertical-align: top;\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-has-fixed-col .as-dynamic-table-space,\r\n.as-dynamic-table-wrapper.as-inline .as-dynamic-table-space {\r\n width: 8096px;\r\n}\r\n\r\n\r\n.as-dynamic-table-vb {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n height: 100%;\r\n width: var(--dt-scroll-bar-width);\r\n display: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-x .as-dynamic-table-vb {\r\n height: calc(100% - var(--dt-scroll-bar-width));\r\n}\r\n\r\n.as-dynamic-table-hb {\r\n position: absolute;\r\n left: 0;\r\n bottom: 0;\r\n width: 100%;\r\n height: var(--dt-scroll-bar-width);\r\n display: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-overflow-y .as-dynamic-table-hb {\r\n width: calc(100% - var(--dt-scroll-bar-width));\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-no-paging .absol-page-selector {\r\n display: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper .absol-page-selector[data-page-count=\"1\"] {\r\n display: none;\r\n}\r\n\r\n\r\n.as-dynamic-table-fixed-x-col {\r\n display: none;\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: auto !important;\r\n z-index: 12;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-has-fixed-col .as-dynamic-table-fixed-x-col {\r\n display: block;\r\n}\r\n\r\n.as-dynamic-table {\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n border-collapse: collapse;\r\n box-sizing: border-box;\r\n display: inline-table;\r\n table-layout: fixed;\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper:not(.as-inline) .as-dynamic-table-space .as-dynamic-table {\r\n /*min-width: 100%;*/\r\n table-layout: auto;\r\n /*display: table;*/\r\n}\r\n\r\n.as-dt-header {\r\n background-color: #d6d6d6;\r\n}\r\n\r\n.as-dt-header-cell {\r\n font-weight: bold;\r\n padding: 10px;\r\n border: 1px solid #ababab;\r\n position: relative;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-dt-header-cell-resizer {\r\n position: absolute;\r\n right: -3px;\r\n top: 0;\r\n bottom: 0;\r\n width: 6px;\r\n /*border-right: 6px solid transparent;*/\r\n z-index: 5;\r\n cursor: col-resize;\r\n /*display: none;*/\r\n}\r\n\r\n/*\r\n.as-dynamic-table-wrapper[id] .as-dt-header-cell[data-col-id] .as-dt-header-cell-resizer {\r\n display: block;\r\n}*/\r\n\r\n.as-dt-header-cell[data-sort-key] {\r\n padding-right: 1.75em;\r\n cursor: pointer;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.as-dt-sort-btn {\r\n display: none;\r\n vertical-align: middle;\r\n line-height: 1.5em;\r\n position: absolute;\r\n right: 0.25em;\r\n top: calc(50% - 0.75em);\r\n color: #a9a9a9;\r\n\r\n height: 1.5em;\r\n width: 1.5em;\r\n pointer-events: none;\r\n /*color: transparent;*/\r\n}\r\n\r\n.as-dt-header-cell[data-sort-key] .as-dt-sort-btn {\r\n display: inline-block;\r\n}\r\n\r\n.as-dt-header-cell[data-sort-order=\"ascending\"] .as-dt-sort-btn .mdi-menu-up,\r\n.as-dt-header-cell[data-sort-order=\"descending\"] .as-dt-sort-btn .mdi-menu-down {\r\n color: #007bff;\r\n}\r\n\r\n.as-dt-sort-btn span {\r\n position: absolute;\r\n display: inline-block;\r\n left: 0;\r\n font-size: 2em;\r\n\r\n}\r\n\r\n.as-dt-sort-btn .mdi-menu-up {\r\n bottom: 0.18em;\r\n}\r\n\r\n\r\n.as-dt-sort-btn .mdi-menu-down {\r\n top: 0.18em;\r\n}\r\n\r\n\r\n.as-dt-body-row:nth-child(odd) {\r\n background-color: rgb(245, 245, 245);\r\n}\r\n\r\n.as-dt-body-row:nth-child(even) {\r\n background-color: white;\r\n}\r\n\r\n.as-dt-body-cell {\r\n padding: 4px 5px;\r\n border: 1px solid #ddd;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-dt-body-row .as-drag-zone{\r\n user-select: none;\r\n}\r\n\r\n.as-dt-body-row .as-drag-zone .mdi,\r\n.as-tree-table-row .as-drag-zone .mdi {\r\n font-size: 25px;\r\n}\r\n\r\n\r\n.as-dt-body-row {\r\n height: calc(40em / 14);\r\n}\r\n\r\n.as-dt-body-row {\r\n height: var(--table-row-height);\r\n}\r\n\r\n.as-dynamic-table-wrapper:not(.as-searching) .as-dt-body-row .as-drag-zone,\r\n.as-tree-table:not(.as-searching) .as-tree-table-row .as-drag-zone {\r\n cursor: move;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-row-dragging .as-dt-body-row {\r\n transition: transform 0.2s;\r\n}\r\n\r\n.as-dt-body-row.as-dragging {\r\n opacity: 0.0;\r\n /*position: relative;*/\r\n /*z-index: 1000000;*/\r\n\r\n /*opacity: 0.8;*/\r\n}\r\n\r\n\r\n.as-dt-body-row.as-after-dragging {\r\n\r\n}\r\n\r\n\r\n.as-dt-body-row-cloned-ctn {\r\n position: fixed;\r\n cursor: move;\r\n opacity: 0.7;\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n\r\n}\r\n\r\n.as-dt-body-row-cloned-ctn > table {\r\n display: block;\r\n}\r\n\r\n.as-dt-body-row.as-drag-neighbor {\r\n position: relative;\r\n z-index: 1;\r\n transition: transform 0.05s;\r\n\r\n}\r\n\r\n.as-dt-body-row.as-dragging.as-homing {\r\n transition: transform 0.06s;\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-searching .as-drag-zone {\r\n opacity: 0.3;\r\n pointer-events: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper .as-drag-zone {\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.as-dt-insert-line {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n border-top: 2px solid blue;\r\n}\r\n\r\n.as-dt-body-cell > .absol-checkbox:last-child:first-child {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-dt-row-index::before {\r\n content: attr(data-idx);\r\n}\r\n\r\n.as-dt-row-index:not([data-idx])::before {\r\n content: \"000\";\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper.as-no-graphic .as-dt-header-cell,\r\n.as-dynamic-table-wrapper.as-no-graphic .as-dt-body-cell {\r\n border: none;\r\n}\r\n\r\n.as-dynamic-table-wrapper.as-no-graphic .as-dt-header,\r\n.as-dynamic-table-wrapper.as-no-graphic .as-dt-body-row {\r\n background-color: transparent;\r\n}\r\n\r\n\r\n.absol-single-page-scroller-viewport .as-dynamic-table-wrapper:not(.as-adapt-infinity-grow) {\r\n max-height: calc(var(--single-page-scroller-height) - 2px);\r\n}\r\n\r\n.absol-single-page-scroller-viewport > div:last-child .as-dynamic-table-wrapper:not(.as-adapt-infinity-grow) {\r\n max-height: calc(var(--single-page-scroller-height) - 2px);\r\n}\r\n\r\n\r\n.as-dynamic-table-wrapper tr.as-dragged,\r\n.as-dynamic-table-wrapper tr.as-dragging{\r\n background-color: #FFF9C4;\r\n}\r\n\r\n/*.absol-single-page-scroller-viewport > div:last-child .as-dynamic-table-wrapper.as-overflow-y:not(.as-adapt-infinity-grow) {*/\r\n/* max-height: calc(var(--single-page-scroller-height) - 2px);*/\r\n/*} try remove this*/\r\n\r\n\r\n/*Keeview modal*/\r\nbody > div > table .as-dynamic-table-wrapper {\r\n width: var(--dt-content-width);\r\n max-width: calc(90vw - 50px);\r\n}\r\n\r\nbody > div > table .as-dynamic-table-wrapper.as-overflow-y {\r\n width: calc(var(--dt-content-width) + var(--dt-scroll-bar-width));\r\n max-width: calc(90vw - 50px);\r\n}\r\n\r\n/*.as-dynamic-table-wrapper*/\r\n\r\n", ""]); /***/ }), /***/ 4284: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.absol-editabe-text {\r\n display: inline;\r\n}\r\n\r\n.absol-editabe-text span {\r\n font-style: inherit;\r\n font-size: inherit;\r\n white-space: pre;\r\n}\r\n\r\n.absol-editabe-text-higne {\r\n display: inline-block;\r\n position: relative;\r\n width: 0px;\r\n height: 0ox;\r\n}\r\n\r\n.absol-editabe-text-higne input {\r\n position: absolute;\r\n display: none;\r\n border: none;\r\n top: -2;\r\n left: -2;\r\n padding-top: 0px;\r\n padding-left: 2px;\r\n padding-bottom: 4px;\r\n margin: 0;\r\n background: transparent;\r\n outline: none;\r\n font-style: inherit;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-editabe-text.editing .absol-editabe-text-higne input {\r\n display: block;\r\n}\r\n\r\n.absol-editabe-text.editing span {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-editabe-text.editing {\r\n -webkit-box-shadow: 0px 0px 2px 0px rgba(33, 77, 255, 1);\r\n -moz-box-shadow: 0px 0px 2px 0px rgba(33, 77, 255, 1);\r\n box-shadow: 0px 0px 2px 0px rgba(33, 77, 255, 1);\r\n border-radius: 0.17em;\r\n}\r\n", ""]); /***/ }), /***/ 1527: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-emoji-counter {\r\n display: inline-block;\r\n vertical-align: middle;\r\n color: rgb(38, 141, 145);\r\n box-sizing: border-box;\r\n box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.2);\r\n height: calc(2rem + 2px);\r\n text-align: center;\r\n min-height: calc(2rem + 2px);\r\n padding: 0 8px;\r\n border-radius: calc(1rem + 1px);\r\n font-size: 1rem;\r\n background-color: white;\r\n outline: none;\r\n}\r\n\r\n.as-emoji-counter::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-emoji-counter-sprite {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 1.285em;\r\n height: 1.285em;\r\n}\r\n\r\n.as-emoji-counter-num {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n margin-left: 0.2em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: inherit;\r\n color: inherit;\r\n cursor: default;\r\n}\r\n\r\n.as-emoji-counter-num:empty {\r\n display: none;\r\n}\r\n\r\n.as-emoji-counter.as-zero {\r\n background-color: rgba(220, 220, 220);\r\n}\r\n\r\n.as-emoji-counter + .as-emoji-counter {\r\n margin-left: 0.3em;\r\n}", ""]); /***/ }), /***/ 1139: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-emoji-picker {\r\n font-size: calc(12em / 14);\r\n border: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.as-emoji-picker-preview {\r\n display: inline-block;\r\n vertical-align: top;\r\n width: 5.7em;\r\n height: calc(8em + 30px);\r\n border-right: 1px solid #dddddd;\r\n text-align: center;\r\n\r\n}\r\n\r\n\r\n.as-emoji-picker-preview-anim {\r\n width: 60px;\r\n height: 60px;\r\n margin-top: 5px;\r\n}\r\n\r\n.as-emoji-picker-preview-desc {\r\n font-size: 12px;\r\n font-weight: bold;\r\n color: black;\r\n}\r\n\r\n.as-emoji-picker-preview-shortcut {\r\n font-size: 12px;\r\n color: rgb(70, 70, 70);\r\n}\r\n\r\n\r\n.as-emoji-picker-list {\r\n display: inline-block;\r\n vertical-align: top;\r\n overflow-y: auto;\r\n width: calc(100% - 5.7em - 1px);\r\n height: calc(8em + 30px);\r\n padding: 5px;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-emoji-picker-item {\r\n display: inline-block;\r\n padding: 5px;\r\n width: 2em;\r\n height: 2em;\r\n box-sizing: border-box;\r\n border-radius: 0.4em;\r\n}\r\n\r\n.as-emoji-picker-item:hover {\r\n background-color: rgba(169, 169, 170, 0.3);\r\n}\r\n\r\n.as-emoji-picker-item:active {\r\n background-color: rgba(169, 169, 170, 0.7);\r\n}", ""]); /***/ }), /***/ 6208: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-emoji-picker-tooltip {\r\n --tool-tip-background-color: white;\r\n filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.5));\r\n}\r\n\r\n.as-emoji-picker-tooltip .absol-tooltip-content {\r\n display: block;\r\n padding: 0;\r\n box-sizing: border-box;\r\n position: relative;\r\n white-space: nowrap;\r\n overflow: hidden;\r\n}\r\n\r\n.as-emoji-picker-tooltip-left-btn,\r\n.as-emoji-picker-tooltip-right-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 60px;\r\n width: 40px;\r\n font-size: 25px;\r\n padding: 0;\r\n background-color: transparent;\r\n border: none;\r\n color: rgb(155, 155, 175);\r\n outline: none;\r\n}\r\n\r\n.as-emoji-picker-tooltip-left-btn:hover,\r\n.as-emoji-picker-tooltip-right-btn:hover {\r\n background-color: rgba(156, 156, 156, 0.15);\r\n}\r\n\r\n.as-emoji-picker-tooltip-left-btn:active,\r\n.as-emoji-picker-tooltip-right-btn:active {\r\n background-color: rgba(0, 0, 0, 0.15);\r\n}\r\n\r\n.as-emoji-picker-tooltip-left-btn:disabled,\r\n.as-emoji-picker-tooltip-right-btn:disabled {\r\n pointer-events: none;\r\n color: rgb(230, 230, 235);\r\n}\r\n\r\n.as-emoji-picker-tooltip-scroller {\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n width: 360px;\r\n height: 60px;\r\n overflow: hidden;\r\n}\r\n\r\n.as-emoji-picker-tooltip-icon-list {\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n left: 0;\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.as-emoji-picker-tooltip:not(.as-scrolling) .as-emoji-picker-tooltip-icon-list {\r\n transition: left 0.5s;\r\n}\r\n\r\n.as-emoji-picker-tooltip-icon-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 60px;\r\n width: 60px;\r\n padding: 0;\r\n border: none;\r\n outline: none;\r\n background-color: transparent;\r\n}\r\n\r\n\r\n.as-emoji-picker-tooltip-icon {\r\n transition: width 0.3s, height 0.3s;\r\n width: 35px;\r\n height: 35px;\r\n}\r\n\r\n.as-emoji-picker-tooltip-icon-btn:hover .as-emoji-picker-tooltip-icon {\r\n width: 45px;\r\n height: 45px;\r\n}\r\n\r\n.as-emoji-picker-tooltip-remove-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 60px;\r\n width: 60px;\r\n padding: 0;\r\n border: none;\r\n outline: none;\r\n background-color: transparent;\r\n font-size: 40px;\r\n color: rgb(185, 185, 185);\r\n}\r\n\r\n.as-emoji-picker-tooltip-remove-btn:hover {\r\n color: rgb(255, 30, 30);\r\n}\r\n\r\n\r\n.as-emoji-picker-tooltip:not(.as-mobile) .as-emoji-picker-tooltip-page-indicator {\r\n display: none;\r\n}\r\n\r\n.as-emoji-picker-tooltip.as-mobile .as-emoji-picker-tooltip-right-btn,\r\n.as-emoji-picker-tooltip.as-mobile .as-emoji-picker-tooltip-left-btn {\r\n display: none;\r\n}\r\n\r\n\r\n@media (max-width: 410px) and (min-width: 310px) {\r\n .as-emoji-picker-tooltip-left-btn,\r\n .as-emoji-picker-tooltip-right-btn {\r\n height: 36px;\r\n width: 24px;\r\n font-size: 15px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-scroller {\r\n width: 216px;\r\n height: 36px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-icon-btn {\r\n height: 36px;\r\n width: 36px;\r\n }\r\n\r\n\r\n .as-emoji-picker-tooltip-icon {\r\n width: 21px;\r\n height: 21px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-icon-btn:hover .as-emoji-picker-tooltip-icon {\r\n width: 27px;\r\n height: 27px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-remove-btn {\r\n height: 36px;\r\n width: 36px;\r\n font-size: 24px;\r\n }\r\n}\r\n\r\n@media (max-width: 510px) and (min-width: 410px) {\r\n .as-emoji-picker-tooltip-left-btn,\r\n .as-emoji-picker-tooltip-right-btn {\r\n height: 48px;\r\n width: 32px;\r\n font-size: 20px;\r\n }\r\n\r\n\r\n .as-emoji-picker-tooltip-scroller {\r\n width: 288px;\r\n height: 48px;\r\n }\r\n\r\n\r\n .as-emoji-picker-tooltip-icon-btn {\r\n height: 48px;\r\n width: 48px;\r\n }\r\n\r\n\r\n .as-emoji-picker-tooltip-icon {\r\n width: 28px;\r\n height: 28px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-icon-btn:hover .as-emoji-picker-tooltip-icon {\r\n width: 36px;\r\n height: 36px;\r\n }\r\n\r\n .as-emoji-picker-tooltip-remove-btn {\r\n height: 48px;\r\n width: 48px;\r\n font-size: 32px;\r\n }\r\n}", ""]); /***/ }), /***/ 1501: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-emoji-user-list-tooltip {\r\n --tool-tip-background-color: white;\r\n filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.5));\r\n text-align: left;\r\n}\r\n\r\n\r\n.as-emoji-user-list-tooltip-emoji {\r\n position: absolute;\r\n width: 60px;\r\n height: 60px;\r\n top: -30px;\r\n left: calc(50% - 30px);\r\n z-index: 2;\r\n\r\n}\r\n\r\n.as-emoji-user-list-tooltip .absol-tooltip-content {\r\n min-height: 60px;\r\n min-width: 120px;\r\n padding-top: 25px;\r\n}\r\n\r\n.as-emoji-user-list-tooltip-user{\r\n padding: 3px 10px 3px 0 ;\r\n}\r\n\r\n.as-emoji-user-list-tooltip-user.as-clickable{\r\n cursor: pointer;\r\n}\r\n\r\n.as-emoji-user-list-tooltip-avatar {\r\n width: 30px;\r\n height: 30px;\r\n border-radius: 50%;\r\n background-size: cover;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-emoji-user-list-tooltip-name {\r\n display: inline-block;\r\n vertical-align: middle;\r\n margin-left: 10px;\r\n color: rgb(70, 70, 72);\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}", ""]); /***/ }), /***/ 9446: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/*.as-expression-input {*/\r\n/* box-sizing: border-box;*/\r\n/* border: 1px solid var(--as-input-border-color);*/\r\n/* min-height: var(--as-input-height);*/\r\n\r\n/*}*/\r\n\r\n/*.as-expression-input-content {*/\r\n/* font-size: 14px;*/\r\n/* line-height: 2;*/\r\n/* min-height: 2em;*/\r\n/*}*/\r\n\r\n/*.as-expression-input-content::before{*/\r\n/* content: \"=\";*/\r\n/* color: #aaaaaa;*/\r\n/* display: inline-block;*/\r\n/* height: 28px;*/\r\n/* vertical-align: middle;*/\r\n/* padding: 0 5px;*/\r\n/*}*/\r\n\r\n/*.asei-identifier{*/\r\n/* display: inline-block;*/\r\n/*}*/\r\n\r\n\r\n.as-expression-input {\r\n font-family: Consolas, monospace;\r\n border-color: var(--as-input-border-color);\r\n border-style: solid;\r\n box-sizing: border-box;\r\n border-width: 1px;\r\n border-radius: var(--as-input-border-radius);\r\n font-size: 14px;\r\n position: relative;\r\n line-height: 2;\r\n background-color: white;\r\n}\r\n\r\n.as-expression-input.as-disabled {\r\n background-color: var(--as-disabled-background-color);\r\n color: var(--as-disabled-text-color);\r\n pointer-events: none;\r\n}\r\n\r\n.as-expression-input.as-border-none {\r\n border: none;\r\n}\r\n\r\n.as-expression-input:not(.as-read-only):not(.as-disabled){\r\n user-select: none;\r\n}\r\n\r\n.as-expression-input-range-ctn {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n z-index: 9;\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-expression-input-range {\r\n position: absolute;\r\n background-color: rgba(19, 176, 233, 0.4);\r\n}\r\n\r\n\r\n.as-expression-input-content {\r\n min-height: 28px;\r\n outline: none;\r\n line-height: inherit;\r\n white-space: pre-wrap;\r\n padding-left: var(--as-input-horizontal-padding);\r\n}\r\n\r\n.as-expression-input-range-ctn {\r\n left: var(--as-input-horizontal-padding);\r\n\r\n}\r\n\r\n.as-expression-input.as-has-icon .as-expression-input-content {\r\n padding-left: calc(18px + var(--as-input-horizontal-padding));\r\n}\r\n\r\n.as-expression-input.as-has-icon .as-expression-input-range-ctn {\r\n left: calc(18px + var(--as-input-horizontal-padding));\r\n}\r\n\r\n\r\n.as-expression-input-content .as-token[data-type=\"number\"] {\r\n color: #0289f6;\r\n}\r\n\r\n.as-expression-input-content .as-token[data-type=\"string\"] {\r\n color: darkgreen;\r\n}\r\n\r\n\r\n.as-expression-input-content .as-token[data-ex-type=\"boolean\"] {\r\n color: #f6a128;\r\n}\r\n\r\n\r\n.as-expression-input-content .as-token[data-ex-type=\"function\"] {\r\n color: #2419c8\r\n}\r\n\r\n.as-expression-input-icon-ctn {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n pointer-events: none;\r\n font-size: 1.5em;\r\n line-height: 28px;\r\n display: none;\r\n}\r\n\r\n\r\n.as-expression-input.as-has-icon .as-expression-input-icon-ctn {\r\n display: block;\r\n}\r\n\r\n.as-expression-input-icon-ctn .mdi-equal {\r\n color: rgba(169, 169, 170);\r\n}\r\n\r\n.as-expression-input-icon-ctn .mdi-alert-circle {\r\n color: red;\r\n opacity: 0.8;\r\n display: none;\r\n}\r\n\r\n\r\n.as-expression-input.as-error .as-expression-input-icon-ctn .mdi-alert-circle {\r\n display: inline-block;\r\n}\r\n\r\n.as-expression-input.as-error .as-expression-input-icon-ctn .mdi-equal {\r\n display: none;\r\n}\r\n\r\n\r\n.as-token.as-unexpected-token {\r\n background-color: red;\r\n animation-name: error_blink;\r\n animation-duration: 1s;\r\n animation-iteration-count: infinite;\r\n}\r\n\r\n.as-expression-input-autocomplete {\r\n min-width: 10em;\r\n position: fixed;\r\n z-index: 1000;\r\n}\r\n\r\n.as-expression-input-autocomplete .absol-selectlist-item {\r\n padding-right: 0.3em;\r\n}\r\n\r\n.as-ei-suggestion-list-item {\r\n --level: 0;\r\n height: 30px;\r\n padding-right: 1em;\r\n min-width: 10em;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-ei-suggestion-list-item:hover {\r\n background-color: var(--as-list-item-hover-background-color);\r\n}\r\n\r\n.as-ei-suggestion-list-item.as-selected {\r\n background-color: var(--as-list-item-selected-background-color);\r\n}\r\n\r\n\r\n.as-ei-suggestion-list-item::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-ei-suggestion-list-item > *,\r\n.as-ei-suggestion-list-item::before\r\n{\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-ei-suggestion-list-item:not(.as-status-open):not(.as-status-close) .as-eisli-toggler{\r\n visibility: hidden;\r\n}\r\n\r\n.as-ei-suggestion-list-item.as-status-open .toggle-close,\r\n.as-ei-suggestion-list-item.as-status-close .toggle-open\r\n{\r\n display: none;\r\n}\r\n\r\n\r\n\r\n.as-eisli-toggler {\r\n text-align: right;\r\n width: calc(1em * var(--level) + 1.5em);\r\n padding-right: 0.5em;\r\n}\r\n\r\n.as-ei-suggestion-list {\r\n max-height: calc(100vh - 100px);\r\n overflow-y:auto ;\r\n}\r\n\r\n.as-ei-suggestion-list .mdi {\r\n width: 30px;\r\n text-align: center;\r\n font-size: 1em;\r\n}\r\n\r\n.as-ei-suggestion-list .mdi.mdi-function {\r\n color: #2419c8;\r\n}\r\n\r\n.as-ei-suggestion-list .mdi.mdi-variable {\r\n color: #5b5d42;\r\n}\r\n\r\n.as-ei-suggestion-list .am-select-tree-leaf-item-icon-ctn {\r\n left: calc(2em * var(--level) - 14px)\r\n}\r\n\r\n.as-expression-input-real-input {\r\n position: absolute;\r\n z-index: 10;\r\n right: 0;\r\n top: 0;\r\n width: 100px;\r\n height: 100px;\r\n opacity: 0.5;\r\n /*visibility: hidden;*/\r\n}\r\n\r\n.as-expression-input-foreground {\r\n position: absolute;\r\n z-index: 8;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n\r\n}\r\n\r\n.as-ei-command-tool {\r\n background: white;\r\n border: 1px solid #e0e0e0;\r\n border-radius: 3px;\r\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\r\n padding: 0 3px;\r\n box-sizing: border-box;\r\n height: 31px;\r\n}\r\n\r\n.as-ei-command-tool::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-ei-command-tool button {\r\n font-size: 14px;\r\n width: 25px;\r\n height: 25px;\r\n padding: 0;\r\n box-sizing: border-box;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-ei-command-tool button:hover {\r\n background-color: #f0f0f0;\r\n}\r\n\r\n.as-ei-command-tool button:not(:last-child) {\r\n margin-right: 3px;\r\n}\r\n\r\n@keyframes error_blink {\r\n 0% {\r\n background-color: red\r\n }\r\n 50% {\r\n background-color: transparent\r\n }\r\n 100% {\r\n background-color: red\r\n }\r\n}", ""]); /***/ }), /***/ 1741: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-exp-node {\r\n height: 2em;\r\n text-align: left;\r\n background-color: transparent;\r\n border: none;\r\n outline: none;\r\n white-space: nowrap;\r\n font-size: inherit;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n position: relative;\r\n color: rgb(33, 33, 34);\r\n}\r\n\r\n.absol-exp-node .toggler-ico {\r\n width: 0.7em;\r\n height: 0.7em;\r\n margin-right: 0.35em;\r\n}\r\n\r\n.absol-exp-node .toggler-ico path {\r\n fill: rgb(104, 104, 104);\r\n}\r\n\r\n.absol-exp-node.status-removable .toggler-ico,\r\n.absol-exp-node.status-modified .toggler-ico {\r\n display: none;\r\n}\r\n\r\n.absol-exp-node:not(.status-open) .toggle-open {\r\n display: none;\r\n}\r\n\r\n.absol-exp-node:not(.status-close) .toggle-close {\r\n display: none;\r\n}\r\n\r\n\r\n\r\n.absol-exp-node:hover .remove-ico {\r\n visibility: visible;\r\n}\r\n\r\n\r\n\r\n.absol-exp-node.status-removable .remove-ico,\r\n.absol-exp-node.status-modified .remove-ico {\r\n display: inline-block;\r\n}\r\n\r\n.absol-exp-node.status-removable .remove-ico .modified {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-exp-node.status-modified .remove-ico .close {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-exp-node.status-modified .remove-ico:hover .close {\r\n visibility: visible;\r\n}\r\n\r\n.absol-exp-node.status-modified .remove-ico:hover .modified {\r\n visibility: hidden;\r\n}\r\n\r\n\r\n.absol-exp-node .remove-ico {\r\n width: 0.9em;\r\n height: 0.9em;\r\n display: none;\r\n visibility: hidden;\r\n margin-left: -0.3em;\r\n margin-right: 0.45em;\r\n}\r\n\r\n.absol-exp-node .remove-ico .close,\r\n.absol-exp-node .remove-ico .modified {\r\n fill: rgb(169, 169, 169);\r\n stroke: none;\r\n}\r\n\r\n\r\n.absol-exp-node.has-status {\r\n padding-right: 2.5em;\r\n}\r\n\r\n.absol-exp-node>div,\r\n.absol-exp-node>svg {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.absol-exp-node .editing input {\r\n color: khaki;\r\n padding-top: 2px;\r\n padding-bottom: 2px;\r\n}\r\n\r\n.absol-exp-node:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.absol-exp-node:focus,\r\n.absol-exp-node.as-active:focus {\r\n background-color: var(--as-transparent-button-focus-color);\r\n}\r\n\r\n.absol-exp-node.as-active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n\r\n\r\n.absol-exp-node-name {\r\n /* -webkit-touch-callout: none;\r\n -webkit-user-select: none;\r\n -khtml-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none; */\r\n user-select: none;\r\n vertical-align: middle;\r\n color: black;\r\n margin-left: 0.5em;\r\n}\r\n\r\n.absol-exp-node-desc {\r\n color: rgb(104, 104, 104);\r\n margin-left: 0.5em;\r\n font-size: 0.85em;\r\n\tvertical-align: middle;\r\n}\r\n\r\n.absol-exp-node-desc:empty {\r\n margin-left: 0;\r\n}\r\n\r\n\r\n.absol-exp-node-expand-icon {\r\n display: inline-block;\r\n vertical-align: middle;\r\n margin-right: 0.2em;\r\n height: 0.5em;\r\n width: 0.5em;\r\n}\r\n\r\nimg.absol-exp-node-ext-icon {\r\n display: none;\r\n}\r\n\r\n.absol-exp-node-ext-icon,\r\n.absol-exp-node-ext-icon>img {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 1.5em;\r\n height: 1.5em;\r\n}\r\n\r\ndiv.absol-exp-node-ext-icon:empty {\r\n display: none;\r\n}\r\n\r\ndiv.absol-exp-node-ext-icon {\r\n text-align: center;\r\n}\r\n\r\n.absol-exp-node-ext-icon>.mdi,\r\n.absol-exp-node-ext-icon>span .absol-exp-node-ext-icon>svg {\r\n line-height: 1em;\r\n font-size: 1.5em;\r\n}\r\n\r\nimg.absol-exp-node-ext-icon[src] {\r\n display: inline-block;\r\n}\r\n\r\n\r\n.absol-exp-tree>.absol-exp-node {\r\n width: 100%;\r\n display: block;\r\n}\r\n\r\n.absol-exp-tree.hide-children>.absol-exp-items {\r\n display: none;\r\n}\r\n\r\n\r\n.dark .toggler-ico path {\r\n fill: rgb(169, 169, 169);\r\n}\r\n\r\n\r\n.dark .absol-exp-node-name {\r\n color: rgb(204, 204, 204);\r\n}\r\n\r\n.dark .absol-exp-node-desc {\r\n color: rgb(169, 169, 170);\r\n}\r\n\r\n.dark .absol-exp-node {\r\n color: rgb(169, 169, 170);\r\n}", ""]); /***/ }), /***/ 4813: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-file-input-box {\r\n font-size: 14px;\r\n position: relative;\r\n width: 100px;\r\n height: 100px;\r\n box-sizing: border-box;\r\n border: 1px solid #dddddd;\r\n background-color: white;\r\n font-family: Arial, Helvetica, sans-serif;\r\n overflow: visible;\r\n}\r\n\r\n.as-file-input-box-trigger:hover + .as-file-input-box-upload-overlay,\r\n.as-file-input-box-trigger.as-drag-over + .as-file-input-box-upload-overlay {\r\n display: block;\r\n}\r\n\r\n.as-file-input-box-trigger input {\r\n visibility: hidden;\r\n opacity: 0;\r\n}\r\n\r\n.as-file-input-box-upload-overlay {\r\n display: none;\r\n pointer-events: none;\r\n background-color: rgba(30, 30, 80, 0.3);\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n z-index: 5;\r\n overflow: hidden;\r\n text-align: center;\r\n white-space: nowrap;\r\n font-size: 3em;\r\n color: #b0fffb;\r\n}\r\n\r\n.as-file-input-box-upload-overlay::before,\r\n.as-file-input-box-upload-overlay > span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-file-input-box-upload-overlay::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n\r\n.as-file-input-box-trigger {\r\n position: absolute;\r\n z-index: 2;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n opacity: 0;\r\n}\r\n\r\n.as-file-input-box:not(.as-has-file-name) .as-file-input-box-file-name,\r\n.as-file-input-box:not(.as-has-file-name) .as-file-input-box-file-name + br,\r\n.as-file-input-box:not(.as-has-file-size) .as-file-input-box-file-size,\r\n.as-file-input-box:not(.as-has-value) .as-file-input-box-action-left,\r\n.as-file-input-box:not(.as-has-value) .as-file-input-box-action-right,\r\n.as-file-input-box:not(.as-downloadable) .as-file-input-box-action-right,\r\n.as-file-input-box:not(.as-removable) .as-file-input-box-action-left,\r\n.as-file-input-box:not(.as-allow-upload) .as-file-input-box-trigger {\r\n display: none;\r\n}\r\n\r\n\r\n.as-file-input-box-background {\r\n position: absolute;\r\n z-index: 1;\r\n left: 4%;\r\n top: 4%;\r\n right: 4%;\r\n bottom: 4%;\r\n background-size: contain;\r\n background-repeat: no-repeat;\r\n background-position: center;\r\n overflow: hidden;\r\n}\r\n\r\n.as-file-input-box.as-allow-upload .as-file-input-box-background {\r\n background-image: url();\r\n}\r\n\r\n\r\n.as-file-input-box-info {\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n padding: 2px;\r\n z-index: 3;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n background-color: rgba(255, 255, 255, 0.3);\r\n pointer-events: none;\r\n text-align: center;\r\n}\r\n\r\n.as-file-input-box-file-name {\r\n font-size: inherit;\r\n color: black;\r\n text-shadow: 0 0 5px white;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-file-input-box-action-left,\r\n.as-file-input-box-action-right {\r\n position: absolute;\r\n z-index: 6;\r\n top: 0;\r\n}\r\n\r\n\r\n.as-file-input-box-action-left {\r\n left: 0;\r\n}\r\n\r\n\r\n.as-file-input-box-action-right {\r\n right: 0;\r\n}\r\n\r\n.as-file-input-box button {\r\n height: 2em;\r\n width: 2em;\r\n padding: 0;\r\n border: none;\r\n background-color: rgba(255, 255, 255, 0.3);\r\n border-radius: 0;\r\n}\r\n\r\n.as-file-input-box button span {\r\n font-size: 1.5em;\r\n}\r\n\r\n.as-file-input-box .mdi-close {\r\n color: rgb(250, 100, 100);\r\n}\r\n\r\n.as-file-input-box .mdi-download {\r\n color: rgb(100, 100, 250);\r\n}\r\n\r\n.as-file-input-box button:hover .mdi-close {\r\n color: rgb(250, 50, 50);\r\n}\r\n\r\n.as-file-input-box button:hover .mdi-download {\r\n color: rgb(50, 50, 250);\r\n}\r\n\r\n.as-file-input-box button:active .mdi-close {\r\n color: rgb(250, 0, 0);\r\n}\r\n\r\n.as-file-input-box button:active .mdi-download {\r\n color: rgb(0, 0, 250);\r\n}\r\n\r\n.as-file-input-box-checked {\r\n display: none;\r\n box-sizing: border-box;\r\n z-index: 4;\r\n position: absolute;\r\n left: -1px;\r\n top: -1px;\r\n bottom: -1px;\r\n right: -1px;\r\n pointer-events: none;\r\n border: 3px solid #0a90eb;\r\n overflow: hidden;\r\n}\r\n\r\n.as-file-input-box.as-checked .as-file-input-box-checked{\r\n display: block;\r\n}\r\n\r\n.as-file-input-box-checked::before {\r\n content: \"\";\r\n display: block;\r\n position: absolute;\r\n right: -20px;\r\n top: -20px;\r\n width: 40px;\r\n height: 40px;\r\n transform: rotate(45deg);\r\n background-color: #0a90eb;\r\n}\r\n\r\n.as-file-input-box-checked .mdi {\r\n display: inline-block;\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n font-size: 14px;\r\n color: white;\r\n}", ""]); /***/ }), /***/ 4745: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.as-file-list-input {\r\n padding: 5px;\r\n border: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n overflow: auto;\r\n --item-width: 100%;\r\n --item-require-width: 300px;\r\n position: relative;\r\n min-height: 42px;\r\n}\r\n\r\n.as-file-list-input.as-border-none {\r\n border: none;\r\n padding: 0;\r\n}\r\n\r\n.as-file-list-input.as-disabled {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-file-list-input.as-disabled > * {\r\n opacity: 0.5;\r\n pointer-events: none;\r\n}\r\n\r\n.as-file-list-input-upload-overlay {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n overflow: hidden;\r\n text-align: center;\r\n white-space: nowrap;\r\n pointer-events: none;\r\n background-color: rgba(30, 30, 80, 0.3);\r\n color: #b0fffb;\r\n}\r\n\r\n.as-file-list-input-upload-overlay::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n content: \"\";\r\n}\r\n\r\n.as-file-list-input-upload-overlay > span {\r\n font-size: 30px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-file-list-input:not(.as-drag-over) .as-file-list-input-upload-overlay,\r\n.as-file-list-input:not(.as-droppable) .as-file-list-input-upload-overlay,\r\n.as-file-list-input:not(.as-droppable) .as-file-list-drag-file-text,\r\n.as-file-list-input.as-read-only .as-file-list-input-upload-overlay {\r\n display: none;\r\n}\r\n\r\n/*span.mdi.mdi-upload*/\r\n\r\n.as-file-list-input .as-file-input-box {\r\n display: inline-block;\r\n vertical-align: middle;\r\n margin-right: 10px;\r\n}\r\n\r\n.as-file-list-input.as-read-only .as-file-list-input-add {\r\n display: none;\r\n}\r\n\r\n.as-file-list-input-add {\r\n border: none;\r\n width: 3.5em;\r\n border-radius: 5px;\r\n background-color: rgba(235, 235, 235, 0.2);\r\n height: calc(2em + 2px);\r\n padding-bottom: 10px;\r\n box-sizing: border-box;\r\n display: inline-block;\r\n overflow: hidden;\r\n position: relative;\r\n vertical-align: middle;\r\n margin-right: 5px;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.as-file-list-input-add:hover {\r\n background-color: rgb(235, 235, 235);\r\n}\r\n\r\n.as-file-list-input-add:active {\r\n background-color: rgb(212, 212, 212);\r\n}\r\n\r\n\r\n.as-file-list-input-add input {\r\n opacity: 0;\r\n visibility: hidden;\r\n}\r\n\r\n.as-file-list-input-add-icon-ctn {\r\n font-size: 1.5em;\r\n text-align: center;\r\n color: rgb(100, 100, 250);\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n white-space: nowrap;\r\n pointer-events: none;\r\n}\r\n\r\n.as-file-list-input-add-icon-ctn span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-file-list-input-add-icon-ctn::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-file-list-input.as-drag-over.as-droppable .as-file-list-input-add,\r\n.as-file-list-input.as-drag-over .as-file-list-drag-file-text {\r\n visibility: hidden;\r\n}\r\n\r\n.as-file-list-item {\r\n position: relative;\r\n height: calc(2em + 2px);\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n width: calc(var(--item-width) - 5px);\r\n padding-left: 2.3em;\r\n white-space: nowrap;\r\n box-sizing: border-box;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n padding-right: calc(2.3em + 5px);\r\n}\r\n\r\n.as-file-list-item .as-file-list-item-check {\r\n display: none;\r\n position: absolute;\r\n left: 0.1em;\r\n top:calc(50% - 1px - 0.5em);\r\n\r\n\r\n}\r\n\r\n\r\n.as-file-list-input.as-show-check .as-file-list-item .as-file-list-item-check {\r\n display: block;\r\n}\r\n\r\n.as-file-list-input.as-show-check .as-file-list-item\r\n{\r\n padding-left: 3.5em ;\r\n}\r\n\r\n.as-file-list-input.as-show-check .as-file-list-item .as-file-list-item-icon{\r\n left: 1.2em;\r\n}\r\n\r\n.as-file-list-item-icon {\r\n position: absolute;\r\n left: 0;\r\n top: calc(50% - 1em - 1px);\r\n bottom: 0;\r\n width: calc(2em + 2px);\r\n height: calc(2em + 2px);\r\n}\r\n\r\n\r\n.as-file-list-item-name {\r\n color: rgb(89, 89, 95);\r\n display: inline-block;\r\n overflow-x: hidden;\r\n vertical-align: middle;\r\n width: 100%;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n font-weight: bold;\r\n}\r\n\r\n\r\n.as-file-list-item::before {\r\n content: \"\";\r\n display: inline-block;\r\n height: 100%;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-file-list-input .as-file-list-item {\r\n display: inline-block;\r\n vertical-align: middle;\r\n margin-bottom: 5px;\r\n margin-right: 5px;\r\n}\r\n\r\n.as-file-list-input:not(.as-empty) .as-file-list-drag-file-text,\r\n.as-file-list-input.as-read-only .as-file-list-drag-file-text {\r\n display: none;\r\n}\r\n\r\n\r\n.as-file-list-item:hover {\r\n background-color: rgba(169, 169, 172, 0.1);\r\n}\r\n\r\n\r\n.as-file-list-input .as-file-list-item:hover .as-file-list-item-quick-btn {\r\n visibility: visible;\r\n}\r\n\r\n\r\n.as-file-list-item-quick-btn {\r\n position: absolute;\r\n border: none;\r\n background-color: transparent;\r\n outline: none;\r\n border-radius: 3px;\r\n height: 2em;\r\n width: 2em;\r\n font-size: inherit;\r\n padding: 0;\r\n right: 5px;\r\n top: calc(50% - 1em);\r\n visibility: hidden;\r\n}\r\n\r\n\r\n.as-file-list-item-quick-btn.as-quick-menu-attached {\r\n display: block;\r\n}\r\n\r\n.as-file-list-item-quick-btn > span {\r\n font-size: 1.2em;\r\n}\r\n\r\n\r\n.as-file-list-item-quick-btn.as-active {\r\n background-color: rgba(20, 185, 235, 0.3);\r\n}\r\n\r\n.as-file-list-item-quick-btn:hover {\r\n background-color: #91e4fb77;\r\n}\r\n\r\n.as-file-list-item-quick-btn:active {\r\n background-color: #91e4fb;\r\n\r\n}\r\n\r\n", ""]); /***/ }), /***/ 9121: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-finder {\r\n font-size: 1rem;\r\n position: relative;\r\n --finder-header-height: 51px;\r\n --finder-nav-width: 250px;\r\n overflow: hidden;\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.as-finder.as-compact-mode {\r\n --finder-header-height: 0;\r\n}\r\n\r\n.as-finder.as-compact-mode .as-finder-header {\r\n display: none;\r\n}\r\n\r\n.as-finder-header {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n height: var(--finder-header-height);\r\n width: 100%;\r\n border-bottom: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-finder-header .as-flexicon-button {\r\n min-width: 110px;\r\n}\r\n\r\n.as-finder-nav-ctn,\r\n.as-finder-search-ctn {\r\n position: absolute;\r\n left: 0;\r\n top: var(--finder-header-height);\r\n width: var(--finder-nav-width);\r\n bottom: 0;\r\n border-right: 1px solid #dddddd;\r\n padding-top: 29px;\r\n background-color: white;\r\n z-index: 20;\r\n}\r\n\r\n.as-finder-nav-ctn {\r\n}\r\n\r\n.as-finder-search-ctn {\r\n visibility: hidden;\r\n\r\n}\r\n\r\n\r\n.as-finder-nav-header,\r\n.as-finder-search-header {\r\n display: flex;\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n right: 0;\r\n height: 29px;\r\n box-sizing: border-box;\r\n border-bottom: 1px solid #dddddd;\r\n align-items: center;\r\n}\r\n\r\n.as-finder-nav-header-left {\r\n flex-grow: 1;\r\n}\r\n\r\n.as-finder-nav-header-right button {\r\n height: 100%;\r\n width: 30px;\r\n margin-left: 5px;\r\n}\r\n\r\n.as-finder-nav-ctn > .as-exp-group,\r\n.as-finder-search-ctn > .as-finder-search-body {\r\n overflow-y: auto;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n\r\n.as-finder-search-body {\r\n padding: 10px 5px;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-finder-search-field {\r\n padding-top: 10px;\r\n}\r\n\r\n.as-finder-search-field > div {\r\n display: inline-block;\r\n}\r\n\r\n.as-finder-search-field > div:first-child {\r\n width: 5em;\r\n}\r\n\r\n\r\n.as-finder-search-footer {\r\n text-align: center;\r\n padding-top: 20px;\r\n\r\n}\r\n\r\n.as-finder-search-footer button {\r\n min-width: 100px;\r\n}\r\n\r\n.as-finder-search-footer button:not(:last-child) {\r\n margin-right: 20px;\r\n}\r\n\r\n.as-finder-body {\r\n position: absolute;\r\n right: 0;\r\n left: var(--finder-nav-width);\r\n top: var(--finder-header-height);\r\n bottom: 0;\r\n padding-top: 29px;\r\n}\r\n\r\n.as-finder-content-header {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n right: 0;\r\n height: 29px;\r\n box-sizing: border-box;\r\n border-bottom: 1px solid white;\r\n display: flex;\r\n\r\n}\r\n\r\n.as-finder-content-header-left {\r\n flex-grow: 1;\r\n}\r\n\r\n.as-finder:not(.as-mobile) .as-finder-content-header-right::after {\r\n content: \"Kéo thả file vào đây để tải lên\";\r\n color: rgb(100, 100, 180);\r\n font-style: italic;\r\n line-height: 28px;\r\n padding-right: 10px;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.as-finder-content-ctn {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n\r\n.as-finder-normal-action-button-ctn,\r\n.as-finder-tiny-action-button-ctn {\r\n position: absolute;\r\n left: 10px;\r\n top: calc(50% - 15px);\r\n white-space: nowrap;\r\n max-width: calc(100% - 50px);\r\n overflow: hidden;\r\n}\r\n\r\n.as-finder-normal-action-button-ctn > button:not(:last-child),\r\n.as-finder-tiny-action-button-ctn > button:not(:last-child) {\r\n margin-right: 10px;\r\n}\r\n\r\n.as-finder-tiny-action-button-ctn button,\r\n.as-finder-content-header button:not(.as-ribbon-button) {\r\n background-color: transparent;\r\n border: none;\r\n border-radius: 3px;\r\n width: 30px;\r\n height: 30px;\r\n font-size: inherit;\r\n padding: 0;\r\n color: var(--as-transparent-button-text-color);\r\n}\r\n\r\n.as-finder-content-header button.as-ribbon-button {\r\n height: 30px;\r\n}\r\n\r\n\r\n\r\n.as-finder-tiny-action-button-ctn button span {\r\n font-size: 1.3em;\r\n}\r\n\r\n.as-finder-tiny-action-button-ctn button:hover {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n.as-finder-tiny-action-button-ctn button:active {\r\n color: var(--as-transparent-button-text-active-color);\r\n}\r\n\r\n\r\n.as-action-button-minimized .as-finder-normal-action-button-ctn,\r\n.as-finder:not(.as-action-button-minimized) .as-finder-tiny-action-button-ctn {\r\n visibility: hidden;\r\n}\r\n\r\n.as-finder[data-selected-file-count=\"0\"] .as-finder-header button[name=\"view\"],\r\n.as-finder[data-selected-file-count=\"0\"] .as-finder-header button[name=\"delete\"],\r\n.as-finder:not([data-selected-folder-count=\"0\"]) .as-finder-header button[name=\"delete\"],\r\n.as-finder[data-selected-file-count=\"0\"] .as-finder-header button[name=\"download\"],\r\n.as-finder[data-selected-file-count=\"0\"][data-selected-folder-count=\"0\"] .as-finder-header button[name=\"move\"],\r\n.as-finder:not([data-selected-file-count=\"1\"][data-selected-folder-count=\"0\"]) .as-finder-header button[name=\"rename\"],\r\n.as-finder:not(.as-mini-layout) .as-finder-content-header button[name=\"nav_toggle\"],\r\n.as-finder:not(.as-mini-layout) .as-finder-nav-ctn button[name=\"nav_toggle\"] {\r\n display: none;\r\n}\r\n\r\n.as-finder-nav-ctn {\r\n overflow-y: auto;\r\n\r\n}\r\n\r\n.as-finder-content-ctn {\r\n overflow-y: auto;\r\n z-index: 1;\r\n}\r\n\r\n.as-finder.as-mini-layout .as-finder-body {\r\n left: 0;\r\n}\r\n\r\n.as-finder.as-mini-layout .as-finder-nav-ctn,\r\n.as-finder.as-mini-layout .as-finder-search-ctn {\r\n left: calc(var(--finder-nav-width) * -1);\r\n transition: left 0.2s;\r\n}\r\n\r\n\r\n.as-finder.as-mini-layout.as-nav-open .as-finder-nav-ctn,\r\n.as-finder.as-mini-layout.as-nav-open .as-finder-search-ctn {\r\n left: 0;\r\n}\r\n\r\n.as-finder.as-mini-layout.as-nav-open::after {\r\n content: \"\";\r\n display: block;\r\n z-index: 8;\r\n position: absolute;\r\n left: 0;\r\n top: var(--finder-header-height);\r\n width: 100%;\r\n height: 100%;\r\n background-color: rgba(169, 169, 172, 0.2);\r\n}\r\n\r\n\r\n.as-finder-content::before,\r\n.as-finder-content::after {\r\n content: \"\";\r\n display: block;\r\n}\r\n\r\n.as-finder-content .as-file-thumbnail {\r\n display: inline-block;\r\n margin: 5px;\r\n}\r\n\r\n\r\n.as-finder-content {\r\n user-select: none;\r\n min-height: 100%;\r\n box-sizing: border-box;\r\n position: relative;\r\n}\r\n\r\n\r\n.as-finder:not(.as-writable-folder) .as-finder-header button[name=\"upload\"],\r\n.as-finder:not(.as-writable-folder) .as-finder-header button[name=\"delete\"],\r\n.as-finder:not(.as-writable-folder) .as-finder-header button[name=\"rename\"],\r\n.as-finder:not(.as-writable-folder) .as-finder-header button[name=\"move\"],\r\n.as-finder.as-disable-create-folder .as-finder-header button[name=\"new_folder\"]\r\n{\r\n display: none;\r\n}\r\n\r\n.as-finder-select-area {\r\n position: fixed;\r\n box-sizing: border-box;\r\n border: 2px solid rgba(0, 103, 240, 0.5);\r\n width: 100px;\r\n height: 100px;\r\n background-color: rgba(0, 103, 240, 0.2);\r\n /*background-color: ;*/\r\n}\r\n\r\n.as-finder:not(.as-dragging) .as-file-thumbnail:hover {\r\n background-color: rgba(29, 161, 255, 0.13);\r\n}\r\n\r\n\r\n.as-finder-upload-overlay {\r\n display: none;\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n z-index: 4;\r\n backdrop-filter: blur(1px);\r\n -webkit-backdrop-filter: blur(1px);\r\n background-color: rgba(167, 167, 167, 0.1);\r\n font-size: 2rem;\r\n text-align: center;\r\n text-shadow: 2px 2px 3px white, -2px -2px 3px white, -2px 2px 3px white, 2px -2px 3px white;\r\n color: rgb(97, 79, 100);\r\n font-weight: bold;\r\n padding-top: calc(50% - 6em);\r\n}\r\n\r\n\r\n.as-finder-upload-overlay-icon-ctn {\r\n text-align: center;\r\n color: #1da1ff;\r\n font-size: 8rem;\r\n\r\n}\r\n\r\n.as-finder:not(.as-searching) .as-finder-body.as-drag-over .as-finder-upload-overlay {\r\n display: block;\r\n}\r\n\r\n\r\n.as-finder.as-searching .as-finder-nav-ctn {\r\n visibility: hidden;\r\n}\r\n\r\n.as-finder.as-searching .as-finder-search-ctn {\r\n visibility: visible;\r\n}\r\n\r\n.as-finder.as-searching .as-finder-content-header-right,\r\n.as-finder.as-searching .as-finder-header button[name='upload'],\r\n.as-finder.as-searching .as-finder-header button[name='move'] {\r\n display: none;\r\n}\r\n\r\n.as-finder-task-check {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-finder-task-check >span{\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-finder-task-check .mdi {\r\n font-size: 1.5em;\r\n color: rgb(30, 237, 219);\r\n}\r\n\r\n\r\n.as-finder-task-check .mdi.mdi-alert-decagram-outline {\r\n color: red;\r\n}\r\n\r\n\r\n/**************************************************/\r\n\r\n.as-file-thumbnail {\r\n display: inline-block;\r\n vertical-align: top;\r\n position: relative;\r\n}\r\n\r\n.as-file-thumbnail-background {\r\n display: block;\r\n width: 100px;\r\n height: 100px;\r\n background-size: contain;\r\n background-position: center;\r\n background-repeat: no-repeat;\r\n box-sizing: border-box;\r\n border: 1px solid #c0c0c0;\r\n}\r\n\r\n.as-file-thumbnail-check {\r\n display: none;\r\n position: absolute;\r\n top: -2px;\r\n left: -2px;\r\n bottom: -2px;\r\n right: -2px;\r\n overflow: hidden;\r\n z-index: 4;\r\n pointer-events: none;\r\n border: 2px solid #0a90eb;\r\n}\r\n\r\n.as-file-thumbnail.as-checked .as-file-thumbnail-check {\r\n display: block;\r\n}\r\n\r\n.as-file-thumbnail-check::before {\r\n content: \"\";\r\n position: absolute;\r\n right: -28px;\r\n top: -28px;\r\n width: 56px;\r\n height: 56px;\r\n transform: rotate(45deg);\r\n background-color: #0a90eb;\r\n}\r\n\r\n.as-file-thumbnail-check .mdi {\r\n display: inline-block;\r\n position: absolute;\r\n right: 5px;\r\n top: 5px;\r\n font-size: 14px;\r\n color: white;\r\n}\r\n\r\n.as-file-thumbnail-file-name {\r\n word-wrap: break-word; /* IE 5.5-7 */\r\n white-space: -moz-pre-wrap; /* Firefox 1.0-2.0 */\r\n white-space: pre-wrap;\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n width: 100px;\r\n max-height: 6.2em;\r\n line-height: 1.5;\r\n text-align: center;\r\n font-size: 13px;\r\n padding-top: 0.2em;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-file-thumbnail-file-name > span:last-child {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-finder-folder-dialog-tree-ctn {\r\n max-height: calc(90vh - 250px);\r\n overflow-y: auto;\r\n border: 1px solid #dddddd;\r\n}\r\n\r\n.as-finder-folder-dialog-tree-ctn > .as-exp-group {\r\n width: 300px;\r\n}\r\n\r\n.as-finder-folder-dialog-selected-ctn {\r\n padding-bottom: 10px;\r\n white-space: pre-wrap;\r\n}\r\n\r\n.as-finder-folder-dialog-selected-ctn > span {\r\n white-space: nowrap;\r\n}\r\n\r\ndiv[data-view-as=\"list\"] {\r\n --col: 1;\r\n}\r\n\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail {\r\n display: inline-block;\r\n margin-right: 4px;\r\n height: 50px;\r\n padding-left: 60px;\r\n white-space: nowrap;\r\n box-sizing: border-box;\r\n width: calc(100% / var(--col) - 10px * var(--col));\r\n}\r\n\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail-background {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 50px;\r\n height: 50px;\r\n}\r\n\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail-file-name {\r\n width: unset;\r\n max-width: 100%;\r\n text-align: left;\r\n}\r\n\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail-background,\r\ndiv[data-view-as=\"list\"] .as-file-thumbnail-file-name {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\ndiv[data-view-as=\"lage_icons\"] .as-file-thumbnail-background{\r\n width: 200px;\r\n height: 200px;\r\n}\r\n\r\ndiv[data-view-as=\"lage_icons\"] .as-file-thumbnail-file-name {\r\n width: 200px;\r\n}", ""]); /***/ }), /***/ 4521: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-flexicon-button {\r\n box-sizing: border-box;\r\n border: solid 1px #bfbfbf;\r\n background-color: #ebebeb;\r\n border-radius: 0.2em;\r\n outline: none;\r\n padding: 0;\r\n overflow: hidden;\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: var(--as-input-height);\r\n font-size: 1rem;\r\n cursor: pointer;\r\n color: black;\r\n}\r\n\r\n.as-flexicon-button:disabled {\r\n pointer-events: none;\r\n background-color: #c7c7c7 !important;\r\n}\r\n\r\n\r\n.as-flexicon-button div,\r\n.as-flexicon-button span {\r\n font-weight: inherit;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.as-icon-button-table-box {\r\n display: table;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-flexicon-button:hover .as-flexicon-button-content {\r\n background-color: rgba(0, 0, 0, 0.1);\r\n}\r\n\r\n.as-flexicon-button:active {\r\n -webkit-box-shadow: inset 0 0.2em 0.25em rgba(0, 0, 0, 0.125);\r\n box-shadow: inset 0 0.2em 0.25em rgba(0, 0, 0, 0.125);\r\n}\r\n\r\n\r\n.as-flexicon-button-content {\r\n display: table-row;\r\n}\r\n\r\n\r\n.as-flexicon-button-icon-container,\r\n.as-flexicon-button-text-container {\r\n display: table-cell;\r\n box-sizing: content-box;\r\n vertical-align: middle;\r\n text-align: center;\r\n}\r\n\r\n.as-flexicon-button-icon-container:empty,\r\n.as-flexicon-button-text-container:empty:not([data-ml-key]) {\r\n display: none;\r\n}\r\n\r\n.as-flexicon-button-icon-container {\r\n width: 2em;\r\n background-color: rgba(0, 0, 0, 0.0893617021);\r\n color: rgb(146, 146, 146);\r\n}\r\n\r\n\r\n.as-flexicon-button-icon-container > span,\r\n.as-flexicon-button-icon-container > i,\r\n.as-flexicon-button-icon-container > svg,\r\n.as-flexicon-button-icon-container > img {\r\n font-size: 1em;\r\n}\r\n\r\n.as-flexicon-button-text-container {\r\n padding-left: 0.357em;\r\n padding-right: 0.357em;\r\n box-sizing: border-box;\r\n min-width: 2em;\r\n}\r\n\r\n\r\n.as-flexicon-button-icon-container + .as-flexicon-button-text-container {\r\n border-left: solid 1px #bfbfbf;\r\n}\r\n\r\n.as-flexicon-button-icon-container:empty + .as-flexicon-button-text-container {\r\n border-left: none;\r\n padding-left: 0.714em;\r\n padding-right: 0.714em;\r\n}\r\n\r\n/*** theme ***/\r\n\r\n.as-flexicon-button.primary {\r\n border-color: #005bbd;\r\n background-color: #007bff;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.primary .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.primary .as-flexicon-button-text-container {\r\n border-color: #005bbd;\r\n}\r\n\r\n\r\n.as-flexicon-button.secondary {\r\n border-color: #4e555a;\r\n background-color: #6d767e;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.secondary .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.secondary .as-flexicon-button-text-container {\r\n border-left-color: #4e555a;\r\n}\r\n\r\n\r\n.as-flexicon-button.success {\r\n border-color: #1e7b34;\r\n background-color: #29a847;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.success .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.success .as-flexicon-button-text-container {\r\n border-left-color: #1e7b34;\r\n}\r\n\r\n\r\n.as-flexicon-button.danger {\r\n border-color: #b21f2e;\r\n background-color: #dc3848;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.danger .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.danger .as-flexicon-button-text-container {\r\n border-left-color: #b21f2e;\r\n}\r\n\r\n.as-flexicon-button.warning {\r\n border-color: #9e7700;\r\n background-color: #e0a800;\r\n color: black;\r\n}\r\n\r\n.as-flexicon-button.warning .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.warning .as-flexicon-button-text-container {\r\n border-left-color: #9e7700;\r\n}\r\n\r\n.as-flexicon-button.info {\r\n border-color: #117888;\r\n background-color: #17a2b8;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.info .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.info .as-flexicon-button-text-container {\r\n border-left-color: #117888;\r\n}\r\n\r\n.as-flexicon-button.light {\r\n border-color: #c9d1d9;\r\n background-color: #f8f9fa;\r\n color: #212529;\r\n}\r\n\r\n.as-flexicon-button.light .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.light .as-flexicon-button-text-container {\r\n border-left-color: #c9d1d9;\r\n}\r\n\r\n.as-flexicon-button.dark {\r\n border-color: #171a1c;\r\n background-color: #343a40;\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.dark .as-flexicon-button-icon-container {\r\n color: white;\r\n}\r\n\r\n.as-flexicon-button.dark .as-flexicon-button-text-container {\r\n border-left-color: #171a1c;\r\n}\r\n\r\n.as-flexicon-button.link {\r\n border-color: transparent;\r\n background-color: transparent;\r\n color: #007bff;\r\n}\r\n\r\n.as-flexicon-button.link .as-flexicon-button-icon-container {\r\n color: #007bff;\r\n background: transparent;\r\n}\r\n\r\n.as-flexicon-button.link .as-flexicon-button-text-container {\r\n border-left-color: transparent;\r\n}\r\n\r\n.as-flexicon-button.link:hover .as-flexicon-button-text-container {\r\n text-decoration: underline;\r\n}", ""]); /***/ }), /***/ 9677: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-flexicon-input-icon-ctn > span,\r\n.as-flexicon-input-icon-ctn > i,\r\n.as-flexicon-input-icon-ctn > svg,\r\n.as-flexicon-input-icon-ctn > img {\r\n font-size: 1em;\r\n line-height: 1;\r\n}\r\n\r\n.as-flexicon-input {\r\n position: relative;\r\n border: 1px solid #dddddd;\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 2em;\r\n font-size: 1rem;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n box-sizing: border-box;\r\n border-radius: 3px;\r\n text-align: left;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-flexicon-input.as-border-none {\r\n border: none;\r\n}\r\n\r\n.as-flexicon-input.as-disabled {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-flexicon-input::before {\r\n content: \"\";\r\n width: 0;\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-flexicon-input-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.as-flexicon-input:not(.as-flexicon-input-has-icon) input {\r\n padding-left: 0.3em;\r\n}\r\n\r\n.as-flexicon-input-icon-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n /*text-align: center;*/\r\n font-size: 1.2em;\r\n width: 1.25em;\r\n text-align: center;\r\n}\r\n\r\n.as-flexicon-input-unit-ctn {\r\n width: 1.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-align: center;\r\n}\r\n\r\n.as-flexicon-input-unit-ctn:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.as-flexicon-input input {\r\n border: none;\r\n font-size: inherit;\r\n font-family: inherit;\r\n outline: none;\r\n height: 100%;\r\n background-color: transparent;\r\n box-sizing: border-box;\r\n width: 100%;\r\n padding-left: 0;\r\n padding-right: 0;\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-align: inherit;\r\n}\r\n\r\n\r\n.as-flexicon-input.as-flexicon-input-has-icon input,\r\n.as-flexicon-input.as-flexicon-input-has-unit input {\r\n width: calc(100% - 1.5em);\r\n}\r\n\r\n.as-flexicon-input.as-flexicon-input-has-unit {\r\n text-align: right;\r\n}\r\n\r\n\r\n.as-flexicon-input.as-flexicon-input-has-icon.as-flexicon-input-has-unit input {\r\n width: calc(100% - 3em);\r\n}", ""]); /***/ }), /***/ 2893: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-follower {\r\n position: fixed;\r\n z-index: 100;\r\n}\r\n\r\n.absol-follower-hidden{\r\n z-index: -1000 !important;\r\n opacity: 0;\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 4110: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-font-input {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: calc(2em + 2px);\r\n width: 12em;\r\n border-radius: 3px;\r\n border: 1px solid #ddd;\r\n\r\n}\r\n\r\n.as-font-input-family {\r\n\r\n}\r\n\r\n.as-font-input-size {\r\n\r\n}\r\n\r\n\r\n\r\n.as-font-family-select-list {\r\n font-size: 16px;\r\n cursor: default;\r\n user-select: none;\r\n min-width: 12em;\r\n padding-top: 40px;\r\n\r\n}\r\n\r\n.as-font-family-select-list-header{\r\n padding: 5px;\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n box-sizing: border-box;\r\n height: 40px;\r\n top: 0;\r\n}\r\n\r\n.as-font-family-select-list-content {\r\n overflow-y: auto;\r\n}\r\n\r\n.as-font-family-select-item {\r\n height: 2em;\r\n line-height: 2em;\r\n padding: 0 20px 0 10px;\r\n\r\n}\r\n\r\n.as-font-family-select-item:hover {\r\n background-color: var(--as-list-item-hover-background-color);\r\n}\r\n\r\n.as-font-family-select-item:active {\r\n /*background-color: var(--as-list-item-active-background-color);*/\r\n}\r\n\r\n.as-font-family-select-item.as-selected {\r\n background-color: var(--as-list-item-selected-background-color);\r\n}", ""]); /***/ }), /***/ 2774: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-frame{\r\n \r\n}", ""]); /***/ }), /***/ 6952: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-frame-view {\r\n position: relative;\r\n}\r\n\r\n\r\n.absol-frame-view-frame-container {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n background-color: white;\r\n}\r\n\r\n\r\n.absol-frame-view-frame-container:not(.absol-active) {\r\n z-index: -100;\r\n visibility: hidden;\r\n opacity: 0;\r\n}\r\n\r\n.absol-frame-view-frame-container:not(.absol-active) *,\r\n.absol-frame-view-frame-container:not(.absol-active) {\r\n pointer-events: none;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n\r\n.absol-frame-view-frame-container > div {\r\n width: 100%;\r\n height: 100%;\r\n display: block;/* avoid overflow if this div is inline-block*/\r\n}", ""]); /***/ }), /***/ 2467: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-has-hanger-drag,\r\n.as-has-hanger-drag * {\r\n touch-action: none;\r\n -webkit-user-select: none !important;\r\n -moz-user-select: none !important;\r\n -ms-user-select: none !important;\r\n user-select: none !important;\r\n}", ""]); /***/ }), /***/ 8061: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-hexa-section-label {\r\n position: relative;\r\n -webkit-print-color-adjust: exact;\r\n /*friendly print*/\r\n}\r\n\r\n.as-hexa-section-label-text {\r\n position: relative;\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: 1em;\r\n padding-right: 2.5em;\r\n color: white;\r\n font-weight: bold;\r\n z-index: 2;\r\n}\r\n\r\n@media print {\r\n .as-hexa-section-label-text {\r\n color: white !important;\r\n }\r\n\r\n .as-hexa-section-label-index {\r\n color: rgb(237, 147, 54) !important;\r\n }\r\n}\r\n\r\n\r\n.as-hexa-section-label-index {\r\n position: relative;\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-align: center;\r\n color: rgb(237, 147, 54);\r\n font-weight: 900;\r\n z-index: 2;\r\n}\r\n\r\n.as-hexa-section-label-background {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n bottom: 0;\r\n z-index: 1;\r\n}\r\n\r\n.as-hexa-section-label-background>svg {\r\n display: block;\r\n}\r\n\r\n.as-hexa-section-label-index-box {\r\n stroke: rgb(251, 186, 130);\r\n fill: white;\r\n stroke-width: 2.5;\r\n}\r\n\r\n.as-hexa-section-label-text-box {\r\n fill: rgb(237, 147, 54);\r\n stroke: none;\r\n}", ""]); /***/ }), /***/ 7292: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/*margin for border size*/\r\n.as-hruler {\r\n position: relative;\r\n height: 1.5em;\r\n border: solid 1px black;\r\n overflow: hidden;\r\n font-family: courier, \"courier new\", monospace;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-hruler-line {\r\n position: absolute;\r\n bottom: 0;\r\n height: 25%;\r\n border-left: solid 1px rgb(17, 48, 43);\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-hruler-line.major {\r\n height: 50%;\r\n border-left: solid 1px rgb(5, 20, 18);\r\n}\r\n\r\n.as-hruler-major-number{\r\n position: absolute;\r\n text-align: center;\r\n width: 5em;\r\n pointer-events: none;\r\n font-size: 0.7em;\r\n bottom: 50%;\r\n} ", ""]); /***/ }), /***/ 3979: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "", ""]); /***/ }), /***/ 7871: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/****Adapt icon************/\r\n.fa-close:before {\r\n content: \"\\f00d\";\r\n}\r\n\r\n\r\n.kv-document-2-site {\r\n display: flex;\r\n align-content: stretch;\r\n}\r\n\r\n.kv-document-2-site-left {\r\n\r\n background-color: rgb(61, 29, 154);\r\n}\r\n\r\n.kv-document-2-site-right {\r\n flex-grow: 1;\r\n\r\n}\r\n\r\n.kv-document-2-site-left-header {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n padding: 25px 20px;\r\n\r\n}\r\n\r\n.kv-document-2-site-left-header-logo {\r\n height: 65px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-document-2-site-left-header-text {\r\n font-weight: bold;\r\n font-size: 25px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n color: #26afa8;\r\n}\r\n\r\n.kv-document-2-site-left .as-vertical-timeline {\r\n padding: 5px 20px;\r\n}\r\n\r\n\r\n/* For Document page */\r\n.kv-document-page {\r\n flex-direction: column;\r\n display: flex;\r\n}\r\n\r\ndiv.kv-document-page.absol-frame {\r\n display: flex;\r\n}\r\n\r\n.kv-document-page-header {\r\n position: relative;\r\n text-align: left;\r\n padding: 10px 10px 10px 10px;\r\n}\r\n\r\n.kv-document-page-title {\r\n font-size: 18px;\r\n font-weight: bold;\r\n line-height: 30px;\r\n}\r\n\r\n.kv-document-page-close-btn {\r\n float: right;\r\n}\r\n\r\n.kv-document-transparent-btn {\r\n background-color: transparent;\r\n border-radius: 50%;\r\n height: 30px;\r\n width: 30px;\r\n padding: 0;\r\n color: var(--as-transparent-button-text-color);\r\n font-size: 20px;\r\n border: none;\r\n}\r\n\r\n.kv-document-transparent-btn:hover {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n.kv-document-transparent-btn:active {\r\n color: var(--as-transparent-button-text-active-color);\r\n}\r\n\r\n\r\n.kv-document-page-content {\r\n flex-grow: 1;\r\n overflow: auto;\r\n padding: 10px 20px 10px 20px;\r\n}\r\n\r\n.kv-document-page-footer {\r\n display: flex;\r\n position: relative;\r\n padding: 30px 20px 10px 20px;\r\n}\r\n\r\n.kv-document-page-footer .as-flexicon-button {\r\n min-width: 110px;\r\n height: 30px;\r\n}\r\n\r\n.kv-document-page-footer-left {\r\n flex-grow: 1;\r\n}\r\n\r\n.kv-document-page-footer-left > *:not(:first-child) {\r\n margin-left: 20px;\r\n}\r\n\r\n.kv-document-page-footer-right {\r\n text-align: right;\r\n}\r\n\r\n\r\n.kv-document-page-footer-right > *:not(:last-child) {\r\n margin-right: 20px;\r\n}\r\n\r\n.kv-document-link {\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n color: black;\r\n cursor: pointer;\r\n height: 30px;\r\n padding: 0 20px;\r\n white-space: normal;\r\n border-radius: 3px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-document-link:hover {\r\n color: rgb(20, 100, 246);\r\n}\r\n\r\n\r\n.kv-document-link > span,\r\n.kv-document-link::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-document-link::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n\r\n.kv-document-link.kv-variant-primary {\r\n color: white;\r\n background-color: rgb(26, 146, 255);\r\n}\r\n\r\n\r\n/*************************************************************/\r\n\r\n.as-message-input-body .as-message-input-text-input {\r\n padding-left: var(--control-horizontal-distance-2);\r\n padding-top: var(--control-verticle-distance-1);\r\n padding-bottom: var(--control-verticle-distance-1);\r\n padding-right: var(--control-horizontal-distance-2);\r\n min-height: 40px;\r\n}\r\n\r\n/*TODO: find usage*/\r\n.bsc-white .absol-selectmenu-anchor-content-container {\r\n z-index: 200001;\r\n}\r\n\r\n.bsc-white .absol-context-menu-anchor {\r\n font-size: var(--font-size-right-mouse-menu);\r\n}\r\n\r\n.card-mobile-content > div:not([class]):first-child:last-child .as-dynamic-table-wrapper.as-overflow-y {\r\n height: 100%;\r\n}\r\n\r\n/* todo: normalize for all module\r\n.absol-selectmenu-holder-item .absol-selectlist-item-text,\r\n.absol-selectmenu-holder-item .absol-selectlist-item-desc {\r\n line-height: calc(var(--control-height) - 10px);\r\n}\r\n\r\n.bsc-white .absol-selectmenu {\r\n height: var(--control-height);\r\n font-size: var(--font-size-text-input);\r\n}\r\n\r\n.bsc-white .absol-selectlist .absol-selectlist-item {\r\n font-size: var(--font-size-text-input);\r\n height: 1.42857142857em;\r\n}\r\n\r\n.bsc-white .absol-selectlist .absol-selectlist-item>span {\r\n line-height: 1.42857142857;\r\n}\r\n\r\n.bsc-white .absol-search-text-input {\r\n font-size: var(--font-size-text-input);\r\n}\r\n\r\n */\r\n\r\n.absol-single-page.as-has-footer-margin > .absol-single-page-scroller{\r\n padding-bottom: var(--footer-margin);\r\n}", ""]); /***/ }), /***/ 2189: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".kv-overview-widget {\r\n background-color: rgb(212, 227, 252);\r\n padding: 0 5px 5px 5px;\r\n border-radius: 3px;\r\n box-sizing: border-box;\r\n display: inline-block;\r\n width: 25em;\r\n height: 40em;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n position: fixed;\r\n --x: 0;\r\n --y: 0;\r\n left: var(--x);\r\n top: var(--y);\r\n z-index: 3000000;\r\n}\r\n\r\n.kv-overview-widget-header {\r\n height: 2em;\r\n padding-left: calc(10em / 14);\r\n user-select: none;\r\n position: relative;\r\n}\r\n\r\n.kv-overview-widget-header-window-action {\r\n position: absolute;\r\n right: 5px;\r\n top: calc(50% - 10em / 14);\r\n height: calc(20em / 14);\r\n display: inline-block;\r\n}\r\n\r\n.kv-overview-widget-header-window-action button {\r\n background-color: transparent;\r\n border-radius: 3px;\r\n padding: 0;\r\n border: none;\r\n width: 20px;\r\n height: 20px;\r\n color: rgb(69, 69, 70);\r\n}\r\n\r\n.kv-overview-widget-header-window-action button:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.kv-overview-widget-header-window-action button:hover {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.kv-overview-widget-title {\r\n font-weight: bold;\r\n display: inline-block;\r\n line-height: 2em;\r\n}\r\n\r\n.kv-overview-widget-body {\r\n box-sizing: border-box;\r\n padding-top: 5px;\r\n background-color: white;\r\n height: calc(100% - 2em);\r\n position: relative;\r\n}\r\n\r\n.kv-overview-widget-body > .absol-tabview > .absol-tabbar .absol-hscroller-viewport {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.kv-overview-widget-body > .absol-tabview > .absol-tabbar .absol-hscroller-viewport {\r\n padding-left: 5px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.kv-overview-widget-body > .absol-tabview > .absol-tabbar .as-tab-bar-button-ext-icon-ctn {\r\n margin: 0;\r\n}\r\n\r\n.kv-overview-widget-page > div {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.kv-overview-widget-tab-view .absol-tabbar-button > .absol-tabbar-button-icon-container {\r\n display: none;\r\n}\r\n\r\n.kv-overview-widget-tab-view .absol-tabbar-button {\r\n min-width: 70px;\r\n text-align: left;\r\n}\r\n\r\n.kv-overview-widget-tab-view {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.kv-overview-widget-bubble {\r\n position: fixed;\r\n z-index: 3000000;\r\n width: 54px;\r\n height: 54px;\r\n border-radius: 50%;\r\n background-color: white;\r\n box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.75);\r\n -webkit-box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.75);\r\n -moz-box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.75);\r\n user-select: none;\r\n}\r\n\r\n.kv-overview-widget-bubble:hover {\r\n background-color: rgb(240, 240, 250);\r\n\r\n}\r\n\r\n.kv-overview-widget-bubble:active {\r\n box-shadow: 2px 2px 5px 0px rgba(0, 0, 0, 0.75);\r\n -webkit-box-shadow: 2px 2px 5px 0px rgba(0, 0, 0, 0.75);\r\n -moz-box-shadow: 2px 2px 5px 0px rgba(0, 0, 0, 0.75);\r\n}\r\n\r\n.kv-overview-widget-bubble-background {\r\n position: absolute;\r\n left: 20%;\r\n top: 20%;\r\n width: 60%;\r\n height: 60%;\r\n pointer-events: none;\r\n}\r\n\r\n.kv-overview-widget-bubble-badge {\r\n position: absolute;\r\n left: calc(85% - 10px);\r\n bottom: calc(85% - 10px);\r\n text-align: center;\r\n padding:0 3px ;\r\n background-color: rgba(255, 0, 0, 0.7);\r\n color: white;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n height: 30px;\r\n min-width: 30px;\r\n white-space: nowrap;\r\n border-radius: 15px;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.kv-overview-widget-bubble-badge span,\r\n.kv-overview-widget-bubble-badge::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-overview-widget-bubble-badge::before{\r\n content:\"\" ;\r\n height: 100%;\r\n}", ""]); /***/ }), /***/ 2336: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".kv-ow-modal-manager {\r\n position: absolute;\r\n z-index: 3000010;\r\n width: 100%;\r\n height: 100%;\r\n left: 0;\r\n top: 0;\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n background-color: rgba(0, 0, 0, 0.502);\r\n box-sizing: border-box;\r\n overflow: auto;\r\n padding-top: 10px;\r\n padding-bottom: 10px;\r\n}\r\n\r\n.kv-ow-modal-manager:empty {\r\n display: none;\r\n}\r\n\r\n.kv-ow-modal {\r\n white-space: nowrap;\r\n text-align: center;\r\n position: absolute;\r\n z-index: 1;\r\n left: 0;\r\n right: 0;\r\n width: 100%;\r\n height: 100%;\r\n box-sizing: border-box;\r\n padding: 60px 20px 10px 20px;\r\n}\r\n\r\n.kv-ow-modal::before {\r\n content: \"\";\r\n height: 66%;\r\n}\r\n\r\n.kv-ow-modal::before,\r\n.kv-ow-modal-window {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.kv-ow-modal-window {\r\n background-color: white;\r\n white-space: normal;\r\n text-align: left;\r\n -webkit-box-shadow: 2px 2px 6px 0 rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0 rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0 rgba(0, 0, 90, 0.55);\r\n border-radius: 4px;\r\n max-width: 100%;\r\n max-height: 100%;\r\n overflow: hidden;\r\n box-sizing: border-box;\r\n display: inline-flex;\r\n flex-direction: column;\r\n align-items: stretch;\r\n}\r\n\r\n.kv-ow-modal-title {\r\n font-size: 14px;\r\n line-height: 1.5;\r\n font-weight: bold;\r\n}\r\n\r\n.kv-ow-modal-header {\r\n padding: 10px 10px 5px 10px;\r\n}\r\n\r\n.kv-ow-modal-body {\r\n flex-grow: 1;\r\n overflow-y: auto;\r\n padding: 10px 10px;\r\n}\r\n\r\n.kv-ow-modal-footer {\r\n padding: 10px 10px;\r\n text-align: center;\r\n}\r\n\r\n.kv-ow-modal-header:empty,\r\n.kv-ow-modal-body:empty,\r\n.kv-ow-modal-footer:empty {\r\n display: none;\r\n}\r\n\r\n.kv-ow-modal-footer > button {\r\n height: 30px;\r\n min-width: 110px;\r\n}\r\n\r\n\r\n.kv-ow-modal-footer > button:not(:last-child) {\r\n margin-right: 20px;\r\n}", ""]); /***/ }), /***/ 657: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".kv-comment-item {\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n position: relative;\r\n\r\n padding: 0 calc(2em + 7px) 0 calc(2.85em + 20px);\r\n cursor: pointer;\r\n background-color: white;\r\n}\r\n\r\n.kv-comment-item:hover{\r\n background-color: #f2f5fa;\r\n}\r\n\r\n\r\n.kv-comment-avatar-ctn {\r\n position: absolute;\r\n left: 10px;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.kv-comment-avatar-ctn::before,\r\n.kv-comment-item-flag-ctn::before {\r\n content: \"\";\r\n display: inline-block;\r\n height: 100%;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-comment-avatar {\r\n width: 2.85em;\r\n height: 2.85em;\r\n background-size: cover;\r\n border-radius: 50%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.kv-comment-item-content {\r\n padding: 5px 10px;\r\n border: 1px solid #d6d6d6;\r\n border-radius: 7px;\r\n line-height: 1.5;\r\n}\r\n\r\n\r\n.kv-comment-item-flag-ctn {\r\n position: absolute;\r\n right: 10px;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.kv-comment-item-flag-unread {\r\n display: none;\r\n vertical-align: middle;\r\n width: 0.75em;\r\n height: 0.75em;\r\n background-color: blue;\r\n border-radius: 50%;\r\n}\r\n\r\n.kv-comment-item.as-unread .kv-comment-item-flag-unread {\r\n display: inline-block;\r\n}\r\n\r\n.kv-comment-item-time {\r\n font-weight: bold;\r\n}", ""]); /***/ }), /***/ 228: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-linear-color-bar {\r\n position: relative;\r\n height: 2em;\r\n}\r\n\r\n.as-linear-color-background {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n display: block;\r\n}\r\n\r\n.as-linear-color-value-text {\r\n position: absolute;\r\n top: 0;\r\n font-weight: 900;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-linear-color-min-value-text,\r\n.as-linear-color-max-value-text {\r\n position: absolute;\r\n bottom: 0;\r\n white-space: nowrap;\r\n font-weight: bold;\r\n}\r\n\r\n\r\n\r\n.as-linear-color-min-value-text {\r\n left: 0;\r\n}\r\n\r\n.as-linear-color-rect {\r\n stroke: none;\r\n}\r\n\r\n\r\n.as-linear-color-value-arrow {\r\n fill: rgb(244, 124, 32);\r\n stroke: rgb(244, 124, 32);\r\n}\r\n\r\n.as-linear-color-split-line {\r\n stroke: white;\r\n}\r\n\r\n\r\n.as-linear-color-tiny-bar {\r\n font-size: 1rem;\r\n --value: 1;\r\n --extend: 0.5;\r\n --color: green;\r\n position: relative;\r\n\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.as-linear-color-tiny-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n padding-right: 0.3em;\r\n width: 4em;\r\n text-align: right;\r\n}\r\n\r\n.as-linear-color-tiny-bar-rect {\r\n height: calc(10em / 14);\r\n width: calc(10em * var(--value) / 1.4);\r\n max-width: calc(10em / 1.4 + 10em * var(--extend) / 1.4);\r\n min-width: 3px;\r\n background-color: var(--color);\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n", ""]); /***/ }), /***/ 3526: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-list-compare-tool {\r\n border: 1px solid #ddd;\r\n box-sizing: border-box;\r\n font-size: 14px;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n\r\n --item-min-width: 10px;\r\n min-width: calc(var(--item-min-width) + var(--item-min-width) + 122px + 44px);\r\n overflow: hidden;\r\n --list-max-height: auto;\r\n position: relative;\r\n}\r\n\r\n.as-remove-line-tool-active .as-list-compare-tool-body,\r\n.as-remove-line-tool-active .as-lct-item {\r\n cursor: none;\r\n}\r\n\r\n.as-lct-cursor {\r\n position: absolute;\r\n pointer-events: none;\r\n z-index: 1e9;\r\n top: -100px;\r\n left: -100px;\r\n font-size: 25px;\r\n width: 30px;\r\n height: 30px;\r\n color: rgba(0, 0, 0, 0.75);\r\n}\r\n\r\n.as-list-compare-tool-header {\r\n padding-bottom: 5px;\r\n border-bottom: 1px solid #ddd;\r\n}\r\n\r\n.as-list-compare-tool-header .as-form-cmd-tool,\r\n.as-list-compare-tool-check-ctn {\r\n display: inline-block;\r\n vertical-align: top;\r\n}\r\n\r\n.as-list-compare-tool-header .as-cmd-tool-group-x2::before {\r\n display: none;\r\n}\r\n\r\n.as-list-compare-tool-body {\r\n width: 100%;\r\n white-space: nowrap;\r\n position: relative;\r\n padding: 30px 10px 10px 10px;\r\n box-sizing: border-box;\r\n overflow: hidden;\r\n}\r\n\r\n.as-list-compare-tool-before-title,\r\n.as-list-compare-tool-after-title{\r\n position: absolute;\r\n top: 5px;\r\n line-height: 20px;\r\n background-color: white;\r\n z-index: 11;\r\n}\r\n\r\n.as-list-compare-tool-before-title {\r\n left: 10px;\r\n line-height: 20px;\r\n}\r\n\r\n.as-list-compare-tool-after-title {\r\n left: calc(50% + 60px);\r\n}\r\n\r\n.as-list-compare-tool-before-title::before {\r\n content: \"Form cũ\";\r\n}\r\n\r\n\r\n.as-list-compare-tool-after-title::before {\r\n content: \"Form mới\";\r\n}\r\n\r\n/*.as-list-compare-tool.as-display-inline {*/\r\n/* display: inline-block;*/\r\n/*}*/\r\n\r\n.as-list-compare-tool-before,\r\n.as-list-compare-tool-after,\r\n.as-list-compare-tool-spacing {\r\n display: inline-block;\r\n vertical-align: top;\r\n position: relative;\r\n\r\n}\r\n\r\n\r\n.as-list-compare-tool-before,\r\n.as-list-compare-tool-after {\r\n border: 1px solid #ddd;\r\n box-sizing: border-box;\r\n width: calc(50% - 60px);\r\n max-height: var(--list-max-height);\r\n overflow-block: auto;\r\n}\r\n\r\n\r\n.as-list-compare-tool-before .as-lct-item:not(:last-child),\r\n.as-list-compare-tool-after .as-lct-item:not(:last-child) {\r\n border-bottom: 1px solid #ddd;\r\n height: 29px;\r\n}\r\n\r\n\r\n.as-list-compare-tool-spacing {\r\n width: 120px;\r\n height: 30px;\r\n}\r\n\r\n.as-list-compare-tool-operators > svg {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-list-compare-tool-operators {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n width: 100%;\r\n height: 100%;\r\n pointer-events: none;\r\n z-index: 10;\r\n}\r\n\r\n.as-list-compare-tool-operators > svg .as-lct-line-group:not(.as-same-value) .as-lct-line-hit-box {\r\n pointer-events: all;\r\n}\r\n\r\n.as-list-compare-tool.as-view-changed {\r\n\r\n}\r\n\r\n\r\n.as-list-compare-tool.as-view-unchanged {\r\n\r\n}\r\n\r\n\r\n.as-list-compare-tool.as-remove-line-tool-active .as-lct-line-group:hover:not(.as-same-value) .as-lct-line-hit-box {\r\n stroke: rgba(255, 100, 0, 0.5);\r\n}\r\n\r\n\r\n.as-lct-line {\r\n fill: none;\r\n stroke: blue;\r\n}\r\n\r\n.as-lct-line-hit-box {\r\n stroke-width: 8px;\r\n stroke: transparent;\r\n}\r\n\r\n.as-lct-line-group.as-same-value .as-lct-line {\r\n stroke: #9cf6b6;\r\n}\r\n\r\n.as-lct-line.as-new-line {\r\n stroke: #c07777;\r\n}\r\n\r\n.as-lct-arrow {\r\n fill: blue;\r\n stroke: none;\r\n}\r\n\r\n.as-lct-same-value-arrow {\r\n fill: #9cf6b6;\r\n stroke: none;\r\n}\r\n\r\n.as-lct-new-line-arrow {\r\n stroke: none;\r\n fill: #c07777;\r\n}\r\n\r\n\r\n.as-lct-item {\r\n white-space: nowrap;\r\n height: 28px;\r\n box-sizing: border-box;\r\n padding-right: 10px;\r\n position: relative;\r\n overflow: visible;\r\n padding-left: 10px;\r\n}\r\n\r\n\r\n.as-list-compare-tool.as-view-changed-only .as-lct-item:not(.as-mapped):not(.as-removed):not(.as-added) {\r\n display: none;\r\n}\r\n\r\n.as-lct-item.as-removed {\r\n background-color: #fbcece;\r\n}\r\n\r\n.as-lct-item.as-added {\r\n background-color: #cedbfb;\r\n}\r\n\r\n\r\n.as-lct-item:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-lct-item.as-active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.as-lct-item::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-lct-item::after {\r\n content: \"\";\r\n display: block;\r\n position: absolute;\r\n z-index: 5;\r\n top: calc(50% - 5px);\r\n right: 5px;\r\n width: 10px;\r\n height: 10px;\r\n background-color: #cdcdcd;\r\n border-radius: 50%;\r\n}\r\n\r\n\r\n.as-lct-item.as-removed,\r\n.as-lct-item.as-added {\r\n cursor: pointer;\r\n}\r\n\r\n.as-lct-item.as-removed::after,\r\n.as-lct-item.as-added::after {\r\n background-color: #37e0e0;\r\n\r\n}\r\n\r\n\r\n\r\n.as-list-compare-tool-after .as-lct-item::after {\r\n left: 5px;\r\n}\r\n\r\n.as-list-compare-tool-after .as-lct-item {\r\n padding-left: 15px;\r\n}\r\n\r\n\r\n.as-lct-item-text {\r\n padding-right: 20px;\r\n}\r\n\r\n.as-lct-item-text,\r\n.as-lct-item-icon-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-lct-item-icon-ctn {\r\n width: 25px;\r\n height: 20px;\r\n text-align: left;\r\n}\r\n\r\n.as-lct-item-icon-ctn > * {\r\n font-size: 20px;\r\n display: block;\r\n}\r\n\r\n.as-lct-item-text::before {\r\n content: attr(data-text);\r\n}", ""]); /***/ }), /***/ 7188: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-location-input-modal {\r\n z-index: 800001;\r\n background-color: rgb(0, 0, 0, 0.1);\r\n}\r\n\r\n\r\n.as-location-picker-control-ctn {\r\n margin: 10px;\r\n background-color: white;\r\n box-shadow: rgb(0 0 0 / 30%) 0px 1px 4px -1px;\r\n border-radius: 2px;\r\n}\r\n\r\n\r\n.as-location-picker-control-btn {\r\n width: 40px;\r\n height: 40px;\r\n padding: 0;\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border: none;\r\n color: rgb(102, 102, 102);\r\n}\r\n\r\n.as-location-picker-control-btn:hover {\r\n color: black;\r\n}\r\n\r\n.gm-ui-hover-effect {\r\n outline: none;\r\n}\r\n\r\n.as-location-picker-control-btn > span {\r\n font-size: 2em;\r\n}\r\n\r\n\r\n.as-location-picker-search-input {\r\n height: 30px;\r\n width: 250px;\r\n border-radius: 2px;\r\n padding-right: 30px;\r\n position: relative;\r\n}\r\n\r\n.as-location-picker-search-input > input {\r\n outline: none;\r\n}\r\n\r\n\r\n.as-location-picker-search-input-search-icon-ctn {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n width: 30px;\r\n text-align: center;\r\n font-size: 20px;\r\n color: rgb(102, 102, 102);\r\n}\r\n\r\n.as-location-picker-search-input-search-icon-ctn:hover {\r\n color: black;\r\n}\r\n\r\n.as-location-picker-search-input-search-icon-ctn::before,\r\n.as-location-picker-search-input-search-icon-ctn > span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-location-picker-search-input-search-icon-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-location-picker-control-ctn .as-flexicon-button {\r\n font-size: 14px;\r\n min-width: 9em;\r\n height: calc(2em + 2px);\r\n}\r\n\r\n.as-location-picker-control-ctn .as-flexicon-button:not(:last-child) {\r\n margin-right: 20px;\r\n}\r\n\r\n\r\n.as-location-picker-control-ctn.as-transparent {\r\n background-color: transparent;\r\n box-shadow: none;\r\n}\r\n\r\n.as-location-picker.as-read-only .as-location-picker-cancel-btn,\r\n.as-location-picker.as-read-only .as-location-picker-search-input {\r\n display: none;\r\n}\r\n\r\n.as-location-picker-control-ctn.as-bottom button{\r\n box-shadow: 0 0px 2px 4px white;\r\n -webkit-box-shadow: 0 0 2px 4px white;\r\n -moz-box-shadow: 0 0 2px 4px white;\r\n}\r\n\r\n\r\n.as-location-input-modal {\r\n\r\n}\r\n\r\n.as-location-input-modal-window {\r\n padding: 10px;\r\n width: calc(100vw - 10px);\r\n height: calc(100vh - 10px);\r\n box-sizing: border-box;\r\n max-width: 900px;\r\n max-height: 600px;\r\n box-shadow: 0px 1px 4px -1px rgba(0, 0, 0, 0.7);\r\n -webkit-box-shadow: 0px 1px 4px -1px rgba(0, 0, 0, 0.7);\r\n border-radius: 5px;\r\n background-color: white;\r\n}\r\n\r\n\r\n.as-location-input-modal-window > .as-location-picker {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.as-location-input {\r\n height: var(--as-input-height);\r\n border-radius: var(--as-input-border-radius);\r\n border: 1px solid #dddddd;\r\n box-sizing: border-box;\r\n width: calc(13em + 50px);\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n background-color: white;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n\r\n.as-location-input.as-disabled {\r\n background-color: var(--as-disabled-background-color);\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-location-input-text {\r\n outline: none;\r\n width: calc(100% - 2em - 1px);\r\n height: 100%;\r\n border: none;\r\n background-color: transparent;\r\n display: block;\r\n padding: 0 0 0 var(--as-input-horizontal-padding);\r\n font: inherit;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.as-location-input-icon-ctn {\r\n border-left: 1px solid #ddd;\r\n border-right: none;\r\n border-top: none;\r\n border-bottom: none;\r\n text-align: center;\r\n position: absolute;\r\n right: 0;\r\n width: calc(2rem + 1px);\r\n box-sizing: border-box;\r\n top: 0;\r\n height: 100%;\r\n background-color: rgba(169, 169, 169, 0.1);\r\n cursor: pointer;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.as-location-input-icon-ctn:hover {\r\n background-color: rgba(169, 169, 169, 0.25);\r\n}\r\n\r\n.as-location-input-icon-ctn:active {\r\n background-color: rgba(169, 169, 169, 0.5);\r\n}\r\n\r\n\r\n.as-location-input-icon-ctn > span {\r\n line-height: 2em;\r\n font-size: calc(16em / 14);\r\n}\r\n\r\n.as-location-input.as-disabled {\r\n color: var(--as-disabled-text-color);\r\n pointer-events: none;\r\n}\r\n\r\n.as-location-input.as-disabled input {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-location-input.as-value-null .as-location-input-clear-btn,\r\n.as-location-input.as-must-not-null .as-location-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n.as-location-input-clear-btn {\r\n font-size: inherit;\r\n position: absolute;\r\n right: calc(2em + 2px);\r\n height: calc(2em + 2px);\r\n top: calc(50% - -1em - 1px);\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border: none;\r\n color: #bbb;\r\n visibility: hidden;\r\n}\r\n\r\n.as-location-input-clear-btn:hover {\r\n color: rgb(132, 132, 132)\r\n}\r\n\r\n.as-location-input-clear-btn:active {\r\n color: #525555;\r\n}\r\n\r\n.as-location-input-text:focus + .as-location-input-clear-btn,\r\n.as-location-input:hover .as-location-input-clear-btn {\r\n visibility: visible;\r\n}\r\n\r\n\r\n@media screen and (max-width: 600px) {\r\n .as-location-input-modal-window {\r\n max-width: unset;\r\n max-height: unset;\r\n\r\n }\r\n}\r\n\r\n\r\n@media screen and (max-width: 500px) {\r\n .as-location-picker-control-ctn.as-top {\r\n margin-top: 60px;\r\n width: calc(100% - 20px);\r\n }\r\n\r\n .as-location-picker-control-ctn.as-top .as-location-picker-search-input {\r\n width: 100%;\r\n }\r\n\r\n .as-location-input-modal-window {\r\n padding: 0;\r\n }\r\n\r\n .as-location-picker-control-ctn.as-bottom button{\r\n margin-top: 20px;\r\n }\r\n}\r\n\r\n\r\n.as-location-input-modal.as-mobile .as-location-input-modal-window {\r\n height: calc(100vh - 80px);\r\n}", ""]); /***/ }), /***/ 5490: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vmedia-no-show {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n width: 1;\r\n height: 1;\r\n z-index: -100000;\r\n opacity: 0;\r\n}\r\n\r\n.vmedia-no-select,\r\n.vmedia-no-select * {\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n}\r\n\r\ncoccocgrammar {\r\n display: none;\r\n}\r\n\r\n.vmedia-media-input {\r\n box-sizing: border-box;\r\n border: solid 1px rgba(0, 0, 0, 0.1)\r\n}\r\n\r\n\r\n.vmedia-media-input-text-container {\r\n position: relative;\r\n min-height: 2.5em;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor:focus {\r\n outline: none;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor img {\r\n display: none;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor * {\r\n font-family: inherit;\r\n font-size: inherit;\r\n font-weight: inherit;\r\n text-decoration: inherit;\r\n color: inherit;\r\n background: none;\r\n padding: 0;\r\n margin: 0;\r\n white-space: pre;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor {\r\n min-height: 2em;\r\n padding-left: 0.5em;\r\n padding-top: 0.25em;\r\n padding-bottom: 0.25em;\r\n margin-right: 0.5em;\r\n box-sizing: border-box;\r\n max-height: 6.66666666em;\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n}\r\n\r\n.vmedia-media-input-imagepreview-container {\r\n white-space: normal;\r\n}\r\n\r\n.vmedia-media-input:not(.dragover) .vmedia-media-input-dropover {\r\n display: none;\r\n}\r\n\r\n.vmedia-media-input-dropover {\r\n display: inline-block;\r\n width: 7em;\r\n height: 7em;\r\n}\r\n\r\n.vmedia-media-input-dropover>svg {\r\n width: 7em;\r\n height: 7em;\r\n}\r\n\r\n.vmedia-media-input-imagepreview-container .vmedia-media-input-filepreview,\r\n.vmedia-media-input-imagepreview-container .vmedia-media-input-imagepreview {\r\n margin: 0.3em;\r\n vertical-align: middle;\r\n}\r\n\r\n.vmedia-media-input-filepreview,\r\n.vmedia-media-input-imagepreview {\r\n position: relative;\r\n display: inline-block;\r\n}\r\n\r\n.vmedia-media-input-imagepreview img {\r\n height: 2.5em;\r\n width: auto;\r\n}\r\n\r\n.vmedia-media-input-filepreview svg.attachment {\r\n height: 2em;\r\n width: 2em;\r\n}\r\n\r\n.vmedia-media-input-filepreview svg.times,\r\n.vmedia-media-input-imagepreview svg.times {\r\n position: absolute;\r\n top: 0.1em;\r\n right: 0.1em;\r\n width: 1em;\r\n height: 1em;\r\n fill: rgba(69, 69, 69, 0.6);\r\n}\r\n\r\n.vmedia-media-input-filepreview svg.times:hover,\r\n.vmedia-media-input-imagepreview svg.times:hover {\r\n fill: rgba(144, 144, 144, 0.6);\r\n}\r\n\r\n.vmedia-media-input-filepreview svg.times:active,\r\n.vmedia-media-input-imagepreview svg.times:active {\r\n fill: rgba(220, 220, 240, 0.6);\r\n}\r\n\r\n.vmedia-media-input-plug-button-container {\r\n position: absolute;\r\n left: 0.25em;\r\n bottom: 0.25em;\r\n top: 0.25em;\r\n}\r\n\r\n.vmedia-media-input-plug-button-container svg {\r\n height: 1.5em;\r\n width: 1.5em;\r\n vertical-align: middle;\r\n transition: transform .22s cubic-bezier(.5, 0, .4, 1);\r\n}\r\n\r\n\r\n.vmedia-media-input-plug-button-container svg path {\r\n fill: rgba(66, 133, 244, 0.7);\r\n transition: fill .22s cubic-bezier(.5, 0, .4, 1);\r\n}\r\n\r\n.vmedia-media-input.show-plugin .vmedia-media-input-plug-button svg path {\r\n fill: rgba(134, 142, 153, 0.75);\r\n}\r\n\r\n\r\n\r\n.vmedia-media-input-plug-button {\r\n padding: 0;\r\n height: 100%;\r\n width: 2em;\r\n border: none;\r\n background: transparent;\r\n outline: none;\r\n\r\n}\r\n\r\n\r\n.vmedia-media-input-plugin-content-container {\r\n position: absolute;\r\n bottom: calc(1px + 100%);\r\n opacity: 1;\r\n transition: opacity .22s cubic-bezier(.5, 0, .4, 1);\r\n background-color: white;\r\n box-sizing: border-box;\r\n border: solid 1px rgba(0, 0, 0, 0.1);\r\n z-index: 20;\r\n background: white;\r\n}\r\n\r\n.vmedia-media-input-plugin-content-container:empty{\r\n display: none;\r\n}\r\n\r\n\r\n\r\n.vmedia-media-input-tool-container {\r\n position: relative;\r\n display: block;\r\n height: 1.5em;\r\n /* background: red; */\r\n}\r\n\r\n\r\n\r\n.vmedia-media-input-tool-container-left {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.vmedia-media-input-tool-container-right {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.vmedia-media-input-tool-container button {\r\n width: 2.5em;\r\n height: 100%;\r\n font-size: 1em;\r\n margin-left: 0.1em;\r\n margin-right: 0.1em;\r\n border: none;\r\n background-color: transparent;\r\n border-radius: 0.4em;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor {\r\n scrollbar-width: thin;\r\n}\r\n\r\n.vmedia-media-input-text-container-editor::-webkit-scrollbar {\r\n width: 7px;\r\n}\r\n\r\n\r\n\r\n.vmedia-media-input-text-container-editor::-webkit-scrollbar-track {\r\n background: rgb(240, 240, 240);\r\n}\r\n\r\n.vmedia-media-input-text-container-editor::-webkit-scrollbar-thumb {\r\n background: rgb(205, 205, 205);\r\n}\r\n\r\n.vmedia-media-input-tool-container button svg {\r\n height: 1.25em;\r\n width: 1.25em;\r\n}\r\n\r\n.vmedia-media-input-tool-container button:hover {\r\n background-color: rgba(91, 192, 222, 0.1);\r\n}\r\n\r\n.vmedia-media-input-tool-container button:active {\r\n background-color: rgba(91, 192, 222, 0.4);\r\n}\r\n\r\n.vmedia-media-input-tool-container button svg.send {\r\n fill: rgba(66, 133, 244, 0.7);\r\n}\r\n\r\n.vmedia-media-input-tool-container button svg.add-file,\r\n.vmedia-media-input-tool-container button svg.add-image {\r\n fill: rgba(66, 66, 66, 0.5);\r\n}\r\n\r\n.vmedia-media-input-tool-container button .mdi{\r\n font-size:1.2em; \r\n}\r\n\r\n.vmedia-media-input-tool-container button:focus {\r\n outline: none;\r\n}\r\n\r\n.vmedia-media-input-tool-container button{\r\n vertical-align: middle;\r\n}\r\n\r\n.vmedia-media-input-plugin-content-container.blur{\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 6329: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-ico {\r\n width: 1em;\r\n height: 1em;\r\n}\r\n\r\n.absol-button {\r\n white-space: normal;\r\n -webkit-touch-callout: none;\r\n -webkit-user-select: none;\r\n -khtml-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n}\r\n\r\n.absol-dropdown {\r\n position: relative;\r\n}\r\n\r\n.absol-dropdown-content {\r\n z-index: 1;\r\n position: fixed;\r\n left: 0;\r\n top: 0;\r\n overflow: auto;\r\n -webkit-touch-callout: none;\r\n -webkit-user-select: none;\r\n -khtml-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n}\r\n\r\n.absol-dropdown.top > .absol-dropdown-content {\r\n top: auto;\r\n bottom: 100%;\r\n}\r\n\r\n.absol-dropdown.overlap-left > .absol-dropdown-content {\r\n left: auto;\r\n right: 0;\r\n}\r\n\r\n.absol-dropright {\r\n position: relative;\r\n}\r\n\r\n.absol-dropright-content {\r\n z-index: 1;\r\n position: fixed;\r\n left: 0;\r\n top: 0;\r\n -webkit-touch-callout: none;\r\n -webkit-user-select: none;\r\n -khtml-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n overflow: auto;\r\n}\r\n\r\n.absol-dropright.overlap-top > .absol-dropright-content {\r\n top: unset;\r\n bottom: 0;\r\n}\r\n\r\n.absol-drop-hidden > .absol-dropdown-content,\r\n.absol-drop-hidden > .absol-dropright-content {\r\n visibility: hidden;\r\n top: 0 !important;\r\n left: 0 !important;\r\n max-height: 99vh !important;\r\n opacity: 0;\r\n pointer-events: none;\r\n}\r\n\r\n.absol-drop-hidden > .absol-dropright-content *,\r\n.absol-drop-hidden > .absol-dropdown-content * {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-hmenu {\r\n display: inline-block;\r\n background-color: rgb(252, 252, 255);\r\n /* background-color: rgb(33, 33, 33); */\r\n\r\n}\r\n\r\n.absol-hmenu > .absol-dropdown {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-hmenu-button:hover,\r\n.absol-hmenu .absol-hmenu-button-hover {\r\n\r\n background-color: rgb(175, 175, 175);\r\n}\r\n\r\n.absol-hmenu-button {\r\n padding-left: 1em;\r\n padding-right: 1em;\r\n}\r\n\r\n.absol-hmenu-button:focus {\r\n outline: none;\r\n}\r\n\r\n.absol-hmenu-button,\r\n.absol-vmenu-button {\r\n color: rgb(55, 55, 55);\r\n height: 100%;\r\n background-color: transparent;\r\n font-size: 1em;\r\n border: none;\r\n padding: 0;\r\n margin: 0;\r\n outline: none;\r\n}\r\n\r\n.absol-hmenu-button {\r\n padding-left: 1em;\r\n padding-right: 1em;\r\n}\r\n\r\n.absol-vmenu {\r\n\r\n}\r\n\r\n.absol-hmenu .absol-dropdown-content,\r\n.absol-hmenu .absol-dropright-content,\r\n.as-v-root-menu .absol-dropright-content {\r\n padding-top: 0.4em;\r\n padding-bottom: 0.4em;\r\n background-color: rgb(252, 252, 255);\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n}\r\n\r\n.absol-vmenu-button {\r\n text-align: left;\r\n padding-left: 0.5em;\r\n padding-right: 2em;\r\n height: 1.8em;\r\n white-space: nowrap;\r\n position: relative;\r\n display: block;\r\n}\r\n\r\nimg.absol-vmenu-button-icon {\r\n opacity: 0;\r\n display: none;\r\n}\r\n\r\nimg.absol-vmenu-button-icon[src] {\r\n display: block;\r\n}\r\n\r\n.absol-vmenu-button-ext-icon-container {\r\n display: inline-block;\r\n width: 1.2em;\r\n height: 1.2em;\r\n vertical-align: middle;\r\n margin-right: 0.5em;\r\n}\r\n\r\n.absol-vmenu-button-ext-icon-container > span,\r\n.absol-vmenu-button-ext-icon-container > i {\r\n font-size: 1.2em;\r\n line-height: 1;\r\n display: block;\r\n}\r\n\r\n\r\n.absol-vmenu-button-ext-icon-container > svg,\r\n.absol-vmenu-button-ext-icon-container > img {\r\n height: 1.2em;\r\n width: 1.2em;\r\n display: block;\r\n}\r\n\r\n\r\n.absol-vmenu-button-text,\r\n.absol-vmenu-button-key {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-vmenu-button-key {\r\n font-style: italic;\r\n text-align: right;\r\n margin-left: 1em;\r\n}\r\n\r\n.absol-vmenu-arrow-container {\r\n position: absolute;\r\n right: 0.2em;\r\n top: 0.3em;\r\n bottom: 0.3em;\r\n}\r\n\r\n\r\n.absol-vmenu-arrow-container::after {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n\r\n.absol-vmenu-arrow {\r\n display: inline-block;\r\n font-size: inherit;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-menu-item-disabled .absol-vmenu-arrow {\r\n display: none;\r\n}\r\n\r\n.absol-vmenu-button:hover,\r\n.absol-vmenu .absol-vmenu-button-hover {\r\n background-color: rgb(214, 214, 217);\r\n}\r\n\r\n.absol-menu-item-disabled .absol-vmenu-button:hover,\r\n.absol-menu-item-disabled .absol-vmenu .absol-vmenu-button-hover,\r\n.absol-menu-item-disabled .absol-hmenu-button:hover,\r\n.absol-menu-item-disabled .absol-hmenu .absol-hmenu-button-hover {\r\n background-color: transparent;\r\n}\r\n\r\n.absol-vmenu-line {\r\n text-align: center;\r\n padding: 0.2em 1em;\r\n}\r\n\r\n.absol-vmenu-line > div {\r\n height: 1px;\r\n background-color: rgb(97, 97, 97);\r\n}\r\n\r\n.absol-menu-item-disabled {\r\n}\r\n\r\n.absol-menu-item-hidden {\r\n display: none;\r\n}\r\n\r\n.absol-menu-item-disabled button {\r\n color: rgb(155, 155, 159);\r\n}\r\n\r\n.dark .absol-menu-item-disabled button {\r\n color: rgb(100, 100, 100);\r\n}\r\n\r\n.dark .absol-vmenu-button:hover,\r\n.dark .absol-vmenu .absol-vmenu-button-hover {\r\n background-color: rgb(9, 71, 113);\r\n}\r\n\r\n\r\n.dark .absol-hmenu .absol-dropdown-content,\r\n.dark .absol-hmenu .absol-dropright-content {\r\n background-color: rgb(37, 37, 38);\r\n}\r\n\r\n\r\n.dark .absol-hmenu-button,\r\n.dark .absol-vmenu-button {\r\n color: rgb(200, 200, 200);\r\n\r\n}\r\n\r\n\r\n.dark .absol-hmenu-button:hover,\r\n.dark .absol-hmenu .absol-hmenu-button-hover {\r\n background-color: rgb(80, 80, 80);\r\n}\r\n\r\n\r\n.dark .absol-hmenu {\r\n background-color: rgb(33, 33, 33);\r\n}\r\n\r\n/*standard-alone*/\r\n.absol-vmenu-button.standard-alone {\r\n height: 2em;\r\n border-radius: 0.3em;\r\n border: solid rgb(169, 169, 170) 1px;\r\n outline: none;\r\n}\r\n\r\n.as-v-root-menu {\r\n display: inline-block;\r\n box-sizing: border-box;\r\n /*overflow-y: auto;*/\r\n /*overflow-x: hidden;*/\r\n}", ""]); /***/ }), /***/ 6114: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-message-dialog {\r\n font-size: 1rem;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n box-sizing: border-box;\r\n background-color: white;\r\n border-radius: 0.3em;\r\n border: 1px solid #dddddd;\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n}\r\n\r\n.as-message-dialog-header {\r\n padding: calc(5em / 14) 1em;\r\n border-bottom: 1px solid #e9ecef;\r\n}\r\n\r\n\r\n.as-message-dialog-title {\r\n font-size: 1.25em;\r\n font-weight: 500;\r\n}\r\n\r\n.as-message-dialog-body {\r\n padding: 1em;\r\n}\r\n\r\n.as-message-dialog-footer {\r\n text-align: right;\r\n padding: 10px 20px;\r\n border-top: 1px solid #e9ecef;\r\n}\r\n\r\n.as-message-dialog-footer:empty,\r\n.as-message-dialog-header:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.as-message-dialog-footer button {\r\n margin-left: 1.5em;\r\n}\r\n\r\n\r\n.as-message-dialog-footer button.as-flexicon-button .as-flexicon-button-text-container {\r\n padding-left: 2em;\r\n padding-right: 2em;\r\n}", ""]); /***/ }), /***/ 4484: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-conversation-box {\r\n display: flex;\r\n flex-direction: column;\r\n font-size: 4rem;\r\n --right-width: 0;\r\n}\r\n\r\n.as-conversation-box-message-ctn {\r\n flex-grow: 1;\r\n}\r\n\r\n.as-conversation-box-input-ctn {\r\n /** empty**/\r\n}\r\n\r\n.as-message-input {\r\n position: relative;\r\n box-sizing: border-box;\r\n padding-top: calc(5em / 14);\r\n padding-bottom: calc(5em / 14);\r\n padding-left: calc(5em / 14);\r\n overflow: visible;\r\n font-size: var(--as-input-font-size);\r\n font-family: var(--as-input-font-family);\r\n}\r\n\r\n.as-message-input * {\r\n font: inherit;\r\n}\r\n\r\n\r\n.as-message-input-plugin-btn {\r\n font-size: inherit;\r\n width: calc(40em / 14);\r\n height: calc(40em / 14);\r\n padding: 0;\r\n border: none;\r\n color: rgb(122, 122, 122);\r\n background-color: rgb(241, 241, 241);\r\n outline: none;\r\n border-radius: 50%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-message-input-plugin-btn:active {\r\n background-color: rgb(212, 212, 212);\r\n}\r\n\r\n.as-message-input-plugin-btn:hover {\r\n background-color: rgb(235, 235, 235);\r\n\r\n}\r\n\r\n\r\n.as-message-input-plugin-btn span {\r\n font-size: calc(24em / 14);\r\n}\r\n\r\n\r\n.as-message-input-right {\r\n position: absolute;\r\n bottom: calc(10em / 14);\r\n right: calc(5em / 14);\r\n z-index: 0;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-message-input-right .as-message-input-plugin-btn {\r\n margin-left: calc(10em / 14);\r\n}\r\n\r\n\r\n.as-message-input-left {\r\n position: absolute;\r\n left: calc(5em / 14);\r\n bottom:calc(5em / 14);\r\n}\r\n\r\n\r\n.as-message-input-pre-ctn {\r\n position: relative;\r\n width: calc(100% - var(--right-width));\r\n border-radius: 1.8em;\r\n box-sizing: border-box;\r\n transition: width 0.1s;\r\n padding: calc(10em / 14) calc(20em / 14) calc(10em / 14) 3.57em;\r\n background-color: rgb(241, 241, 244);\r\n}\r\n\r\n\r\n.as-message-input-pre-ctn::after {\r\n display: inline-block;\r\n content: \"\";\r\n height: calc(2em + 2px);\r\n vertical-align: middle;\r\n}\r\n\r\n.as-message-input:not(.as-v2) .as-message-input-pre:before {\r\n content: \"\";\r\n line-height: calc(2em + 2px);\r\n display: inline;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n/*.as-message-input.as-has-text.as-text-changed .as-message-input-pre-ctn,*/\r\n/*.as-message-input.as-has-quote .as-message-input-pre-ctn,*/\r\n/*.as-message-input.as-has-attachment .as-message-input-pre-ctn {*/\r\n/* width: calc(100% - 4em - var(--always-visible-buttons-width));*/\r\n/*}*/\r\n\r\n\r\n.as-message-input-pre {\r\n display: inline-block;\r\n width: calc(100% - 2px);\r\n max-height: 6.5em;\r\n box-sizing: border-box;\r\n font-family: inherit;\r\n font-size: inherit;\r\n outline: none;\r\n vertical-align: middle;\r\n margin: 0;\r\n white-space: pre-wrap;\r\n overflow-x: hidden;\r\n overflow-y: auto;\r\n line-height: 1.5;\r\n border: none;\r\n}\r\n\r\n\r\n\r\n.as-message-input-camera-caller,\r\n.as-message-input-camera-microphone {\r\n display: none;\r\n}\r\n\r\n.as-message-input-emoji-picker-ctn {\r\n position: absolute;\r\n bottom: 100%;\r\n left: 0;\r\n right: 0;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n background-color: white;\r\n}\r\n\r\n\r\n.as-message-input-plugin-btn.as-message-input-plugin-send {\r\n color: white;\r\n background: linear-gradient(135deg, rgb(0, 120, 212), rgb(0, 188, 242));\r\n transform: scale(1);\r\n transition: scale 0.1s;\r\n}\r\n\r\n.as-message-input-plugin-btn.as-message-input-plugin-send span {\r\n font-size: calc(20em / 14);\r\n}\r\n\r\n.as-message-input-plugin-btn.as-message-input-plugin-send:hover {\r\n background: linear-gradient(135deg, rgb(0, 140, 212), rgb(0, 208, 252));\r\n}\r\n\r\n.as-message-input-plugin-btn.as-message-input-plugin-send:active {\r\n transform: scale(0.9);\r\n}\r\n\r\n\r\n.as-message-input:not(.as-text-changed):not(.as-has-attachment):not(.as-has-quote) .as-message-input-plugin-send,\r\n.as-message-input:not(.as-has-text):not(.as-has-attachment):not(.as-has-quote) .as-message-input-plugin-send,\r\n.as-message-input:not(.as-mode-edit) .as-message-input-plugin-cancel,\r\n.as-message-input.as-mode-edit.as-text-changed.as-has-text .as-message-input-plugin-cancel,\r\n.as-message-input:not(.as-has-attachment):not(.as-drag-hover) .as-message-input-attachment-ctn,\r\n.as-message-input.as-auto-send .as-message-input-attachment-ctn,\r\n.as-message-input.as-mode-edit .as-message-input-plugin-file,\r\n.as-message-input.as-has-text .as-message-input-plugin-file,\r\n.as-message-input.as-has-quote .as-message-input-plugin-file,\r\n.as-message-input:not(.as-has-quote) .as-message-quote-box {\r\n display: none;\r\n}\r\n\r\n.as-message-input .as-message-quote-box {\r\n border-bottom: 1px solid #ddd;\r\n}\r\n\r\n.as-message-quote-box {\r\n position: relative;\r\n\r\n}\r\n\r\n.as-message-input.as-has-attachment .as-message-quote-box {\r\n margin-bottom: 5px;\r\n}\r\n\r\n.as-message-quote-remove-btn {\r\n position: absolute;\r\n color: rgb(43, 44, 51);\r\n right: -7px;\r\n top: 5px;\r\n width: 20px;\r\n height: 20px;\r\n padding: 0;\r\n background: transparent;\r\n border: none;\r\n border-radius: 50%;\r\n font-size: 16px;\r\n outline: none;\r\n}\r\n\r\n.as-message-quote-remove-btn:hover {\r\n color: rgb(143, 144, 151);\r\n}\r\n\r\n.as-message-quote-box {\r\n user-select: none;\r\n -webkit-user-select: none;\r\n}\r\n\r\n.as-message-quote-box:not(.as-removable) .as-message-quote-remove-btn {\r\n display: none;\r\n}\r\n\r\n\r\n.as-message-quote-box > div {\r\n display: inline-block;\r\n vertical-align: top;\r\n}\r\n\r\n.as-message-quote-box:not(.as-has-img):not(.as-has-file) .as-message-quote-img {\r\n display: none;\r\n}\r\n\r\n.as-message-quote-img {\r\n width: 40px;\r\n height: 40px;\r\n padding: 5px;\r\n box-sizing: border-box;\r\n background-size: cover;\r\n background-origin: border-box;\r\n background-position: center;\r\n background-repeat: no-repeat;\r\n}\r\n\r\n.as-message-quote-sym {\r\n width: 1.8em;\r\n}\r\n\r\n.as-message-quote-sym > span {\r\n font-size: 1.8em;\r\n color: rgb(169, 169, 172);\r\n}\r\n\r\n.as-message-quote-content {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n width: calc(100% - 26px);\r\n box-sizing: border-box;\r\n padding-left: 20px;\r\n}\r\n\r\n.as-message-quote-box.as-has-img .as-message-quote-content,\r\n.as-message-quote-box.as-has-file .as-message-quote-content {\r\n width: calc(100% - 66px);\r\n padding-left: 5px;\r\n}\r\n\r\n.as-message-quote-box.as-has-file .as-message-quote-img {\r\n background-origin: padding-box;\r\n background-size: contain;\r\n}\r\n\r\n.as-message-quote-text {\r\n font-size: calc(16em / 14);\r\n line-height: 1.75;\r\n font-style: italic;\r\n color: rgb(43, 44, 51);\r\n max-width: 100%;\r\n word-break: break-word;\r\n white-space: pre-wrap;\r\n}\r\n\r\n.as-message-quote-box.as-shorten-text .as-message-quote-text {\r\n word-break: normal;\r\n\r\n overflow: hidden;\r\n white-space: nowrap;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.as-message-quote-text .as-emoji {\r\n width: 20px;\r\n height: 20px;\r\n}\r\n\r\n.as-message-quote-desc {\r\n font-size: 0.85em;\r\n color: rgb(80, 80, 88);\r\n}\r\n\r\n.as-message-input-attachment-ctn {\r\n border-bottom: 1px solid #ddd;\r\n max-height: 170px;\r\n overflow-y: auto;\r\n}\r\n\r\n\r\n.as-message-input-attach-preview {\r\n display: inline-block;\r\n position: relative;\r\n width: 135px;\r\n height: 135px;\r\n vertical-align: middle;\r\n margin-right: 5px;\r\n margin-bottom: 5px;\r\n border-radius: 10px;\r\n background-color: white;\r\n overflow: hidden;\r\n}\r\n\r\n.as-message-input-attach-preview-image {\r\n min-width: 20px;\r\n image-orientation: from-image;\r\n width: 100%;\r\n height: 100%;\r\n background-size: cover;\r\n background-position: center center;\r\n background-repeat: no-repeat;\r\n}\r\n\r\n\r\n.as-message-input-attach-preview-file {\r\n max-width: 50%;\r\n max-height: 50%;\r\n margin-left: 10px;\r\n margin-top: 10px;\r\n}\r\n\r\n.as-message-input-attach-preview-close-btn {\r\n position: absolute;\r\n right: 10px;\r\n top: 10px;\r\n width: 18px;\r\n height: 18px;\r\n border-radius: 50%;\r\n text-align: center;\r\n border: 1px solid white;\r\n outline: none;\r\n padding: 0;\r\n color: white;\r\n -webkit-box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.64);\r\n -moz-box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.64);\r\n box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.64);\r\n background-color: rgba(100, 100, 100, 0.5);\r\n}\r\n\r\n.as-message-input-attach-preview-close-btn span {\r\n font-size: 14px;\r\n}\r\n\r\n.as-message-input-attach-preview-close-btn:hover {\r\n background-color: rgba(255, 255, 255, 0.5);\r\n color: rgb(200, 200, 200);\r\n}\r\n\r\n.as-message-input-attach-preview-close-btn:active {\r\n background-color: rgba(255, 255, 255, 0.7);\r\n color: rgb(255, 255, 255);\r\n}\r\n\r\n\r\n.as-message-input:not(.as-drag-hover) .as-message-input-attachment-add-btn-drop,\r\n.as-message-input.as-drag-hover .as-message-input-attachment-add-btn-plus {\r\n display: none;\r\n}\r\n\r\n\r\n.as-message-input-attach-preview-info {\r\n position: absolute;\r\n left: 10px;\r\n bottom: 10px;\r\n right: 10px;\r\n max-height: calc(100% - 20px);\r\n text-shadow: 0px 1px 3px white;\r\n color: black;\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.as-message-input-attach-preview-name {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.as-message-input-attach-preview-size {\r\n color: #42494c;\r\n}\r\n\r\n.as-message-input-attachment-add-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 135px;\r\n width: 60px;\r\n border: none;\r\n border-radius: 10px;\r\n padding: 0;\r\n background-color: rgb(196, 196, 200);\r\n color: white;\r\n font-size: 50px;\r\n outline: none;\r\n margin-bottom: 10px;\r\n}\r\n\r\n.as-message-input-attachment-add-btn:hover {\r\n background-color: rgb(169, 169, 169)\r\n\r\n}\r\n\r\n.as-message-input-attachment-add-btn:active {\r\n background-color: rgb(138, 141, 145)\r\n}\r\n\r\n.as-message-input-external-tools-popup {\r\n position: absolute;\r\n\r\n max-width: 100%;\r\n bottom: 100%;\r\n background-color: white;\r\n}\r\n\r\n.as-message-input-external-tools-popup.as-align-left{\r\n left: 0;\r\n}\r\n\r\n\r\n.as-message-input-external-tools-popup.as-align-right{\r\n right: 0;\r\n}\r\n\r\n.as-message-input-external-tools-popup.as-align-fixed{\r\n right: 0;\r\n left: 0;\r\n}\r\n\r\nimg.as-emoji {\r\n vertical-align: bottom;\r\n}\r\n\r\nspan.as-emoji-text {\r\n position: absolute;\r\n color: transparent;\r\n width: 20px;\r\n opacity: 0;\r\n}", ""]); /***/ }), /***/ 1433: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --control-horizontal-distance-2: 10px;\r\n}\r\n\r\n.mk-nav {\r\n position: relative;\r\n --mk-nav-line-top: 0;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -ms-user-select: none;\r\n -moz-user-select: none;\r\n --mk-navigator-bound-left: 0;\r\n padding-right: 4px;\r\n box-sizing: border-box;\r\n --max-text-width: 10px;\r\n min-width: calc(var(--max-text-width) + 96px);\r\n}\r\n\r\n.mk-nav::after {\r\n content: \"\";\r\n position: absolute;\r\n transition: top 0.2s;\r\n top: var(--mk-nav-line-top);\r\n height: calc(2em + 12px);\r\n border-right: 4px solid rgb(20, 100, 246);\r\n right: 0px;\r\n}\r\n\r\n.mk-nav.mk-has-draggable .mk-nav-item {\r\n padding-left: calc(2em + 2px);\r\n}\r\n\r\n.mk-nav-item {\r\n height: calc(2em + 12px);\r\n padding-left: var(--control-horizontal-distance-2);\r\n padding-right: 20px;\r\n min-width: 100px;\r\n cursor: pointer;\r\n white-space: nowrap;\r\n position: relative;\r\n overflow: visible;\r\n display: flex;\r\n align-items: center;\r\n background-color: white;\r\n}\r\n\r\n.mk-nav-item.as-board-moving {\r\n transform: none;\r\n left: var(--mk-navigator-bound-left) !important;\r\n background-color: rgb(169, 169, 172, 0.3);\r\n}\r\n\r\n.mk-nav-item:hover {\r\n background-color: rgb(169, 169, 172, 0.3);\r\n}\r\n\r\n.mk-nav-item.as-hidden{\r\n display: none;\r\n}\r\n\r\n.mk-nav-item-text-ctn {\r\n flex-grow: 1;\r\n padding-right: var(--control-horizontal-distance-2);\r\n padding-left: var(--control-horizontal-distance-2)\r\n}\r\n\r\n\r\n.mk-nav-item-switch-ctn {\r\n\r\n}\r\n\r\n/*\r\n.mk-nav-item::after {\r\n content: \"\";\r\n border: 1px solid #ddd;\r\n z-index: 2;\r\n pointer-events: none;\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: -1px;\r\n}\r\n\r\n.mk-nav-item:hover::after,\r\n.mk-nav-item.mk-current::after{\r\n border-color: rgb(20, 100, 246);\r\n z-index: 3;\r\n}\r\n*/\r\n\r\n\r\n.mk-nav-item.mk-current {\r\n color: rgb(20, 100, 246);\r\n text-shadow: 1px 0 0 currentColor;\r\n}\r\n\r\n.mk-nav-item-drag-zone {\r\n position: absolute;\r\n z-index: 1;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n width: 30px;\r\n font-size: inherit;\r\n}\r\n\r\n.mk-nav-item-drag-zone i {\r\n font-size: 1.7em;\r\n}\r\n\r\n.mk-nav-item-drag-zone::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.mk-nav-item-drag-zone::before,\r\n.mk-nav-item-drag-zone i {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}", ""]); /***/ }), /***/ 3742: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/**** APP ***************/\r\n\r\n.am-application {\r\n width: 100%;\r\n height: 100%;\r\n position: relative;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n}\r\n\r\n.am-application-frameview {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n\r\n.am-application-tabbar {\r\n display: none;\r\n}\r\n\r\n.am-application.am-show-tabbar .am-application-tabbar {\r\n display: block;\r\n}\r\n\r\n.am-application.am-show-tabbar .am-application-frameview {\r\n height: calc(100% - 3em);\r\n}\r\n\r\n\r\n/*************** HEADER****************************************/\r\n\r\n.am-header-bar {\r\n display: flex;\r\n align-items: center;\r\n background-color: var(--variant-color-primary);\r\n -webkit-box-shadow: 0px 1px 10px 2px rgba(0, 0, 0, 0.5);\r\n -moz-box-shadow: 0px 1px 10px 2px rgba(0, 0, 0, 0.5);\r\n box-shadow: 0px 1px 5px 1px rgba(0, 0, 0, 0.5);\r\n box-sizing: border-box;\r\n position: relative;\r\n font-family: Arial, Helvetica, sans-serif;\r\n color: white;\r\n height: 3em;\r\n font-size: 1rem;\r\n}\r\n\r\n\r\n.am-header-bar-left-btn,\r\nbutton.am-header-bar-command {\r\n display: inline-block;\r\n text-align: center;\r\n border: none;\r\n background-color: transparent;\r\n height: 3em;\r\n width: 3em;\r\n padding: 0;\r\n margin: 0;\r\n vertical-align: middle;\r\n color: white;\r\n outline: none;\r\n font-size: inherit;\r\n}\r\n\r\n.am-header-bar-left-btn span,\r\nbutton.am-header-bar-command span,\r\n.am-header-bar-left-btn i,\r\nbutton.am-header-bar-command i {\r\n font-size: 2em;\r\n}\r\n\r\nbutton.am-header-bar-command:not(:last-child) {\r\n margin-right: 0.6256em;\r\n}\r\n\r\n\r\n.am-header-bar-left-btn:active,\r\nbutton.am-header-bar-action:active,\r\nbutton.am-header-bar-command:active {\r\n color: rgb(220, 220, 222);\r\n}\r\n\r\n\r\n.as-header-bar-notification-action {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-header-bar-notification-action-count {\r\n position: relative;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-header-bar-notification-action-count::before {\r\n display: none;\r\n content: \"0\";\r\n position: absolute;\r\n font-size: 12px;\r\n line-height: 18px;\r\n bottom: 5px;\r\n right: -8px;\r\n background-color: rgb(221, 35, 52);\r\n color: white;\r\n text-align: center;\r\n min-width: 18px;\r\n height: 18px;\r\n padding-left: 2px;\r\n padding-right: 2px;\r\n box-sizing: border-box;\r\n border-radius: 9px;\r\n}\r\n\r\n.am-header-bar-title-ctn {\r\n flex-grow: 1;\r\n white-space: nowrap;\r\n overflow: inherit;\r\n position: relative;\r\n height: 3em;\r\n}\r\n\r\n.am-header-bar-no-size-wrapper {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n white-space: nowrap;\r\n}\r\n\r\n.am-header-bar-no-size-wrapper::before {\r\n content: \"\";\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-header-bar-title-wrapper {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 100%;\r\n\r\n}\r\n\r\n.am-header-bar-title-ctn:first-child .am-header-bar-title {\r\n padding-left: 1.2em;\r\n}\r\n\r\n\r\n.am-header-bar-title {\r\n font-size: 1.2em;\r\n color: white;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n\r\n}\r\n\r\n.am-header-bar-title-desc {\r\n font-size: 0.8em;\r\n line-height: 2;\r\n}\r\n\r\n.am-header-bar-title-desc:empty {\r\n display: none;\r\n}\r\n\r\n\r\n.am-header-bar-right {\r\n\r\n}\r\n\r\n.am-header-bar-right::after {\r\n content: \"\";\r\n height: 100%;\r\n vertical-align: middle;\r\n display: inline-block;\r\n width: 0.357142857em;\r\n}\r\n\r\n\r\n.am-header-bar-right-item-ctn {\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n\r\nbutton.am-header-bar-action {\r\n height: 3em;\r\n width: 3em;\r\n background-color: transparent;\r\n color: white;\r\n border: none;\r\n font-size: inherit;\r\n outline: none;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-header-bar-quickmenu-btn.am-status-active .am-header-bar-quickmenu-btn-circle {\r\n background-color: rgba(169, 169, 169, 0.5);\r\n}\r\n\r\n\r\n.am-header-bar-quickmenu-btn-circle {\r\n height: 2em;\r\n width: 2em;\r\n border-radius: 50%;\r\n text-align: center;\r\n}\r\n\r\n.am-header-bar-quickmenu-btn-circle span {\r\n font-size: 1.6em;\r\n line-height: 1.25em;\r\n}\r\n\r\n.am-header-bar-quickmenu-btn.as-active .mdi-dots-horizontal-circle-outline,\r\n.am-header-bar-quickmenu-btn:not(.as-active) .mdi-dots-horizontal-circle {\r\n display: none;\r\n}\r\n\r\n\r\n.am-header-bar.am-light-weight,\r\n.am-header-bar.am-light-weight .am-header-bar-title-ctn,\r\n.am-header-bar.am-light-weight .am-header-bar-left-btn,\r\n.am-header-bar.am-light-weight button.am-header-bar-command,\r\n.am-header-bar.am-light-weight button.am-header-bar-action {\r\n height: calc(2rem + 2px);\r\n}\r\n\r\n\r\n.am-header-bar.am-light-weight .am-header-bar-left-btn span,\r\n.am-header-bar.am-light-weight button.am-header-bar-command span,\r\n.am-header-bar-left-btn i,\r\n.am-header-bar.am-light-weight button.am-header-bar-command i {\r\n font-size: 1.6em;\r\n}\r\n\r\n.am-application.am-stack > .am-activity {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n}\r\n\r\n\r\n.am-activity {\r\n width: 100%;\r\n height: 100%;\r\n background-color: white;\r\n}\r\n\r\n.am-activity.am-grid {\r\n grid-template-areas: 'header' 'body';\r\n grid-template-rows: 3em auto;\r\n display: grid;\r\n}\r\n\r\n\r\n.am-activity.am-grid > .am-header-bar {\r\n grid-area: header;\r\n}\r\n\r\n.am-activity.am-grid > .am-activity-body {\r\n grid-area: body;\r\n padding: 10px 5px;\r\n overflow: auto;\r\n}\r\n\r\n.am-explore-item-block {\r\n display: inline-block;\r\n vertical-align: top;\r\n padding: 10px 18px 15px 18px;\r\n position: relative;\r\n user-select: none;\r\n box-sizing: border-box;\r\n width: var(--item-width);\r\n outline: none;\r\n}\r\n\r\n.am-explore-item-block.as-hidden {\r\n display: none;\r\n}\r\n\r\n.am-explore-item-block:active::after,\r\n.am-explore-item-block:hover::after,\r\n.am-explore-item-block:focus::after {\r\n display: block;\r\n position: absolute;\r\n left: 10px;\r\n right: 10px;\r\n top: 0;\r\n bottom: 0;\r\n z-index: 2;\r\n border-radius: 5px;\r\n}\r\n\r\n.am-explore-item-block:active::after {\r\n content: \"\";\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.am-explore-item-block:focus::after {\r\n content: \"\";\r\n border: 1px solid #a9a9a9;\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.am-explore-item-block-icon {\r\n display: block;\r\n box-sizing: border-box;\r\n width: 100%;\r\n height: 50px;\r\n text-align: center;\r\n white-space: nowrap;\r\n color: var(--variant-color-secondary);\r\n padding: 0 5px;\r\n}\r\n\r\n.am-explore-item-block-icon::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.am-explore-item-block-icon > span:first-child,\r\n.am-explore-item-block-icon > .mdi {\r\n display: inline-block;\r\n font-size: 50px;\r\n vertical-align: middle;\r\n line-height: 1;\r\n}\r\n\r\n.am-explore-item-block-icon > svg {\r\n width: 50px;\r\n height: 50px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.am-explore-item-block-name {\r\n width: 100%;\r\n text-align: center;\r\n padding: 10px 0 5px 0;\r\n}\r\n\r\n\r\n.am-explore-section-break {\r\n display: flex;\r\n align-content: center;\r\n margin-bottom: 10px;\r\n}\r\n\r\n.am-explore-section-break-name {\r\n padding: 3px 5px 3px 5px;\r\n background-color: var(--variant-color-link);\r\n border-radius: 2px;\r\n color: white;\r\n\r\n}\r\n\r\n.am-explore-section-break-line {\r\n flex-grow: 1;\r\n position: relative;\r\n}\r\n\r\n.am-explore-section-break-line::after {\r\n position: absolute;\r\n left: 0;\r\n width: 100%;\r\n top: calc(50% - 1px);\r\n display: block;\r\n content: \"\";\r\n flex-grow: 1;\r\n border-top: 2px solid #dddddd;\r\n vertical-align: center;\r\n}\r\n\r\n.am-float-button {\r\n position: fixed;\r\n bottom: 12px;\r\n right: 12px;\r\n border-radius: 50%;\r\n width: 50px;\r\n height: 50px;\r\n transition: box-shadow 0.4s ease;\r\n background: #4610f5;\r\n box-shadow: 0 1px 4px rgba(0, 0, 0, 0.6);\r\n color: #fff;\r\n font-size: 1.7rem;\r\n font-weight: bold;\r\n cursor: pointer;\r\n z-index: 500;\r\n border: none;\r\n}\r\n\r\n.am-explore-group {\r\n padding: 5px 5px 10px 5px;\r\n}\r\n\r\n.am-explore-group.as-hidden {\r\n display: none;\r\n}\r\n\r\n/******************************/\r\n.am-springboard-menu {\r\n --item-width: 150px;\r\n outline: none;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.am-springboard-menu.am-style-simple {\r\n background-color: rgb(235, 235, 235);\r\n padding: 10px;\r\n}\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-group {\r\n background-color: white;\r\n border-radius: 5px;\r\n padding: 5px;\r\n\r\n}\r\n\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-group:not(:last-child) {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-section-break-line {\r\n display: none;\r\n}\r\n\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-section-break-name {\r\n background-color: transparent;\r\n color: black;\r\n font-weight: bold;\r\n padding: 5px 15px;\r\n}\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-item-block {\r\n padding: 5px 16px;\r\n}\r\n\r\n\r\n.am-springboard-menu.am-style-simple .am-explore-section-break {\r\n margin-bottom: 0;\r\n}\r\n\r\n.am-springboard-menu.as-style-desktop .am-explore-section-break-name {\r\n background-color: white;\r\n color: black;\r\n font-weight: bold;\r\n font-size: 14px;\r\n}\r\n\r\n.am-springboard-menu.as-style-desktop .am-explore-item-block:hover .am-explore-item-block-icon {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n.am-springboard-menu.as-style-desktop .am-explore-item-block:hover::after {\r\n content: \"\";\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.am-springboard-menu.as-style-desktop .am-explore-item-block:active::after {\r\n content: \"\";\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.am-springboard-menu > .absol-search-text-input {\r\n margin: 10px;\r\n max-width: 400px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.am-springboard-menu::before {\r\n content: \"\";\r\n display: block;\r\n height: 1px;\r\n}\r\n\r\n/*justify-content: space-between;*/\r\n\r\n\r\n.am-springboard-menu.as-searching .am-explore-group:not(.as-search-result),\r\n.am-springboard-menu:not(.as-searching) .am-explore-group.as-search-result {\r\n display: none;\r\n}\r\n", ""]); /***/ }), /***/ 1148: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-modal {\r\n position: fixed;\r\n left: 0;\r\n height: 100%;\r\n top: 0;\r\n width: 100%;\r\n z-index: 1001000;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-modal.as-hidden {\r\n z-index: -1000;\r\n visibility: hidden;\r\n opacity: 0;\r\n}\r\n\r\n.as-modal.as-center {\r\n text-align: center;\r\n}\r\n\r\n\r\n.as-modal.as-middle::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n width: 0;\r\n}\r\n\r\n.as-modal > .as-modal-content {\r\n display: inline-block;\r\n text-align: initial;\r\n white-space: initial;\r\n}\r\n\r\n/*for content*/\r\n.as-modal.as-middle > .as-modal-content {\r\n vertical-align: middle;\r\n}\r\n\r\n.as-loading-cube-modal {\r\n background-color: rgba(169, 169, 169, 0.3);\r\n}\r\n\r\n\r\n.as-loading-cube-modal {\r\n z-index: 1000000;\r\n background-color: rgba(169, 169, 169, 0.3);\r\n}\r\n\r\n.as-loading-cube-modal > .as-modal-content {\r\n background-color: white;\r\n border-radius: 4px;\r\n padding: 10px;\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n display: inline-block;\r\n}\r\n\r\n.as-loading-cube-modal > .as-modal-content > svg {\r\n width: 5em;\r\n height: 5em;\r\n}\r\n\r\n\r\n.am-modal {\r\n z-index: 100005;\r\n position: fixed;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n text-align: center;\r\n box-sizing: border-box;\r\n padding-top: var(--modal-margin-top);\r\n}\r\n\r\n.am-modal>div{\r\n text-align: initial;\r\n display: inline-block;\r\n}", ""]); /***/ }), /***/ 8759: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --multi-select-menu-max-height: 90px;\r\n}\r\n\r\n.as-multi-select-menu {\r\n --list-min-width: 3em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n min-height: var(--select-box-min-height);\r\n min-width: var(--list-min-width);\r\n border: solid 1px #d6d6d6;\r\n border-radius: 3px;\r\n box-sizing: border-box;\r\n outline: none;\r\n background-color: white;\r\n padding-right: 45px;\r\n white-space: normal;\r\n --as-width-limit: 100vw;\r\n max-width: var(--as-width-limit);\r\n}\r\n\r\n.as-multi-select-menu.am-multi-select-menu {\r\n min-width: unset;\r\n}\r\n\r\n.as-multi-select-menu .absol-selectbox-item-text span{\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n max-width: calc(var(--as-width-limit) - 85px);\r\n}\r\n\r\n.as-multi-select-menu-item-ctn {\r\n display: block;\r\n max-height: var(--multi-select-menu-max-height);\r\n overflow-y: auto;\r\n}\r\n\r\n.as-multi-select-menu-item-ctn.as-has-more {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-multi-select-menu-item-ctn.as-has-more::after {\r\n content: \"...\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-weight: bold;\r\n font-size: 1.5em;\r\n color: rgb(57, 57, 58);\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-multi-select-menu-toggle-btn {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n width: 30px;\r\n pointer-events: none;\r\n border: none;\r\n background-color: transparent;\r\n}\r\n\r\n.as-multi-select-menu-toggle-btn svg.dropdown {\r\n width: 10px;\r\n height: 10px;\r\n fill: #929292;\r\n}\r\n\r\n.as-multi-select-menu:hover svg.dropdown {\r\n fill: black;\r\n}\r\n\r\n.as-multi-select-menu.as-disable-click-to-focus .as-multi-select-menu-toggle-btn {\r\n display: none;\r\n}\r\n\r\n.as-multi-select-menu .absol-selectbox-item {\r\n margin: calc((var(--select-box-min-height) - 2px - var(--select-box-item-height)) / 2) 2px;\r\n}\r\n\r\n\r\n.as-multi-select-menu.as-item-focusable .absol-selectbox-item.as-active {\r\n background-color: var(--select-box-focus-item-color);\r\n}\r\n\r\n.as-multi-select-menu.as-disabled {\r\n background-color: #ebebe4;\r\n}\r\n\r\n.as-multi-select-menu-toggle-btn {\r\n\r\n}\r\n\r\n.as-multi-select-menu.as-disabled .as-multi-select-menu-item-ctn * {\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-multi-select-menu.as-multi-check-tree-leaf-menu {\r\n min-width: calc(var(--select-list-estimate-width) + 14px);\r\n}\r\n\r\n\r\n.as-multi-select-menu.as-read-only .absol-selectbox-item-close,\r\n.as-multi-select-menu.as-read-only .as-multi-select-menu-toggle-btn,\r\n.as-multi-select-menu.as-disabled .absol-selectbox-item-close,\r\n.as-multi-select-menu.as-disabled .as-multi-select-menu-toggle-btn {\r\n display: none;\r\n}\r\n\r\n.as-multi-select-menu.as-read-only .absol-selectbox-item-text {\r\n padding-right: 10px;\r\n}\r\n\r\n.as-multi-select-menu.as-read-only {\r\n padding-right: 0;\r\n}\r\n\r\n.as-multi-select-menu.as-border-none {\r\n border: none;\r\n}\r\n\r\n.as-multi-select-menu.as-border-none .as-multi-select-menu-item-ctn {\r\n /*max-height: unset;*/\r\n /*overflow-y: auto;*/\r\n}\r\n\r\n\r\n.as-multi-select-menu.as-has-max-width {\r\n --max-width: 1024px;\r\n max-width: var(--max-width);\r\n min-width: 100px !important;\r\n}\r\n\r\n.as-multi-select-menu.as-has-max-width .absol-selectbox-item-text span{\r\n max-width: calc(var(--max-width) - 85px);\r\n}", ""]); /***/ }), /***/ 7675: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --np-item-width: 370px;\r\n}\r\n\r\n\r\n.as-mobile-notification-virtual-dropdown {\r\n --np-item-width: auto;\r\n}\r\n\r\n.as-notification-panel {\r\n padding: 5px 10px;\r\n text-align: center;\r\n display: inline-block;\r\n vertical-align: top;\r\n font-size: 14px;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n\r\n.as-notification-panel > .as-np-dropdown-button:not(:last-child) {\r\n margin-right: 10px;\r\n}\r\n\r\n\r\n.as-np-dropdown-button {\r\n display: inline-block;\r\n vertical-align: center;\r\n}\r\n\r\n.as-np-db-btn {\r\n width: 40px;\r\n height: 40px;\r\n border: none;\r\n background-color: rgba(169, 169, 171, 0.2);\r\n border-radius: 50%;\r\n position: relative;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-np-db-btn:hover {\r\n background-color: rgba(169, 169, 171, 0.4);\r\n}\r\n\r\n.as-np-db-icon-ctn, .as-np-db-count {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-np-dropdown-button.as-active > .as-np-db-btn {\r\n background-color: rgba(169, 169, 220, 0.4);\r\n}\r\n\r\n\r\n.as-np-dropdown-button.as-active .as-np-db-icon-ctn {\r\n color: #0866ff;\r\n}\r\n\r\n.as-np-db-count:not([data-count]) {\r\n display: none;\r\n}\r\n\r\n.as-np-db-count {\r\n position: relative;\r\n overflow: visible;\r\n}\r\n\r\n\r\n.as-np-db-count::before {\r\n content: attr(data-count);\r\n position: absolute;\r\n font-size: 12px;\r\n line-height: 18px;\r\n bottom: 5px;\r\n left: -5px;\r\n background-color: rgb(221, 35, 52);\r\n color: white;\r\n border-radius: 9px;\r\n text-align: center;\r\n min-width: 18px;\r\n height: 18px;\r\n padding-left: 2px;\r\n padding-right: 2px;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-np-db-icon-ctn > span,\r\n.as-np-db-icon-ctn > i,\r\n.as-np-db-icon-ctn > svg {\r\n font-size: 20px;\r\n color: currentColor;\r\n}\r\n\r\n\r\n.as-np-db-dropdown {\r\n position: fixed;\r\n right: 20px;\r\n\r\n background-color: white;\r\n visibility: hidden;\r\n opacity: 0;\r\n --max-height: calc(90vh - 160px);\r\n max-height: var(--max-height);\r\n z-index: -1000;\r\n text-align: left;\r\n}\r\n\r\n.as-np-db-dropdown::before {\r\n content: \"\";\r\n display: block;\r\n height: 0;\r\n}\r\n\r\n\r\n.as-np-db-dropdown:empty {\r\n display: none;\r\n}\r\n\r\n.as-np-db-dropdown-quick-menu-ctn {\r\n position: absolute;\r\n z-index: 9;\r\n left: calc(var(--np-item-width) - 30px);\r\n top: 2px;\r\n}\r\n\r\n.as-np-db-quick-menu-btn {\r\n width: 30px;\r\n height: 30px;\r\n}\r\n\r\n.as-np-db-quick-menu-btn:hover {\r\n background-color: var(--icon-background-cover-hover);\r\n}\r\n\r\n.as-np-dropdown-button.as-active .as-np-db-dropdown {\r\n z-index: 10;\r\n visibility: visible;\r\n opacity: 1;\r\n}\r\n\r\n.as-np-db-dropdown-body > h3 {\r\n font-size: 16px;\r\n margin: 0;\r\n padding: 0 10px;\r\n text-align: left;\r\n color: rgb(169, 169, 170);\r\n line-height: 34px;\r\n\r\n}\r\n\r\n.as-np-db-dropdown-body > h4 {\r\n font-size: 14px;\r\n margin: 0;\r\n padding: 0 20px;\r\n text-align: left;\r\n color: rgb(69, 69, 70);\r\n}\r\n\r\n\r\n.as-np-section-header {\r\n padding: 5px 20px;\r\n display: flex;\r\n}\r\n\r\n.as-np-section-name {\r\n font-size: 14px;\r\n font-weight: bold;\r\n flex-grow: 1;\r\n line-height: 20px;\r\n}\r\n\r\n.as-np-section-name::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1.5;\r\n content: attr(data-name);\r\n}\r\n\r\n.as-np-section-action {\r\n cursor: pointer;\r\n color: var(--variant-color-link);\r\n padding: 0 5px;\r\n line-height: 20px;\r\n}\r\n\r\n.as-np-section-action:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-np-section-action:not([data-text]) {\r\n display: none;\r\n}\r\n\r\n.as-np-section-action::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1.5;\r\n content: attr(data-text);\r\n}\r\n\r\n\r\n.as-np-list {\r\n overflow-y: auto;\r\n max-height: calc(var(--max-height) - 100px);\r\n}\r\n\r\n.as-np-db-dropdown.as-has-quick-menu > .as-np-db-dropdown-body > .as-np-list:first-child {\r\n margin-top: 30px;\r\n}\r\n\r\n.as-np-list-more-ctn {\r\n padding: 10px 0;\r\n text-align: center;\r\n}\r\n\r\n.as-np-list-more-btn {\r\n width: calc(100% - 20px);\r\n height: 30px;\r\n}\r\n\r\n.as-np-item {\r\n box-sizing: border-box;\r\n position: relative;\r\n cursor: pointer;\r\n border-bottom: 1px solid #dddddd;\r\n width: var(--np-item-width);\r\n}\r\n\r\n.as-np-item-body {\r\n padding-right: 26px;\r\n min-height: 52px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-np-item-body[data-time-text]::after {\r\n display: block;\r\n font-size: 12px;\r\n color: #1da1ff;\r\n padding-left: 10px;\r\n}\r\n\r\n\r\n.as-np-item-body:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n\r\n.as-np-item-unread-btn::after {\r\n content: \"\";\r\n background-color: rgb(107, 176, 255);\r\n width: 12px;\r\n height: 12px;\r\n border-radius: 50%;\r\n display: inline-block;\r\n}\r\n\r\n.as-np-item-unread-btn {\r\n position: absolute;\r\n right: 0;\r\n top: calc(50% - 13px);\r\n width: 26px;\r\n height: 26px;\r\n padding: 0;\r\n background-color: transparent;\r\n outline: none;\r\n box-sizing: border-box;\r\n cursor: pointer;\r\n border: none;\r\n}\r\n\r\n.as-np-item-pin-btn {\r\n position: absolute;\r\n right: 0px;\r\n top: 0;\r\n width: 26px;\r\n height: 26px;\r\n padding: 0;\r\n background-color: transparent;\r\n outline: none;\r\n box-sizing: border-box;\r\n cursor: pointer;\r\n border: none;\r\n}\r\n\r\n.as-np-item-pin-btn > span {\r\n color: #aaaaaa;\r\n font-size: 20px;\r\n display: inline-block;\r\n}\r\n\r\n.as-np-item-pin-btn:hover > span {\r\n color: #dddddd;\r\n}\r\n\r\n\r\n.as-np-item.as-pin .as-np-item-unread-btn {\r\n top: calc(50% - 7px);\r\n}\r\n\r\n\r\n.as-np-item:not(.as-unread) .as-np-item-unread-btn,\r\n.as-np-item:not(.as-pin) .as-np-item-pin-btn {\r\n display: none;\r\n}\r\n\r\n\r\n.as-np-item-quick-menu-ctn {\r\n position: absolute;\r\n z-index: 1;\r\n right: 30px;\r\n top: calc(50% - 15px);\r\n visibility: hidden;\r\n\r\n}\r\n\r\n.as-np-item:hover .as-np-item-quick-menu-ctn {\r\n visibility: visible;\r\n}\r\n\r\n.as-np-item-quick-menu-btn {\r\n background-color: rgb(230, 230, 230);\r\n box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);\r\n width: 30px;\r\n height: 30px;\r\n border-radius: 50%;\r\n border: none;\r\n font-size: 20px;\r\n cursor: pointer;\r\n padding: 0;\r\n}\r\n\r\n.as-np-item-quick-menu-btn:active {\r\n box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);\r\n}\r\n\r\n\r\n.as-mb-vd-header-bar .as-header-bar-notification-action {\r\n display: none;\r\n}\r\n\r\n\r\n.as-mobile-notification-virtual-dropdown {\r\n position: fixed;\r\n right: 0;\r\n top: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: white;\r\n overflow: hidden;\r\n z-index: 1005;\r\n}\r\n\r\n\r\n.as-mobile-notification-virtual-dropdown.as-hidden {\r\n visibility: hidden;\r\n opacity: 0;\r\n z-index: -1000;\r\n}\r\n\r\n.as-mb-vd-body {\r\n height: calc(100% - 3em);\r\n overflow: auto;\r\n}\r\n\r\n.as-mb-vd-body .as-np-item-body {\r\n padding-right: 56px;\r\n}\r\n\r\n.as-mb-vd-body .as-np-item-quick-menu-ctn {\r\n visibility: visible;\r\n}\r\n\r\n.as-mb-vd-body .as-np-item-quick-menu-btn {\r\n background-color: transparent;\r\n box-shadow: none !important;\r\n}\r\n\r\n.as-mb-vd-body .as-np-item-quick-menu-btn:active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}", ""]); /***/ }), /***/ 1099: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-number-input {\r\n text-align: right;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n min-width: calc(1em + 2px);\r\n height: calc(2em + 2px);\r\n border: solid 1px #d6d6d6;\r\n font-size: 1rem;\r\n box-sizing: border-box;\r\n width: 4em;\r\n --text-width: 0.5em;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.absol-number-input.as-width-auto {\r\n width: calc(var(--text-width) + 1em);\r\n}\r\n\r\n.absol-number-input.as-has-stepper.as-width-auto {\r\n width: calc(var(--text-width) + 2.2em);\r\n}\r\n\r\n.absol-number-input-text-container {\r\n right: 0;\r\n left: 0em;\r\n top: 0;\r\n bottom: 0;\r\n position: absolute;\r\n}\r\n\r\n/*.absol-number-input.as-read-only .absol-number-input-button-up-container,*/\r\n/*.absol-number-input.as-read-only .absol-number-input-button-down-container,*/\r\n.absol-number-input-button-up-container,\r\n.absol-number-input-button-down-container {\r\n display: none;\r\n}\r\n\r\n.absol-number-input.as-read-only.as-border-none {\r\n border: none;\r\n}\r\n\r\n.absol-number-input.as-read-only.as-border-none input {\r\n /*text-align: left;*/\r\n padding-left: 0;\r\n}\r\n\r\n\r\n.absol-number-input-button-up-container {\r\n top: 0;\r\n}\r\n\r\n.absol-number-input-button-down-container {\r\n bottom: 0;\r\n}\r\n\r\n.absol-number-input.as-has-stepper .absol-number-input-button-up-container,\r\n.absol-number-input.as-has-stepper .absol-number-input-button-down-container {\r\n right: 0;\r\n position: absolute;\r\n height: 1em;\r\n width: 1em;\r\n max-height: 50%;\r\n overflow: hidden;\r\n display: block;\r\n}\r\n\r\n.absol-number-input-button-up-container > button,\r\n.absol-number-input-button-down-container > button {\r\n width: 100%;\r\n height: 100%;\r\n line-height: 1;\r\n padding: 0;\r\n border: none;\r\n box-sizing: border-box;\r\n outline: none;\r\n color: rgb(101, 101, 101);\r\n background-color: transparent;\r\n font-size: inherit;\r\n}\r\n\r\n.as-printer-content .absol-number-input button {\r\n display: none;\r\n}\r\n\r\n.absol-number-input-button-up-container > button:active,\r\n.absol-number-input-button-down-container > button:active {\r\n color: black;\r\n background-color: rgba(101, 101, 101, 0.3);\r\n}\r\n\r\n.absol-number-input.as-has-stepper .absol-number-input-text-container {\r\n right: 1.2em;\r\n}\r\n\r\n\r\n.absol-number-input-text-container > input[type=\"text\"] {\r\n border: none;\r\n outline: none;\r\n width: 100%;\r\n height: 100%;\r\n text-align: right;\r\n padding: 0 0.35em;\r\n box-sizing: border-box;\r\n font: inherit;\r\n}\r\n\r\n.absol-number-input.as-has-stepper .absol-number-input-text-container > input[type=\"text\"] {\r\n padding: 0 0.2em;\r\n}\r\n\r\n.absol-number-input.absol-disabled {\r\n pointer-events: none;\r\n color: var(--as-disabled-text-color);\r\n}\r\n\r\n.absol-number-input.absol-disabled input {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.absol-number-input.absol-disabled .absol-number-input-button-up-container,\r\n.absol-number-input.absol-disabled .absol-number-input-button-down-container {\r\n opacity: 0.3;\r\n}\r\n\r\nbody.as-number-input-force-dragging {\r\n user-select: none;\r\n pointer-events: none;\r\n}\r\n\r\n.as-number-input-mouse-line {\r\n border: 1px dashed #bfc1c2;\r\n position: fixed;\r\n z-index: 1e8;\r\n}", ""]); /***/ }), /***/ 8900: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-omt {\r\n display: block;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n}\r\n\r\n.as-omt-node {\r\n\r\n}\r\n\r\n\r\n.as-omt-field {\r\n --level: 0;\r\n position: relative;\r\n padding-bottom: 10px;\r\n}\r\n\r\n\r\n.as-omt-field.as-hover::before {\r\n border-color: rgb(30, 101, 234);\r\n border-width: 2px;\r\n}\r\n\r\n.as-omt-field::before {\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n top: 15px;\r\n right: 0;\r\n bottom: 0;\r\n border: 1px solid rgb(170, 170, 200);\r\n z-index: 0;\r\n pointer-events: none;\r\n}\r\n\r\n.as-omt-field-header {\r\n padding-left: 10px;\r\n line-height: 2;\r\n}\r\n\r\n\r\n.as-omt-field-body {\r\n padding-left: 10px;\r\n padding-right: 10px;\r\n min-height: 1em;\r\n}\r\n\r\n\r\n.as-omt-field-raw-ctn,\r\n.as-omt-field.as-mode-raw > .as-omt-field-body {\r\n display: none;\r\n}\r\n\r\n.as-omt-field.as-mode-raw > .as-omt-field-raw-ctn {\r\n display: block;\r\n}\r\n\r\n\r\n.as-omt-field-command-ctn {\r\n position: absolute;\r\n z-index: 20;\r\n right: 10px;\r\n top: 20px;\r\n background-color: white;\r\n height: 30px;\r\n display: none;\r\n}\r\n\r\n.bsc-white .as-omt-field-command-ctn button[data-command=\"view_mode\"] {\r\n display: none;\r\n}\r\n\r\n\r\n.as-omt-field.as-hover > .as-omt-field-command-ctn {\r\n display: block;\r\n}\r\n\r\n.as-omt-field-command-ctn > button {\r\n height: 30px;\r\n}\r\n\r\n.as-omt-field-command-ctn > button:not(:first-child) {\r\n margin-left: 5px;\r\n}\r\n\r\n.as-omt-field-command-ctn > button span {\r\n font-size: 24px;\r\n}\r\n\r\n.as-omt-field-name {\r\n font-weight: bold;\r\n background-color: white;\r\n display: inline-block;\r\n z-index: 3;\r\n position: relative;\r\n padding-left: 5px;\r\n padding-right: 5px;\r\n margin-right: 10px;\r\n}\r\n\r\n\r\n.as-omt-field-body > .as-omt-field:first-child {\r\n margin-top: 10px;\r\n}\r\n\r\n.as-omt-field code {\r\n white-space: pre-wrap;\r\n}\r\n\r\n.as-omt-field-raw-ctn {\r\n padding-left: 10px;\r\n padding-right: 10px;\r\n}\r\n\r\n.as-omt-field.as-type-struct > .as-omt-field-body {\r\n padding-left: 20px;\r\n}\r\n\r\nimg.as-omt-field-value {\r\n max-width: calc(100vw - 5em);\r\n max-height: 10em;\r\n}\r\n\r\n.as-omt-dialog .as-message-dialog-body {\r\n max-height: calc(90vh - 5em);\r\n max-width: calc(90vw - 5em);\r\n overflow: auto;\r\n}\r\n\r\n.as-omt-option-row {\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n.as-omt-option-row:not(:first-child) {\r\n margin-top: 5px;\r\n}\r\n\r\n.as-omt-field-raw-ctn > div > .as-omt-field-name {\r\n display: none;\r\n}\r\n\r\n.as-omt-option-row > .as-omt-field {\r\n flex-grow: 1;\r\n}\r\n\r\n\r\n.as-omt-field-color-value-bg {\r\n height: 2em;\r\n width: 5em;\r\n background-image: url('');\r\n background-size: 1.5em;\r\n image-rendering: optimizeSpeed;\r\n image-rendering: -moz-crisp-edges;\r\n image-rendering: -o-crisp-edges;\r\n image-rendering: -webkit-optimize-contrast;\r\n image-rendering: pixelated;\r\n image-rendering: optimize-contrast;\r\n -ms-interpolation-mode: nearest-neighbor;\r\n --omt-color-value: transparent;\r\n}\r\n\r\n.as-omt-field-color-value {\r\n width: 100%;\r\n height: 100%;\r\n background-color: var(--omt-color-value);\r\n}\r\n", ""]); /***/ }), /***/ 2743: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-onscreen-widget {\r\n --client-width: 0px;\r\n --client-height: 0px;\r\n --cx: 0.9;\r\n --cy: 0.9;\r\n position: fixed;\r\n z-index: 1000000;\r\n left: calc((100vw - var(--client-width) - 4px) * var(--cx) + 2px);\r\n top: calc((100vh - var(--client-height) - 4px) * var(--cy) + 2px);\r\n touch-action: none;\r\n user-select: none;\r\n}\r\n\r\n.as-onscreen-widget.as-size-loading {\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 2356: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-onscreen-window {\r\n z-index: 1002;\r\n position: fixed;\r\n left: 10px;\r\n top: 10px;\r\n width: 12em;\r\n height: 5em;\r\n /*default size*/\r\n /* min-width: 12em;\r\n min-height: 1.4em; */\r\n}\r\n\r\n\r\n.absol-onscreen-window > .as-window-box {\r\n width: 100%;\r\n height: 100%;\r\n display: flex;\r\n flex-direction: column;\r\n}\r\n\r\n.absol-onscreen-window > .as-window-box > .as-window-box-body {\r\n flex-grow: 1;\r\n}\r\n\r\n.as-window-box {\r\n position: relative;\r\n\r\n background: white;\r\n -webkit-box-shadow: 2px 2px 17px -1px rgba(0, 0, 0, 0.54);\r\n -moz-box-shadow: 2px 2px 17px -1px rgba(0, 0, 0, 0.54);\r\n box-shadow: 2px 2px 17px -1px rgba(0, 0, 0, 0.54);\r\n}\r\n\r\n.as-window-box-header {\r\n display: flex;\r\n min-height: 1.4em;\r\n position: relative;\r\n background-color: rgba(169, 169, 169, 0.15);\r\n padding: 0.2em;\r\n box-sizing: border-box;\r\n align-items: center;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n.as-window-box-header-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n.as-window-box-header-title {\r\n flex-grow: 1;\r\n padding-left: 0.2em;\r\n}\r\n\r\n.as-window-box-header-button-ctn {\r\n}\r\n\r\n.as-window-box-header-icon {\r\n margin-right: 0.2em;\r\n font-size: inherit;\r\n}\r\n\r\nspan.as-window-box-header-icon {\r\n line-height: 1.2em;\r\n}\r\n\r\nsvg.as-window-box-header-icon {\r\n width: 1.2em;\r\n height: 1.2em;\r\n}\r\n\r\nspan.as-window-box-header-title {\r\n line-height: 1.2em;\r\n font-size: 1em;\r\n color: rgb(33, 33, 34);\r\n}\r\n\r\n\r\n.as-window-box-header-button-ctn > button {\r\n height: 100%;\r\n width: 1em;\r\n font-size: 1em;\r\n padding: 0;\r\n margin: 0 0 0 0.1em;\r\n border: none;\r\n color: rgb(169, 169, 169);\r\n outline: none;\r\n}\r\n\r\n.as-window-box-header-button-ctn > button:hover {\r\n color: rgb(103, 103, 103);\r\n}\r\n\r\n.as-window-box-header-button-ctn > button:active {\r\n color: rgb(33, 33, 34);\r\n}\r\n\r\n.as-window-box-header-button-ctn > button:hover > .mdi-close {\r\n color: rgb(255, 59, 59);\r\n}\r\n\r\n.as-window-box-header-button-ctn > button > span {\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-onscreen-window-body-container {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 1.4em;\r\n bottom: 0;\r\n}\r\n\r\n\r\n.absol-onscreen-window-moving-modal {\r\n position: fixed;\r\n left: 1px;\r\n right: 1px;\r\n top: 1px;\r\n bottom: 1px;\r\n z-index: 1000000006;\r\n}\r\n\r\n.absol-onscreen-window-resizer {\r\n position: absolute;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom {\r\n bottom: -3px;\r\n height: 6px;\r\n left: 3px;\r\n right: 3px;\r\n z-index: 3;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-top {\r\n top: -3px;\r\n height: 6px;\r\n left: 3px;\r\n right: 3px;\r\n z-index: 3;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-left {\r\n left: -3px;\r\n top: 3px;\r\n bottom: 3px;\r\n width: 6px;\r\n cursor: ew-resize;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-right {\r\n right: -3px;\r\n top: 3px;\r\n bottom: 3px;\r\n width: 6px;\r\n cursor: ew-resize;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-right {\r\n width: 6px;\r\n height: 6px;\r\n right: -3px;\r\n bottom: -3px;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-bottom-left {\r\n width: 6px;\r\n height: 6px;\r\n left: -3px;\r\n bottom: -3px;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-left {\r\n width: 6px;\r\n height: 6px;\r\n left: -3px;\r\n top: -3px;\r\n}\r\n\r\n.absol-onscreen-window-resizer.absol-onscreen-window-resize-top-right {\r\n width: 6px;\r\n height: 6px;\r\n right: -3px;\r\n top: -3px;\r\n}\r\n\r\n\r\n.absol-onscreen-window-resize-top,\r\n.absol-onscreen-window-resize-bottom {\r\n cursor: ns-resize;\r\n\r\n}\r\n\r\n.absol-onscreen-window-resize-left,\r\n.absol-onscreen-window-resize-right {\r\n cursor: ew-resize;\r\n\r\n}\r\n\r\n\r\n.absol-onscreen-window-resize-bottom-right {\r\n cursor: se-resize;\r\n}\r\n\r\n.absol-onscreen-window-resize-bottom-left {\r\n cursor: sw-resize;\r\n}\r\n\r\n.absol-onscreen-window-resize-top-left {\r\n cursor: nw-resize;\r\n}\r\n\r\n.absol-onscreen-window-resize-top-right {\r\n cursor: ne-resize;\r\n}", ""]); /***/ }), /***/ 4610: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-page-indicator {\r\n text-align: center;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-page-indicator::before{\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-page-indicator-item {\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-align: center;\r\n font-size: inherit;\r\n width: 1.5em;\r\n padding: 0;\r\n border: 0;\r\n background-color: transparent;\r\n}\r\n\r\n\r\n\r\n.as-page-indicator-item::before {\r\n content: \"\";\r\n display: inline-block;\r\n height: 0.5em;\r\n width: 0.5em;\r\n transition: width 0.25s, height 0.25s, color 0.25s;\r\n border-radius: 50%;\r\n background-color: rgb(196, 196, 196);\r\n font-size: inherit;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-page-indicator-item.as-active::before{\r\n width: 0.75em;\r\n height: 0.75em;\r\n background-color: var(--variant-color-primary);\r\n\r\n}", ""]); /***/ }), /***/ 5622: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-page-selector {\r\n white-space: normal;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.absol-page-selector > ul {\r\n margin-bottom: 0px;\r\n margin-top: 0;\r\n}\r\n\r\n.absol-page-number-buttons {\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-page-number-input > label {\r\n font-weight: 100;\r\n}\r\n\r\n.absol-page-number-buttons > li.page-previous,\r\n.absol-page-number-buttons > li.page-next,\r\n.absol-page-number-buttons > li.page-first,\r\n.absol-page-number-buttons > li.page-last {\r\n display: inline-block;\r\n height: calc(2em + 2px);;\r\n padding-left: 10px;\r\n padding-right: 10px;\r\n text-align: center;\r\n transition: all .3s linear;\r\n background-color: transparent;\r\n cursor: pointer;\r\n}\r\n\r\n.absol-page-number-buttons > li.absol-page-number {\r\n font-size: inherit;\r\n display: inline-block;\r\n height: calc(2em + 2px);\r\n width: 3em;\r\n text-align: center;\r\n transition: all .3s linear;\r\n background-color: transparent;\r\n cursor: pointer;\r\n}\r\n\r\nli.absol-page-number > a {\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.absol-page-number-buttons > li.absol-page-number.active {\r\n box-shadow: 0 2px 5px 0 rgba(0, 0, 0, .16), 0 2px 10px 0 rgba(0, 0, 0, .12);\r\n background-color: #4285f4;\r\n border-radius: 2px;\r\n\r\n}\r\n\r\n.absol-page-number-buttons > li.absol-page-number.active > a {\r\n color: white;\r\n\r\n}\r\n\r\n.absol-page-number-buttons > li > a {\r\n line-height: calc(2em + 2px);\r\n text-decoration: none;\r\n outline: none;\r\n}\r\n\r\n.absol-page-number-buttons > li:not(.active):hover {\r\n background-color: var(--icon-background-cover-hover);\r\n\r\n}\r\n\r\n.absol-page-selector .absol-page-number-input {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-page-selector .absol-page-number-input input[type=\"text\"] {\r\n font-size: inherit;\r\n width: 3em;\r\n margin-left: 0.3em;\r\n margin-right: 0.3em;\r\n text-align: center;\r\n height: 1.8em;\r\n border: solid 1px #ccc;\r\n border-radius: 2px;\r\n\r\n}\r\n\r\n.absol-page-link {\r\n color: #147af6;\r\n cursor: pointer;\r\n text-decoration: underline;\r\n}\r\n\r\n.absol-page-number {\r\n color: #147af6;\r\n cursor: pointer;\r\n}\r\n\r\n.absol-page-number a::before {\r\n content: attr(data-index-text);\r\n}\r\n\r\n.absol-page-selector.as-simple-mode .absol-page-number,\r\n.absol-page-selector.as-simple-mode .page-first,\r\n.absol-page-selector.as-simple-mode .page-last{\r\n display: none;\r\n}\r\n\r\n.absol-page-selector.as-simple-mode .mdi{\r\n font-size: 20px;\r\n line-height: 1.5;\r\n}", ""]); /***/ }), /***/ 8815: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --as-path-menu-max-text-width: 150px;\r\n}\r\n\r\n.am-mobile-theme {\r\n --as-path-menu-max-text-width: 100px;\r\n}\r\n\r\n\r\n.as-path-menu-item .mdi-chevron-right::before {\r\n transition: transform 0.1s;\r\n}\r\n\r\n.as-path-menu .as-ribbon-split-button-text {\r\n max-width: var(--as-path-menu-max-text-width);\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n display: inline-block;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-path-menu-item.as-has-no-item .as-ribbon-split-button-extend {\r\n display: none;\r\n}\r\n\r\n\r\n.as-path-view {\r\n white-space: nowrap;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n font-size: 1em;\r\n height: calc(2em + 2px);\r\n}\r\n\r\n.as-path-view-item {\r\n display: inline-block;\r\n white-space: nowrap;\r\n background: transparent;\r\n border: 1px solid transparent;\r\n box-sizing: border-box;\r\n height: 100%;\r\n position: relative;\r\n padding-left: 0.5em;\r\n padding-right: 0;\r\n cursor: pointer;\r\n font-size: inherit;\r\n}\r\n\r\n.as-path-view-item:last-child {\r\n padding-right: 0.5em;\r\n}\r\n\r\n.as-path-view-item:hover {\r\n border-color: #dddddd;\r\n}\r\n\r\n.as-path-view-item::before{\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n right: 1em;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-path-view-item:last-child::before{\r\n right: 0;\r\n}\r\n\r\n.as-path-view-item:hover::before {\r\n background-color: rgba(169, 169, 169, 0.15);\r\n}\r\n\r\n.as-path-view-item:active::before {\r\n background-color: rgba(169, 169, 169, 0.3);\r\n}\r\n\r\n.as-path-view-item-icon {\r\n margin-right: 0.5em;\r\n}\r\n\r\nspan.as-path-view-item-icon,\r\ni.as-path-view-item-icon {\r\n font-size: 1.5em;\r\n line-height: 1;\r\n text-align: center;\r\n}\r\n\r\nsvg.as-path-view-item-icon,\r\nimg.as-path-view-item-icon {\r\n width: 1.5em;\r\n height: 1.5em;\r\n}\r\n\r\n\r\n\r\n.as-path-view-item-text {\r\n padding-right: 0.2em;\r\n}\r\n\r\n\r\n.as-path-view-item-arrow {\r\n width: 1em;\r\n text-align: center;\r\n}\r\n\r\n.as-path-view-item-icon,\r\n.as-path-view-item-text,\r\n.as-path-view-item-arrow {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-path-view-item:last-child .as-path-view-item-arrow {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 7508: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-picking-list {\r\n font-size: 14px;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n\r\n.as-picking-list-item {\r\n height: 30px;\r\n position: relative;\r\n padding-right: 40px;\r\n padding-left: 10px;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-picking-list-item::before {\r\n content: \"\";\r\n display: inline-block;\r\n height: 100%;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-picking-list-item-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-picking-list-item:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-picking-list-item:active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.as-picking-list-item-checked {\r\n position: absolute;\r\n right: 5px;\r\n top: 0;\r\n bottom: 0;\r\n font-size: 20px;\r\n}\r\n\r\n.as-picking-list-item-checked::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-picking-list-item-checked::before,\r\n.as-picking-list-item-checked span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: inherit;\r\n}\r\n\r\n.as-picking-list-item:not(.as-checked) .as-picking-list-item-checked {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 9963: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-autocomplete-input-item.as-place-search-auto-complete-item:not(:last-child) {\r\n border-bottom: 1px solid #dddddd;\r\n\r\n}\r\n\r\n.absol-autocomplete-input-item.as-place-search-auto-complete-item {\r\n padding: 3px 5px;\r\n height: auto;\r\n}\r\n", ""]); /***/ }), /***/ 4050: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-preinput {\r\n margin: 0;\r\n padding: 0;\r\n white-space: pre-wrap;\r\n -moz-user-modify: read-write;\r\n -webkit-user-modify: read-write;\r\n word-break: normal;\r\n}\r\npre.as-preinput{\r\n word-break: normal;\r\n}\r\n\r\n\r\n.as-preinput img {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 2819: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --as-process-l-bar-active-color: rgb(255, 160, 0);\r\n --as-process-l-bar-item-width: 60px;\r\n}\r\n\r\n.as-process-l-bar {\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 14px;\r\n display: inline-block;\r\n vertical-align: top;\r\n position: relative;\r\n --as-process-l-bar-item-min-width: 0;\r\n}\r\n\r\n\r\n\r\n.as-process-l-bar-step-ctn {\r\n white-space: nowrap;\r\n}\r\n\r\n.as-process-l-bar-col:not(:last-child) {\r\n margin-right: 10px;\r\n}\r\n\r\n.as-process-l-bar-col {\r\n vertical-align: top;\r\n display: inline-block;\r\n}\r\n\r\n.as-process-l-bar-step {\r\n width: var(--as-process-l-bar-item-width);\r\n min-width: var(--as-process-l-bar-item-min-width);\r\n height: 15px;\r\n background-color: #ebebeb;\r\n border: solid 1px #bfbfbf;\r\n transition: background-color 0.2s;\r\n position: relative;\r\n}\r\n\r\n\r\n\r\n.as-process-l-bar-step.as-active {\r\n background-color: var(--as-process-l-bar-active-color);\r\n border-color: rgb(20, 100, 246);\r\n}\r\n\r\n.as-process-l-bar-step.as-active::after {\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: calc(100% + 3px);\r\n border-top: 2px solid rgb(20, 100, 246);\r\n}\r\n\r\n\r\n.as-process-l-bar-step::before {\r\n content: \"\";\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-process-l-bar.as-disabled .as-process-l-bar-step::before{\r\n display: none;\r\n}\r\n\r\n.as-process-l-bar-step:hover::before {\r\n background-color: rgba(169, 169, 172, 0.3);\r\n}\r\n\r\n.as-process-l-bar-step.as-active,\r\n.as-process-l-bar-step:hover {\r\n background-color: var(--as-process-l-bar-active-color);\r\n}\r\n\r\n\r\n.as-process-l-bar-col .as-process-l-bar-step:not(:last-child) {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.as-process-l-bar-step-name {\r\n position: absolute;\r\n left: 0;\r\n top: 24px;\r\n font-weight: bold;\r\n}\r\n\r\n\r\n.as-process-l-bar.as-col-layout .as-process-l-bar-step-name {\r\n position: relative;\r\n left: initial;\r\n top: unset;\r\n}\r\n\r\n\r\n.as-process-l-bar.as-single-line .as-process-l-bar-step-ctn {\r\n white-space: normal;\r\n}\r\n\r\n\r\n.as-process-l-bar.as-single-line .as-process-l-bar-col {\r\n margin-bottom: 10px;\r\n}\r\n\r\n.as-process-l-bar.as-single-line .as-process-l-bar-step-name {\r\n position: relative;\r\n display: block;\r\n left: 0 !important;\r\n top: 0!important;\r\n}", ""]); /***/ }), /***/ 2015: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-progress-bar {\r\n height: 1em;\r\n background-color: #e9ecef;\r\n border-radius: .25em;\r\n box-sizing: border-box;\r\n overflow: hidden;\r\n --value-color: #007bff;\r\n}\r\n\r\n\r\n.as-progress-bar-value {\r\n height: 100%;\r\n width: 0;\r\n color: #fff;\r\n text-align: center;\r\n white-space: nowrap;\r\n background-color: var(--value-color);\r\n transition: width .6s ease;\r\n}\r\n\r\n.as-progress-bar.as-variant-success,\r\n.as-progress-circle.as-variant-success {\r\n --value-color: #28a745;\r\n}\r\n\r\n.as-progress-bar.as-variant-info,\r\n.as-progress-circle.as-variant-info {\r\n --value-color: #17a2b8;\r\n}\r\n\r\n.as-progress-bar.as-variant-warning,\r\n.as-progress-circle.as-variant-warning {\r\n --value-color: #ffc107;\r\n}\r\n\r\n.as-progress-bar.as-variant-danger,\r\n.as-progress-circle.as-variant-danger {\r\n --value-color: #dc3545;\r\n}\r\n\r\n\r\n.as-progress-bar.as-striped .as-progress-bar-value,\r\n.as-progress-bar.as-animated .as-progress-bar-value {\r\n background-image: linear-gradient(45deg, hsla(0, 0%, 100%, .15) 25%, transparent 0, transparent 50%, hsla(0, 0%, 100%, .15) 0, hsla(0, 0%, 100%, .15) 75%, transparent 0, transparent);\r\n background-size: 1.33333em 1.33333em;\r\n}\r\n\r\n@keyframes as-progress-bar-stripes {\r\n 0% {\r\n background-position: 1.33333em 0\r\n }\r\n\r\n to {\r\n background-position: 0 0\r\n }\r\n}\r\n\r\n.as-progress-bar.as-animated .as-progress-bar-value {\r\n animation: as-progress-bar-stripes 1s linear infinite;\r\n}\r\n\r\n\r\n.as-progress-circle {\r\n display: inline-block;\r\n width: 7em;\r\n height: 7em;\r\n background-color: #fcfcf6;\r\n border-radius: 50%;\r\n position: relative;\r\n --value-color: #007bff;\r\n\r\n box-shadow: 3px 2px 12px -1px rgba(0, 0, 0, 0.1) inset;\r\n overflow: hidden;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.as-progress-circle-inner {\r\n background-color: white;\r\n position: absolute;\r\n border-radius: 50%;\r\n left: 0.8em;\r\n right: 0.8em;\r\n top: 0.8em;\r\n bottom: 0.8em;\r\n font-size: 1rem;\r\n box-shadow: 3px 2px 12px -1px rgba(0, 0, 0, 0.1);\r\n white-space: nowrap;\r\n text-align: center;\r\n}\r\n\r\n\r\n.as-progress-circle-inner::before {\r\n content: \"\";\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-progress-circle-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: pre-wrap;\r\n max-width: calc(100% - 0.3em);\r\n font-size: 1em;\r\n color: #454c5b;\r\n}\r\n\r\n.as-progress-circle-start,\r\n.as-progress-circle-end {\r\n border-radius: 50%;\r\n width: 0.8em;\r\n height: 0.8em;\r\n background-color: var(--value-color);\r\n /*background-color: red;*/\r\n top: 0;\r\n left: calc(50% - 0.4em);\r\n position: absolute;\r\n /*box-shadow: 3px 2px 12px -1px rgba(0, 0, 0, 0.1);*/\r\n}\r\n\r\n.as-progress-circle-pie {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n border-radius: 50%;\r\n background-color: var(--value-color);\r\n}\r\n\r\n\r\n.as-progress-circle-end {\r\n\r\n}\r\n\r\n\r\n", ""]); /***/ }), /***/ 4734: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-quick-list-button {\r\n box-sizing: border-box;\r\n height: calc(2em + 2px);\r\n font-size: 14px;\r\n}\r\n\r\n.as-quick-list-button .as-flexicon-button-text-container {\r\n border-right: solid 1px #bfbfbf;\r\n}\r\n\r\n\r\n.as-quick-list-button-follower .absol-selectlist {\r\n max-height: calc(100vh - 20px);\r\n overflow-y: auto;\r\n border: solid 1px rgb(100, 100, 255);\r\n box-sizing: border-box;\r\n background-color: white;\r\n display: inline-block;\r\n vertical-align: top;\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n}", ""]); /***/ }), /***/ 3346: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-quick-path {\r\n position: relative;\r\n box-sizing: border-box;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -ms-user-select: none;\r\n -moz-user-select: none;\r\n min-height: 1.5em;\r\n}\r\n\r\n.absol-quick-path button {\r\n outline: none;\r\n color: rgb(69, 69, 69);\r\n height: 1.5em;\r\n}\r\n\r\n.absol-quick-path button:hover {\r\n color: black;\r\n}\r\n\r\n.absol-quick-path .toggler-ico path {\r\n fill: rgb(104, 104, 104);\r\n}\r\n\r\n.dark .absol-quick-path button {\r\n color: rgb(200, 200, 200);\r\n}\r\n\r\n\r\n.dark .absol-quick-path button:hover {\r\n color: white;\r\n}\r\n\r\n.dark .absol-quick-path .toggler-ico path {\r\n fill: rgb(169, 169, 169);\r\n}\r\n\r\n\r\n\r\n.absol-quick-path-btn:focus span {\r\n text-decoration: underline;\r\n}\r\n\r\n/* \r\n.absol-quick-path-btn .toggler-ico path {\r\n fill: rgb(104, 104, 104);\r\n} */\r\n", ""]); /***/ }), /***/ 9450: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-radio {\r\n display: inline;\r\n cursor: pointer;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-radio input {\r\n display: none;\r\n}\r\n\r\n.absol-radio > span {\r\n white-space: pre;\r\n cursor: inherit;\r\n vertical-align: middle;\r\n margin: 0;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-radio > span:empty {\r\n display: none;\r\n}\r\n\r\n.absol-radio > svg {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: calc(1em + 4px);\r\n height: calc(1em + 4px);\r\n}\r\n\r\n.absol-radio > svg .bound {\r\n stroke: #929292;\r\n fill: white;\r\n}\r\n\r\n.absol-radio:hover > svg .bound {\r\n fill: #d6d6d6;\r\n stroke: black;\r\n}\r\n\r\n/* \r\n.absol-radio>svg .bound {\r\n fill: none;\r\n} */\r\n\r\n.absol-radio-icon .border {\r\n}\r\n\r\n.absol-radio .dot {\r\n transition: opacity 0.07s;\r\n opacity: 0;\r\n fill: #606060;\r\n}\r\n\r\n.absol-radio:hover .dot {\r\n transition: opacity 0.07s;\r\n opacity: 0;\r\n fill: black;\r\n}\r\n\r\n.absol-radio.checked .dot {\r\n opacity: 1;\r\n transition: opacity 0.1s;\r\n}\r\n\r\n.absol-radio:not(.right) > span.absol-radio-left-label {\r\n display: none;\r\n}\r\n\r\n.absol-radio.right > span.absol-radio-right-label {\r\n display: none;\r\n}\r\n\r\nspan.absol-radio-left-label {\r\n padding-right: 0.3em;\r\n}\r\n\r\nspan.absol-radio-right-label {\r\n padding-left: 0.3em;\r\n}\r\n\r\n\r\n\r\n\r\n.absol-radio.disabled {\r\n cursor: default;\r\n}\r\n\r\n.absol-radio.disabled{\r\n color: #777;\r\n}\r\n\r\n.absol-radio.disabled:hover .dot,\r\n.absol-radio.disabled .dot {\r\n fill: #929292;\r\n}\r\n\r\n.absol-radio.disabled .bound,\r\n.absol-radio.disabled:hover .bound {\r\n stroke: #929292;\r\n fill: #ebebe4;\r\n}\r\n\r\n\r\n.absol-radio .standar-alone {\r\n display: inline-block;\r\n}\r\n\r\ninput:checked ~ .absol-radio-icon .dot {\r\n opacity: 1;\r\n}", ""]); /***/ }), /***/ 3813: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-radio-button {\r\n display: inline;\r\n cursor: pointer;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-radio-button input {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-radio-button > svg {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: calc(1em + 4px);\r\n height: calc(1em + 4px);\r\n}\r\n\r\n.absol-radio-button > svg .bound {\r\n stroke: #929292;\r\n fill: white;\r\n}\r\n\r\n.absol-radio-button:hover > svg .bound {\r\n fill: #d6d6d6;\r\n stroke: black;\r\n}\r\n\r\n.absol-radio-icon .border {\r\n}\r\n\r\n.absol-radio-button .dot {\r\n transition: opacity 0.07s;\r\n opacity: 0;\r\n fill: #606060;\r\n}\r\n\r\n.absol-radio-button:hover .dot {\r\n transition: opacity 0.07s;\r\n opacity: 0;\r\n fill: black;\r\n}\r\n\r\n.absol-radio-button.checked .dot {\r\n opacity: 1;\r\n transition: opacity 0.1s;\r\n}\r\n\r\n\r\n\r\n.absol-radio-button > span:last-child {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-radio-button.disabled {\r\n cursor: default;\r\n}\r\n\r\n.absol-radio-button.disabled:hover .dot,\r\n.absol-radio-button.disabled .dot {\r\n fill: #929292;\r\n}\r\n\r\n.absol-radio-button.disabled .bound,\r\n.absol-radio-button.disabled:hover .bound {\r\n stroke: #929292;\r\n fill: #ebebe4;\r\n}\r\n\r\n\r\n.absol-radio .standar-alone {\r\n display: inline-block;\r\n}\r\n\r\n.absol-radio > span:not(:last-child) {\r\n padding-right: 0.3em;\r\n}\r\n\r\n.absol-radio span:last-child {\r\n padding-left: 0.3em;\r\n}\r\n\r\ninput:checked ~ .absol-radio-icon .dot {\r\n opacity: 1;\r\n}", ""]); /***/ }), /***/ 5517: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "label.as-radio-input {\r\n display: inline-block;\r\n position: relative;\r\n width: calc(1em + 2px);\r\n height: calc(1em + 2px);\r\n cursor: pointer;\r\n font-size: inherit;\r\n box-sizing: border-box;\r\n overflow: hidden;\r\n vertical-align: middle;\r\n border-radius: 50%;\r\n border: 1px solid var(--candy-border-color);\r\n text-align: center;\r\n background-color: white;\r\n text-align: center;\r\n white-space: nowrap;\r\n}\r\n\r\nlabel.as-radio-input:hover {\r\n background-color: var(--candy-hover-background-color);\r\n}\r\n\r\nlabel.as-radio-input::after{\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.as-radio-input .as-radio-input-check-mark {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 0.5em;\r\n height: 0.5em;\r\n background-color: #606060;\r\n font-size: inherit;\r\n border-radius: 50%;\r\n}\r\n\r\n.as-radio-input input.as-radio-input-value {\r\n font-size: inherit;\r\n position: absolute;\r\n right: 100%;\r\n top: 0;\r\n opacity: 0.0;\r\n}\r\n\r\ninput.as-radio-input-value:not(:checked) ~ .as-radio-input-check-mark {\r\n display: none;\r\n}\r\n\r\n\r\nlabel.as-radio-input.as-disabled,\r\nlabel.as-radio-input.as-disabled:hover {\r\n border-color: #929292;\r\n background-color: #ebebe4;\r\n}", ""]); /***/ }), /***/ 9955: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-resize-box {\r\n position: absolute;\r\n /*or fixed*/\r\n z-index: 1;\r\n box-sizing: border-box;\r\n opacity: 0.5;\r\n pointer-events: none;\r\n}\r\n\r\n.as-resize-box-body {\r\n margin: -1px;\r\n width: calc(100% + 2px);\r\n height: calc(100% + 2px);\r\n position: relative;\r\n box-sizing: border-box;\r\n border: solid 2px rgb(32, 150, 218);\r\n}\r\n\r\n.as-resize-box.as-can-move .as-resize-box-body {\r\n cursor: move;\r\n pointer-events: all;\r\n}\r\n\r\n.as-resize-box.as-can-click .as-resize-box-body {\r\n pointer-events: all;\r\n}\r\n\r\n.as-resize-box.as-can-move .as-resize-box-dot,\r\n.as-resize-box.as-can-resize .as-resize-box-dot.right,\r\n.as-resize-box.as-can-resize .as-resize-box-dot.bottom,\r\n.as-resize-box.as-can-resize .as-resize-box-dot.right-bottom {\r\n display: unset;\r\n\r\n}\r\n\r\n.as-resize-box-dot {\r\n position: absolute;\r\n width: 0.6em;\r\n height: 0.6em;\r\n background: rgb(32, 150, 218);\r\n display: none;\r\n pointer-events: all;\r\n}\r\n\r\n.as-resize-box-dot.left-top {\r\n top: calc(-0.3em - 1px);\r\n left: calc(-0.3em - 1px);\r\n cursor: nw-resize;\r\n}\r\n\r\n.as-resize-box-dot.left-bottom {\r\n bottom: calc(-0.3em - 1px);\r\n left: calc(-0.3em - 1px);\r\n cursor: sw-resize;\r\n}\r\n\r\n.as-resize-box-dot.left {\r\n top: calc(50% - 0.3em);\r\n left: calc(-0.3em - 1px);\r\n cursor: w-resize;\r\n}\r\n\r\n.as-resize-box-dot.top {\r\n top: calc(-0.3em - 1px);\r\n left: calc(50% - 0.3em);\r\n cursor: n-resize;\r\n}\r\n\r\n.as-resize-box-dot.bottom {\r\n bottom: calc(-0.3em - 1px);\r\n left: calc(50% - 0.3em);\r\n cursor: s-resize;\r\n}\r\n\r\n.as-resize-box-dot.right-top {\r\n top: calc(-0.3em - 1px);\r\n right: calc(-0.3em - 1px);\r\n cursor: ne-resize;\r\n}\r\n\r\n.as-resize-box-dot.right-bottom {\r\n bottom: calc(-0.3em - 1px);\r\n right: calc(-0.3em - 1px);\r\n cursor: se-resize;\r\n}\r\n\r\n\r\n.as-resize-box-dot.right {\r\n top: calc(50% - 0.3em);\r\n right: calc(-0.3em - 1px);\r\n cursor: e-resize;\r\n}\r\n\r\n.as-resize-box-overiding .as-resize-box-dot,\r\n.as-resize-box-overiding .as-resize-box-body {\r\n cursor: unset;\r\n}\r\n\r\n.as-resize-box-overiding.body {\r\n cursor: move !important;\r\n}\r\n\r\n\r\n.as-resize-box-overiding.left-top {\r\n cursor: nw-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.left-bottom {\r\n cursor: sw-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.left {\r\n cursor: w-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.top {\r\n cursor: n-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.bottom {\r\n cursor: s-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.right-top {\r\n cursor: ne-resize !important;\r\n}\r\n\r\n.as-resize-box-overiding.right-bottom {\r\n cursor: se-resize !important;\r\n}\r\n\r\n\r\n.as-resize-box-overiding.right {\r\n cursor: e-resize !important;\r\n}", ""]); /***/ }), /***/ 2946: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-ribbon-button {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: calc(2em + 2);\r\n padding-left: 0.5em;\r\n padding-right: 0.5em;\r\n\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n box-sizing: border-box;\r\n border-radius: 0;\r\n outline: none;\r\n border-style: solid;\r\n border-color: transparent;\r\n border-width: 1px 1px 1px 1px;\r\n background-color: transparent;\r\n}\r\n\r\n.as-ribbon-button:disabled .as-ribbon-button-icon {\r\n color: rgba(16, 16, 16, 0.3) !important;\r\n}\r\n\r\n.as-ribbon-button div,\r\n.as-ribbon-button span {\r\n font-weight: inherit;\r\n font-size: inherit;\r\n}\r\n\r\n.as-ribbon-button:hover {\r\n background-color: rgba(169, 168, 169, 0.15);\r\n}\r\n\r\n.as-ribbon-button:active {\r\n background-color: rgba(169, 168, 169, 0.3);\r\n}\r\n\r\n\r\n.as-ribbon-split-button:active:hover .as-ribbon-split-button-content > button,\r\n.as-ribbon-split-button:active .as-ribbon-split-button-content > button {\r\n border-color: rgba(169, 168, 169, 0.3);\r\n}\r\n\r\n.as-ribbon-split-button:hover .as-ribbon-split-button-content > button {\r\n border-color: rgba(169, 168, 169, 0.15);\r\n}\r\n\r\n.as-ribbon-button-icon {\r\n font-size: 1.2em;\r\n margin-right: 0.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\nimg.as-ribbon-button-icon,\r\nsvg.as-ribbon-button-icon {\r\n width: 1.2em;\r\n height: 1.2em;\r\n}\r\n\r\n.as-ribbon-button-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: inherit;\r\n}\r\n\r\n.as-ribbon-button-text::before {\r\n content: attr(data-text);\r\n}\r\n\r\n.as-ribbon-button.as-no-dropdown .as-ribbon-dropdown-icon {\r\n display: none;\r\n}\r\n\r\n.as-ribbon-button.as-big {\r\n width: 5em;\r\n height: auto;\r\n white-space: nowrap;\r\n padding-left: 0;\r\n padding-right: 0;\r\n}\r\n\r\n.as-ribbon-button.as-big span.as-ribbon-button-icon {\r\n font-size: 2em;\r\n display: block;\r\n margin-left: auto;\r\n margin-right: auto;\r\n}\r\n\r\n.as-ribbon-button.as-big .as-ribbon-button-text {\r\n white-space: normal;\r\n max-width: calc(100% - 1em);\r\n}\r\n\r\n.as-ribbon-button.as-big svg.as-ribbon-button-icon,\r\n.as-ribbon-button.as-big img.as-ribbon-button-icon {\r\n height: 2em;\r\n width: 2em;\r\n display: block;\r\n margin-left: auto;\r\n margin-right: auto;\r\n}\r\n\r\n.as-ribbon-button.as-appearance-button {\r\n height: calc(2rem + 2px);\r\n box-sizing: border-box;\r\n border: solid 1px #bfbfbf;\r\n background-color: #ebebeb;\r\n border-radius: 0.2em;\r\n outline: none;\r\n font-size: 1rem;\r\n}\r\n\r\n\r\n.as-ribbon-button.as-appearance-button:hover {\r\n background-color: #D3D3D3;\r\n}\r\n\r\n.as-ribbon-button.as-appearance-button:active,\r\n.as-ribbon-button.as-appearance-button.as-quick-menu-attached {\r\n -webkit-box-shadow: inset 0 0.2em 0.25em rgba(0, 0, 0, 0.125);\r\n box-shadow: inset 0 0.2em 0.25em rgba(0, 0, 0, 0.125);\r\n}\r\n\r\n\r\n.as-select-ribbon-menu {\r\n color: #007bff;\r\n}\r\n\r\n.as-ribbon-selected {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n.as-mobile-ribbon-list > button {\r\n font-size: 12px;\r\n}\r\n\r\n@media screen and (min-width: 350px) {\r\n .as-mobile-ribbon-list .as-ribbon-button.as-big {\r\n width: 25%;\r\n }\r\n}\r\n\r\n\r\n@media screen and (max-width: 350px) {\r\n .as-mobile-ribbon-list .as-ribbon-button.as-big {\r\n width: 33%;\r\n }\r\n}\r\n\r\n.as-mobile-ribbon-list .as-ribbon-button {\r\n vertical-align: top;\r\n font-size: 13px;\r\n}\r\n\r\n.as-mobile-ribbon-list .as-ribbon-button.as-big span.as-ribbon-button-icon {\r\n font-size: 20px;\r\n}", ""]); /***/ }), /***/ 8192: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-ribbon-split-button {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: calc(2em + 2px);\r\n font-family: Arial, Helvetica, sans-serif;\r\n box-sizing: border-box;\r\n font-size: 1rem;\r\n}\r\n\r\n.as-ribbon-split-button div,\r\n.as-ribbon-split-button span,\r\n.as-ribbon-split-button button {\r\n font-weight: inherit;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.as-ribbon-split-button-content {\r\n height: 100%;\r\n}\r\n\r\n.as-ribbon-split-button-content > button {\r\n font-family: inherit;\r\n border-radius: 0;\r\n background-color: transparent;\r\n height: 100%;\r\n margin-right: 0;\r\n outline: none;\r\n box-sizing: border-box;\r\n border-style: solid;\r\n border-color: transparent;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-ribbon-split-button-content > button:hover {\r\n background-color: rgba(169, 168, 169, 0.15);\r\n}\r\n\r\n.as-ribbon-split-button-content > button:active {\r\n background-color: rgba(169, 168, 169, 0.3);\r\n}\r\n\r\n\r\n.as-ribbon-split-button-primary {\r\n font-size: inherit;\r\n padding-left: 0.5em;\r\n padding-right: 0.2em;\r\n border-width: 1px 0px 1px 1px;\r\n color: inherit;\r\n}\r\n\r\n.as-ribbon-split-button-extend {\r\n color: rgb(37, 36, 35);\r\n width: calc(1em + 2px);\r\n padding: 0;\r\n text-align: center;\r\n font-size: 20px;\r\n border-width: 1px 1px 1px 0px;\r\n}\r\n\r\n.as-ribbon-split-button-extend span:before {\r\n margin-left: -3px;\r\n}\r\n\r\n\r\n.as-ribbon-split-button:active:hover .as-ribbon-split-button-content > button,\r\n.as-ribbon-split-button:active .as-ribbon-split-button-content > button {\r\n border-color: rgba(169, 168, 169, 0.3);\r\n}\r\n\r\n.as-ribbon-split-button:hover .as-ribbon-split-button-content > button {\r\n border-color: rgba(169, 168, 169, 0.15);\r\n}\r\n\r\n.as-ribbon-split-button-icon {\r\n margin-right: 0.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\nspan.as-ribbon-split-button-icon {\r\n font-size: 1.2em;\r\n}\r\n\r\nimg.as-ribbon-split-button-icon,\r\nsvg.as-ribbon-split-button-icon {\r\n width: 1.2em;\r\n height: 1.2em;\r\n}\r\n\r\n.as-ribbon-split-button-text {\r\n vertical-align: middle;\r\n font-size: inherit;\r\n}\r\n\r\n.as-ribbon-split-button-text::before {\r\n content: attr(data-text);\r\n}\r\n\r\n.as-ribbon-split-button-extend .as-ribbon-split-button-text {\r\n display: none;\r\n}\r\n\r\n.as-ribbon-split-button.as-no-dropdown .as-ribbon-dropdown-icon{\r\n display: none;\r\n}\r\n\r\n.as-ribbon-split-button.as-no-dropdown .as-ribbon-split-button-primary {\r\n padding-right: 5px;\r\n border-width: 1px 1px 1px 1px;\r\n}\r\n\r\n.as-ribbon-split-button.as-big {\r\n width: 5em;\r\n height: auto;\r\n}\r\n\r\n.as-ribbon-split-button.as-big .as-ribbon-split-button-content {\r\n height: auto;\r\n}\r\n\r\n.as-ribbon-split-button.as-big span.as-ribbon-split-button-icon {\r\n font-size: 2em;\r\n display: block;\r\n margin: 0;\r\n}\r\n\r\n.as-ribbon-split-button.as-big .as-ribbon-split-button-extend .as-ribbon-split-button-text {\r\n display: inline-block;\r\n white-space: normal;\r\n max-width: calc(100% - 1em);\r\n}\r\n\r\n.as-ribbon-split-button.as-big .as-ribbon-split-button-primary .as-ribbon-split-button-text {\r\n display: none;\r\n}\r\n\r\n.as-ribbon-split-button.as-big .as-ribbon-split-button-extend {\r\n white-space: nowrap;\r\n width: 100%;\r\n height: auto;\r\n border-width: 0 1px 1px 1px;\r\n\r\n}\r\n\r\n.as-ribbon-split-button.as-big .as-ribbon-split-button-primary {\r\n width: 100%;\r\n height: 2.5em;\r\n box-sizing: border-box;\r\n border-width: 1px 1px 0 1px;\r\n}\r\n\r\n.as-ribbon-split-button.as-big img.as-ribbon-split-button-icon,\r\n.as-ribbon-split-button.as-big svg.as-ribbon-split-button-icon {\r\n width: 2em;\r\n height: 2em;\r\n}", ""]); /***/ }), /***/ 1690: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-rotated-text {\r\n\r\n}\r\n\r\n.as-rotated-text::after {\r\n content: \"o\";\r\n color: transparent;\r\n display: inline;\r\n}\r\n\r\n.as-rotated-text-content {\r\n transform: rotate(0deg);\r\n transform-origin: 0.3em 50%;\r\n display: block;\r\n zoom: 1.001;\r\n}\r\n\r\n\r\n.as-rotated-text-anchor{\r\n position: fixed;\r\n z-index: 1000;\r\n}\r\n\r\n.as-rotated-text,.as-rotated-text-anchor, .as-rotated-text-content{\r\n font: inherit;\r\n}", ""]); /***/ }), /***/ 5770: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-vscroller {\r\n position: relative;\r\n overflow-x: hidden;\r\n}\r\n\r\n\r\n.absol-vscroller.disabled > .absol-vscroller-viewport {\r\n overflow-y: visible;\r\n margin-right: 0px;\r\n min-width: 100%;\r\n}\r\n\r\n.absol-vscroller.disabled {\r\n overflow: visible;\r\n overflow-x: visible;\r\n\r\n}\r\n\r\n\r\n.absol-vscroller-viewport {\r\n overflow-y: scroll;\r\n box-sizing: content-box;\r\n\r\n}\r\n\r\n.absol-vscroller > .absol-vscroller-viewport {\r\n max-height: 100%;\r\n}\r\n\r\n.absol-vscroller.limited-height > .absol-vscroller-viewport {\r\n max-height: inherit;\r\n}\r\n\r\n\r\n/************ hscroller ***********/\r\n.absol-hscroller {\r\n position: relative;\r\n overflow-y: hidden;\r\n}\r\n\r\n.absol-hscroller.disabled {\r\n overflow: visible;\r\n overflow-y: visible;\r\n}\r\n\r\n.absol-hscroller-viewport {\r\n overflow-x: scroll;\r\n box-sizing: content-box;\r\n min-height: calc(100% + 17px);\r\n}\r\n\r\n.absol-hscroller.disabled > .absol-hscroller-viewport {\r\n overflow-x: visible;\r\n margin-bottom: 0px;\r\n}\r\n\r\n\r\n.absol-hscroller > .absol-hscroller-viewport {\r\n max-width: 100%;\r\n}\r\n\r\n\r\n/********** scroll bar *********************/\r\n.absol-scrollbar-force-modal {\r\n position: fixed;\r\n top: 5px;\r\n left: 5px;\r\n right: 5px;\r\n bottom: 5px;\r\n z-index: 1000000;\r\n}\r\n\r\n.absol-scrollbar-container {\r\n position: absolute;\r\n right: 0;\r\n bottom: 0;\r\n z-index: 10;\r\n}\r\n\r\n.absol-scrollbar-container.vertical {\r\n top: 0;\r\n width: 7px;\r\n}\r\n\r\n.absol-scrollbar-container.horizontal {\r\n height: 7px;\r\n left: 0;\r\n}\r\n\r\n.absol-scrollbar-container > .absol-scrollbar {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n\r\n.absol-scrollbar-container.vertical > .absol-scrollbar > .absol-scrollbar-button {\r\n left: 1px;\r\n right: 1px;\r\n top: 0;\r\n}\r\n\r\n.absol-scrollbar-container.horizontal > .absol-scrollbar > .absol-scrollbar-button {\r\n top: 1px;\r\n bottom: 1px;\r\n left: 0;\r\n}\r\n\r\n.absol-scrollbar {\r\n position: relative;\r\n background-color: rgba(180, 180, 182, 0.1);\r\n overflow: hidden;\r\n}\r\n\r\n.absol-scrollbar-button {\r\n position: absolute;\r\n background-color: rgba(133, 133, 133, 0.5);\r\n border-radius: 2px;\r\n}\r\n\r\n.absol-scrollbar-button:hover, .absol-scrollbar-button:active {\r\n background-color: rgba(133, 133, 133, 1);;\r\n}\r\n\r\n\r\n.absol-scrollbar.absol-hidden {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-vscrollbar .absol-scrollbar-button {\r\n width: 100%;\r\n}\r\n\r\n\r\n.absol-hscrollbar .absol-scrollbar-button {\r\n height: 100%;\r\n}\r\n\r\n.absol-table-scroller-vscrollbar-container .absol-vscrollbar:not(.as-overflow) {\r\n visibility: hidden;\r\n pointer-events: none;\r\n}\r\n\r\n.absol-table-scroller-left-vscroller-viewport:empty {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 846: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-search-text-input {\r\n position: relative;\r\n height: 2em;\r\n border-radius: 0.3em;\r\n border: solid 1px #a9a9a9;\r\n font-size: 1rem;\r\n background-color: white;\r\n}\r\n\r\n.absol-search-text-input.focus {\r\n outline: solid 1px rgba(30, 30, 255, 0.4);\r\n}\r\n\r\n.absol-search-text-input-container {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n bottom: 0;\r\n right: 2em;\r\n}\r\n\r\n.absol-search-text-button-container {\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n width: 2em;\r\n bottom: 0em;\r\n}\r\n\r\n.absol-search-text-button-container button {\r\n width: 100%;\r\n height: 100%;\r\n outline: none;\r\n border: none;\r\n background: transparent;\r\n padding: 0;\r\n font-size: 1em;\r\n}\r\n\r\n.absol-search-text-button-container button > svg {\r\n height: calc(16em / 14);\r\n width: calc(16em / 14);\r\n fill: rgb(132, 132, 132);\r\n}\r\n\r\n.absol-search-text-input-container input {\r\n width: 100%;\r\n height: 100%;\r\n font-size: 1em;\r\n box-sizing: border-box;\r\n outline: none;\r\n border: none;\r\n background-color: transparent;\r\n padding-left: 0.6em;\r\n}\r\n\r\n.absol-search-text-input:not(.searching) svg.times {\r\n display: none;\r\n}\r\n\r\n.absol-search-text-input.searching svg.find {\r\n display: none;\r\n}\r\n\r\n.absol-search-text-input .as-spinner-ico{\r\n width: 2em;\r\n height: 2em;\r\n}\r\n\r\n.absol-search-text-input:not(.as-waiting) svg.as-spinner-ico,\r\n.absol-search-text-input.as-waiting svg:not(.as-spinner-ico) {\r\n display: none;\r\n}\r\n\r\n.absol-search-text-input-container input::-webkit-search-cancel-button {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 7145: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --select-box-item-height: calc(20rem / 14);\r\n --select-box-item-font-size: 1rem;\r\n --select-box-item-border-radius: 9px;\r\n --select-box-item-close-opacity: 0;\r\n --select-box-min-height: calc(2rem + 2px);\r\n --select-box-focus-item-color: rgb(208, 145, 239);\r\n}\r\n\r\n.absol-selectbox {\r\n --list-min-width: 3em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n min-height: var(--select-box-min-height);\r\n min-width: var(--list-min-width);\r\n border: solid 1px #d6d6d6;\r\n border-radius: calc(3rem / 14);\r\n box-sizing: border-box;\r\n padding-right: var(--select-box-item-height);\r\n overflow-y: auto;\r\n outline: none;\r\n background-color: white;\r\n}\r\n\r\n.absol-selectbox:not(.as-disable-click-to-focus) {\r\n cursor: copy;\r\n}\r\n\r\n.absol-selectbox.as-disabled {\r\n pointer-events: none;\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.absol-selectbox.as-disabled .absol-selectbox-item {\r\n opacity: 0.7;\r\n}\r\n\r\n.absol-selectbox {\r\n white-space: normal;\r\n}\r\n\r\n.absol-selectbox .absol-selectbox-item {\r\n margin: calc((var(--select-box-min-height) - 2px - var(--select-box-item-height)) / 2) 2px;\r\n}\r\n\r\n.absol-selectbox-item {\r\n font-family: Arial, Helvetica, sans-serif;\r\n display: inline-block;\r\n position: relative;\r\n font-size: var(--select-box-item-font-size);\r\n height: var(--select-box-item-height);\r\n box-sizing: border-box;\r\n border-radius: var(--select-box-item-border-radius);\r\n overflow: hidden;\r\n background-color: rgb(113, 148, 169);\r\n border-color: rgb(121, 165, 192);\r\n vertical-align: top;\r\n white-space: normal;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n color: white;\r\n cursor: pointer;\r\n}\r\n\r\n\r\n.absol-selectbox-item.as-theme-confirmed {\r\n background-color: rgb(145, 228, 251);\r\n}\r\n\r\n.absol-selectbox-item.as-theme-declined {\r\n background-color: rgb(255, 138, 138)\r\n}\r\n\r\n.absol-selectbox-item.as-theme-waiting {\r\n background-color: rgb(255, 227, 174);\r\n color: black;\r\n}\r\n\r\n.absol-selectbox-item-text {\r\n height: var(--select-box-item-height);\r\n padding-right: calc(var(--select-box-item-height) + 5px);\r\n padding-left: 5px;\r\n font-size: inherit;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-selectbox-item-text:hover {\r\n background-color: rgba(0, 0, 0, 0.0893617021);\r\n}\r\n\r\n.absol-selectbox-item-text span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-selectbox-item-close {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n width: var(--select-box-item-height);\r\n text-align: center;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n cursor: pointer;\r\n background-color: rgba(0, 0, 0, var(--select-box-item-close-opacity));\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-selectbox-item-close:hover {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n.absol-selectbox-item-close::after,\r\n.absol-selectbox-item-text::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.absol-selectbox-item-close span {\r\n font-size: 1.25em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.absol-selectbox.as-item-focusable .absol-selectbox-item.as-active {\r\n background-color: var(--select-box-focus-item-color);\r\n}", ""]); /***/ }), /***/ 7607: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-selectlist {\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.absol-selectlist * {\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-selectlist .absol-selectlist-item:hover {\r\n background-color: #efefef;\r\n}\r\n\r\n.absol-selectlist .absol-selectlist-item {\r\n height: calc(20rem / 14);\r\n font-size: 1rem;\r\n cursor: pointer;\r\n}\r\n\r\n.absol-selectlist-item.as-selected {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n\r\n.absol-selectlist-item.as-disabled,\r\n.absol-selectlist-item.as-disabled * {\r\n color: var(--as-disabled-text-color);\r\n pointer-events: none;\r\n}\r\n\r\n.absol-selectlist:not(.as-searching) > .absol-selectlist-item.as-last-in-group,\r\n.as-select-list-box:not(.as-searching) .as-last-in-group {\r\n position: relative;\r\n overflow: visible;\r\n}\r\n\r\n\r\n.as-select-list-box:not(.as-searching) .as-last-in-group::after,\r\n.absol-selectlist:not(.as-searching) > .absol-selectlist-item.as-last-in-group:not(:last-child)::after {\r\n content: \"\";\r\n border-bottom: 1px solid #aaaaaa;\r\n position: absolute;\r\n left: 0.2em;\r\n right: 0.2em;\r\n bottom: -0.5px;\r\n z-index: 20;\r\n}\r\n\r\n.absol-selectlist-item-text {\r\n line-height: inherit;\r\n white-space: pre;\r\n padding-left: var(--as-input-horizontal-padding);\r\n padding-right: var(--as-input-horizontal-padding);\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n}\r\n\r\n.absol-selectlist-item {\r\n height: 20px;\r\n line-height: 20px;\r\n --level: 0;\r\n padding-left: calc(0.9em * var(--level));\r\n}\r\n\r\n\r\n.absol-selectlist-item {\r\n position: relative;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-selectlist-item-desc-container {\r\n position: absolute;\r\n right: 0.3em;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.absol-selectlist-item-desc {\r\n font-style: italic;\r\n line-height: 20px;\r\n white-space: nowrap;\r\n color: rgb(37, 37, 37);\r\n}\r\n\r\n.absol-selectlist-item-desc:empty {\r\n display: none;\r\n}\r\n\r\n.absol-selectlist-item {\r\n padding-right: calc(0.35em + var(--select-list-desc-width));\r\n}\r\n\r\n.absol-selectlist-item-desc-container {\r\n width: var(--select-list-desc-width);\r\n}\r\n\r\n\r\n.as-select-list-icon {\r\n font-size: 1.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n padding-left: var(--as-input-horizontal-padding);\r\n}\r\n\r\n\r\n\r\n/**************** MOBILE ******************************/\r\n\r\n:root {\r\n --modal-margin-top: 80px;\r\n --modal-margin-bottom: 80px;\r\n --modal-max-width: 500px;\r\n --modal-width: calc(100vw - 80px);\r\n /*--modal-border-radius: 8px;*/\r\n --modal-border-radius: 0px;\r\n}\r\n\r\n.am-list-modal,\r\n.am-list-modal-v2 {\r\n z-index: 100005;\r\n position: fixed;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n text-align: center;\r\n box-sizing: border-box;\r\n padding-top: var(--modal-margin-top);\r\n background-color: rgba(0, 0, 0, 0.1);\r\n}\r\n\r\n.am-list-modal > div,\r\n.am-list-modal-v2 > div {\r\n display: inline-block;\r\n text-align: initial;\r\n}\r\n\r\n\r\n.am-list-popup-box {\r\n box-shadow: 2px 2px 2px 0px #908787;\r\n -webkit-box-shadow: 2px 2px 2px 0px #908787;\r\n background-color: #ffffff;\r\n border-radius: var(--modal-border-radius);\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.am-list-popup-box.am-enable-search .absol-search-text-input,\r\n.am-list-modal-v2.as-enable-search .absol-search-text-input {\r\n visibility: visible;\r\n}\r\n\r\n\r\n.am-list-popup-header {\r\n height: calc(2em + 10px);\r\n display: block;\r\n white-space: nowrap;\r\n box-sizing: border-box;\r\n padding-top: 5px;\r\n padding-bottom: 5px;\r\n padding-left: 10px;\r\n border-bottom: solid 1px #dddddd;\r\n /*background-color: rgba(169, 169, 169, 0.2);*/\r\n}\r\n\r\n.am-list-popup-header .absol-search-text-input {\r\n display: inline-block;\r\n width: calc(100% - 2em - 18px);\r\n vertical-align: middle;\r\n box-sizing: border-box;\r\n background-color: white;\r\n}\r\n\r\n.am-list-popup-close-btn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n border-radius: 50%;\r\n padding: 0;\r\n height: 2em;\r\n width: 2em;\r\n font-size: inherit;\r\n border: none;\r\n outline: none;\r\n margin-left: 10px;\r\n background-color: rgb(255, 255, 255);\r\n color: #7a7a7a;\r\n white-space: nowrap;\r\n}\r\n\r\n.am-list-popup-close-btn:active {\r\n color: red;\r\n}\r\n\r\n\r\n.am-list-popup-close-btn:before {\r\n content: \"\";\r\n display: inline-block;\r\n height: 2em;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-list-popup-close-btn span {\r\n font-size: 24px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1;\r\n}\r\n\r\n.am-list-popup-box .absol-search-text-input {\r\n visibility: hidden;\r\n}\r\n\r\n.am-list-popup-paging {\r\n display: block;\r\n height: 2em;\r\n text-align: center;\r\n box-sizing: border-box;\r\n border-bottom: 1px solid #dddddd;\r\n}\r\n\r\n.am-list-popup-paging::before {\r\n content: \"\";\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-list-popup-paging-content {\r\n padding-left: 0.5em;\r\n padding-right: 0.5em;\r\n}\r\n\r\n.am-list-popup-paging > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-list-popup-paging > button {\r\n padding: 0;\r\n margin-left: 0.25em;\r\n margin-right: 0.25em;\r\n width: 1.75em;\r\n height: 1.75em;\r\n display: inline-block;\r\n background-color: transparent;\r\n border: none;\r\n box-sizing: border-box;\r\n outline: none;\r\n}\r\n\r\n.am-list-popup-paging > button:active {\r\n background-color: rgba(169, 169, 169, 0.3);\r\n}\r\n\r\n\r\ninput[type=\"number\"].am-list-popup-paging-offset {\r\n width: 4em;\r\n outline: none;\r\n margin-right: 0.2em;\r\n /*border: solid 1px #a9a9a9;*/\r\n /*border-radius: 0.3em;*/\r\n border: none;\r\n text-align: right;\r\n font-size: inherit;\r\n height: 1.25em;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.am-list-popup-list-scroller {\r\n width: 100%;\r\n overflow: auto;\r\n --content-height: calc(100vh - 200px);\r\n -ms-overflow-style: none; /* IE and Edge */\r\n scrollbar-width: none; /* Firefox */\r\n}\r\n\r\n\r\n.am-list-popup-list-scroller::-webkit-scrollbar {\r\n display: none;\r\n}\r\n\r\n.am-list-popup-content {\r\n display: block;\r\n position: relative;\r\n}\r\n\r\n.am-list-popup-list-page {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: -200vh;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.am-list-modal .am-selectlist {\r\n width: 100%;\r\n}\r\n\r\n.am-list-popup-list-page.am-selectlist {\r\n --desc-width: inherit;\r\n}\r\n\r\n.am-value-hidden .am-selectlist-item.as-selected {\r\n display: none;\r\n}\r\n\r\n.am-selectlist {\r\n display: table;\r\n border-collapse: collapse;\r\n border-spacing: 0;\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item {\r\n display: table-row;\r\n\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item:active {\r\n background-color: rgba(169, 169, 169, 0.4);\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item.as-selected {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n\r\n.am-selectlist > .am-selectlist-item {\r\n border-bottom: 0.5px solid #dddddd;\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item > .am-selectlist-item-check-ctn {\r\n display: table-cell;\r\n vertical-align: middle;\r\n padding-left: 0.35em;\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item > .am-selectlist-item-text-ctn,\r\n.am-selectlist > .am-selectlist-item > .am-selectlist-item-desc-ctn {\r\n display: table-cell;\r\n padding-top: 0.5em;\r\n padding-bottom: 0.5em;\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item > .am-selectlist-item-text-ctn {\r\n padding-right: 5px;\r\n padding-left: calc(10px + 0.9em * var(--level));\r\n}\r\n\r\n.am-selectlist > .am-selectlist-item > .am-selectlist-item-desc-ctn {\r\n padding-left: 5px;\r\n padding-right: 10px;\r\n}\r\n\r\n\r\n.am-selectlist {\r\n --desc-width: auto;\r\n}\r\n\r\n.am-selectlist .am-selectlist-item-desc-ctn {\r\n width: var(--desc-width);\r\n}\r\n\r\n.am-check-list-page {\r\n overflow: hidden;\r\n}\r\n\r\n/******************************************************/\r\n.am-selectlist-item {\r\n --level: 0;\r\n}\r\n\r\n.am-selectlist-item-text-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-selectlist-item-desc-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.am-selectlist-item-desc {\r\n font-style: italic;\r\n line-height: 20px;\r\n color: rgb(80, 80, 82);\r\n white-space: pre;\r\n}\r\n\r\n\r\n.am-selectlist-item-icon {\r\n font-size: 1.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-check-list-scroller {\r\n max-height: calc(100vh - var(--modal-margin-top) - 200px);\r\n overflow-y: auto;\r\n overflow-x: hidden;\r\n}\r\n\r\n.am-check-list-modal {\r\n --col1-width: 100px;\r\n --col2-width: 100px;\r\n}\r\n\r\n.am-check-list-modal .am-list-popup-content {\r\n width: calc(var(--col1-width) + var(--col2-width));\r\n min-width: 300px;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item {\r\n position: relative;\r\n min-height: 30px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-desc-ctn {\r\n position: absolute;\r\n width: var(--col2-width);\r\n right: 0;\r\n height: 100%;\r\n white-space: nowrap;\r\n\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-text,\r\n.am-check-list-modal .am-selectlist-item-desc {\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n line-height: 20px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: pre;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-text-ctn {\r\n position: absolute;\r\n right: var(--col2-width);\r\n left: calc(var(--level) * 12px + 30px);\r\n height: 100%;\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.am-check-list-modal .am-selectlist-item-check-ctn {\r\n position: absolute;\r\n top: 0;\r\n left: calc(var(--level) * 12px + 5px);\r\n height: 100%;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-check-ctn::before,\r\n.am-check-list-modal .am-selectlist-item-check-ctn > *,\r\n.am-check-list-modal .am-selectlist-item-text-ctn::before,\r\n.am-check-list-modal .am-selectlist-item-desc-ctn::before,\r\n.am-check-list-modal .am-selectlist-item-text-ctn > span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-check-ctn::before,\r\n.am-check-list-modal .am-selectlist-item-text-ctn::before,\r\n.am-check-list-modal .am-selectlist-item-desc-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n\r\n.am-check-list-modal .am-selectlist-item-text-ctn {\r\n white-space: nowrap;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item-text {\r\n max-height: 100%;\r\n line-height: 20px;\r\n white-space: pre;\r\n width: calc(var(--col1-width) - 12px * var(--level) - 30px - 21px - 10px);\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.am-list-modal-v2 {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n height: 100%;\r\n width: 100%;\r\n box-sizing: border-box;\r\n font-size: 14px;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.am-list-modal-v2 .am-list-popup-list-scroller {\r\n max-height: calc(100vh - var(--modal-margin-top) - 200px);\r\n}\r\n\r\n.am-list-modal-v2 .am-list-popup-content {\r\n width: calc(var(--col1-width) + var(--col2-width));\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item-text-ctn {\r\n padding-left: 10px;\r\n white-space: nowrap;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item-text-ctn::before,\r\n.am-list-modal-v2 .am-selectlist-item-desc-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item-text-ctn::before,\r\n.am-list-modal-v2 .am-selectlist-item-desc-ctn::before,\r\n.am-list-modal-v2 .am-selectlist-item-text,\r\n.am-list-modal-v2 .am-selectlist-item-desc {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-selectlist-item-text {\r\n white-space: pre;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item {\r\n position: relative;\r\n height: 30px;\r\n line-height: 20px;\r\n}\r\n\r\n\r\n.am-list-modal-v2 .am-selectlist-item::after {\r\n content: \"\";\r\n display: block;\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n border-bottom: 1px solid #eee;\r\n}\r\n\r\n.am-check-list-modal .am-selectlist-item.as-last-in-group::after{\r\n content: \"\";\r\n display: block;\r\n position: absolute;\r\n bottom: 0;\r\n left: 0;\r\n right: 0;\r\n border-bottom: 1px solid #aaa;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item.as-selected {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item-text-ctn,\r\n.am-list-modal-v2 .am-selectlist-item-desc-ctn {\r\n box-sizing: border-box;\r\n overflow: hidden;\r\n height: 100%;\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item {\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.am-list-modal-v2 .am-selectlist-item-text-ctn {\r\n width: var(--col1-width);\r\n}\r\n\r\n.am-list-modal-v2 .am-selectlist-item-desc-ctn {\r\n width: var(--col2-width);\r\n}\r\n\r\n.am-list-modal-v2 .am-list-popup-header {\r\n height: auto;\r\n min-height: calc(2em + 10px);\r\n}\r\n\r\n.am-selectlist-item.as-disabled .as-checkbox-input{\r\n visibility: hidden;\r\n}", ""]); /***/ }), /***/ 9219: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-select-list-box {\r\n --select-list-estimate-width: 0;\r\n --max-height: calc(100vh - 80px);\r\n --as-width-limit: 100vw;\r\n position: fixed;\r\n top: 10px;\r\n left: 10px;\r\n width: calc(var(--select-list-estimate-width) + 2px + 5px + 7px);\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n border: solid 1px rgb(100, 100, 255);\r\n box-sizing: border-box;\r\n background-color: white;\r\n display: inline-block;\r\n vertical-align: top;\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n outline: none;\r\n}\r\n\r\n.as-select-list-box.as-has-icon .absol-selectlist-item {\r\n height: calc(30rem / 14);\r\n line-height: calc(30rem / 14);\r\n}\r\n\r\n.as-select-list-box.as-enable-search {\r\n min-width: 10em;\r\n}\r\n\r\n.as-select-list-box.as-text-align-center .absol-selectlist-item {\r\n text-align: center;\r\n}\r\n\r\n.as-select-list-box.as-text-align-center .absol-selectlist-item-text {\r\n padding-right: calc(0.35em + 28px);\r\n}\r\n\r\n.as-select-menu.as-text-align-center {\r\n text-align: center;\r\n}\r\n\r\n.as-select-menu.as-text-align-center .absol-selectlist-item,\r\n.as-select-list-box.as-text-align-center .absol-selectlist-item {\r\n padding-left: 0.35em;\r\n padding-right: calc(0.35em + 28px);\r\n}\r\n\r\n.as-select-menu.as-text-align-center .absol-selectlist-item-text,\r\n.as-select-list-box.as-text-align-center .absol-selectlist-item-text {\r\n padding: 0;\r\n}\r\n\r\n\r\ndiv.absol-follower.as-select-list-box {\r\n z-index: 4000000;\r\n}\r\n\r\n.as-select-list-box .as-select-list-box {\r\n min-width: 100%;\r\n}\r\n\r\n.as-select-list-box-search-ctn {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n}\r\n\r\n.as-select-list-box.as-enable-search.as-anchor-6 .as-select-list-box-search-ctn,\r\n.as-select-list-box.as-enable-search.as-anchor-5 .as-select-list-box-search-ctn {\r\n bottom: 0;\r\n top: unset;\r\n}\r\n\r\n.as-select-list-box.as-enable-search.as-anchor-6,\r\n.as-select-list-box.as-enable-search.as-anchor-5 {\r\n padding-bottom: calc(2em + 10px);\r\n padding-top: 0;\r\n}\r\n\r\n.as-select-list-box.as-enable-search,\r\n.as-select-list-box.as-enable-search.as-anchor-1,\r\n.as-select-list-box.as-enable-search.as-anchor-2 {\r\n padding-top: calc(2em + 10px);\r\n}\r\n\r\n.as-select-list-box.as-enable-search .as-select-list-box-search-ctn,\r\n.as-select-list-box.as-enable-search.as-anchor-1 .as-select-list-box-search-ctn,\r\n.as-select-list-box.as-enable-search.as-anchor-2 .as-select-list-box-search-ctn {\r\n top: 0;\r\n bottom: unset;\r\n}\r\n\r\n.as-select-list-box-scroller {\r\n overflow-y: auto;\r\n overflow-x: visible;\r\n}\r\n\r\n.as-select-list-box .as-select-list-box-scroller {\r\n max-height: var(--max-height);\r\n}\r\n\r\n.as-select-list-box.as-enable-search .as-select-list-box-scroller {\r\n max-height: calc(var(--max-height) - 2em - 10px);\r\n}\r\n\r\n.as-select-list-box-content {\r\n position: relative;\r\n}\r\n\r\n.as-select-list-box-page {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n overflow: hidden;\r\n}\r\n\r\n.as-select-list-box .absol-selectlist-item {\r\n cursor: default;\r\n}\r\n\r\n.as-select-list-box .absol-selectlist-item-text {\r\n max-width: calc(var(--as-width-limit) - var(--select-list-desc-width) - 10px);\r\n display: inline-block;\r\n vertical-align: middle;\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n}\r\n\r\n.as-select-list-box-search-ctn {\r\n display: none;\r\n padding: 5px;\r\n}\r\n\r\n\r\n.as-select-list-box.as-enable-search .as-select-list-box-search-ctn {\r\n display: block;\r\n}\r\n\r\n\r\n.as-select-list-box .as-last-in-group span {\r\n line-height: 19px;\r\n}\r\n\r\n\r\n.as-select-list-box .absol-selectlist-item:hover {\r\n background-color: #efefef;\r\n}\r\n\r\n.as-select-list-box.as-value-hidden .absol-selectlist-item.as-selected {\r\n color: #aaaaaa;\r\n}\r\n\r\n.as-select-list-box.as-value-hidden .absol-selectlist-item.as-selected.as-is-leaft {\r\n display: none;\r\n}\r\n\r\n\r\n/**********************************************************************************************************************/\r\n", ""]); /***/ }), /***/ 5741: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-selectmenu-anchor-container {\r\n /* position: fixed; */\r\n\r\n /* top: 0; */\r\n /* left: 0; */\r\n width: 0;\r\n height: 0;\r\n overflow: visible;\r\n}\r\n\r\n.absol-selectmenu-anchor {\r\n position: relative;\r\n}\r\n\r\n.absol-selectmenu-anchor-content-container {\r\n position: absolute;\r\n z-index: 1002;\r\n top: 0;\r\n left: 0;\r\n}\r\n\r\n.absol-selectmenu-anchor-content-container .absol-bscroller {\r\n max-height: calc(100vh - 50px);\r\n}\r\n\r\n\r\n.absol-selectmenu-anchor.absol-disabled .absol-selectmenu-anchor-content-container {\r\n visibility: hidden;\r\n top: -100000px;\r\n left: -10000px;\r\n z-index: -1000;\r\n opacity: 0;\r\n}\r\n\r\n\r\n.absol-selectmenu-dropdown-box {\r\n border: solid 1px rgb(100, 100, 255);\r\n box-sizing: border-box;\r\n background-color: white;\r\n display: inline-block;\r\n vertical-align: top;\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n}\r\n\r\n.absol-selectmenu-dropdown-box > .as-bscroller {\r\n overflow-y: auto;\r\n}\r\n\r\n.absol-selectmenu-dropdown-box .absol-search-text-input {\r\n margin: 0.2em;\r\n}\r\n\r\n\r\n.absol-selectmenu.absol-hidden {\r\n display: none !important;\r\n}\r\n\r\n.absol-selectmenu-render-space {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n z-index: -1000;\r\n visibility: hidden;\r\n font-size: 14px;\r\n}\r\n\r\n.absol-selectmenu-render-space > div {\r\n display: inline-block;\r\n}\r\n\r\n\r\n.absol-selectmenu.as-disabled,\r\n.as-select-menu.as-disabled {\r\n pointer-events: none;\r\n background-color: var(--as-disabled-background-color);\r\n color: var(--as-disabled-text-color);\r\n}\r\n\r\n.absol-selectmenu {\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n height: calc(2em + 2px);\r\n min-width: calc(2em + 2px);\r\n border: solid 1px #d6d6d6;\r\n border-radius: 2px;\r\n box-sizing: border-box;\r\n font-size: 1rem;\r\n outline: none;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n background-color: white;\r\n}\r\n\r\n.absol-selectmenu.as-border-none {\r\n border: none;\r\n}\r\n\r\n.absol-selectmenu.as-border-none .absol-selectlist-item span {\r\n padding-left: 0;\r\n user-select: inherit;\r\n -ms-user-select: inherit;\r\n -webkit-user-select: inherit;\r\n}\r\n\r\n.absol-selectmenu:not(.as-read-only) {\r\n cursor: pointer;\r\n}\r\n\r\n.absol-selectmenu.as-read-only .absol-selectlist-item span {\r\n user-select: inherit;\r\n -moz-user-select: inherit;\r\n -webkit-user-select: inherit;\r\n -ms-user-select: inherit;\r\n}\r\n\r\n\r\n.absol-selectmenu-btn {\r\n position: absolute;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n width: 30px;\r\n border: none;\r\n background: transparent;\r\n z-index: 2;\r\n pointer-events: none;\r\n}\r\n\r\n.absol-selectmenu-btn:focus {\r\n outline: none;\r\n}\r\n\r\n.absol-selectmenu-btn svg.dropdown {\r\n width: 10px;\r\n height: 10px;\r\n fill: #929292;\r\n}\r\n\r\n.absol-selectmenu.as-read-only svg.dropdown {\r\n display: none;\r\n}\r\n\r\n.absol-selectmenu:not(.as-read-only):hover svg.dropdown {\r\n width: 10px;\r\n height: 10px;\r\n fill: black;\r\n}\r\n\r\n.absol-selectmenu .absol-selectlist-item-text {\r\n display: inline-block;\r\n overflow: hidden;\r\n max-width: calc(var(--as-width-limit) - 30px);\r\n text-overflow: ellipsis;\r\n vertical-align: middle;\r\n\r\n}\r\n\r\n\r\n.absol-selectmenu-holder-item {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n /*1px for border*/\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-selectmenu-holder-item::before {\r\n content: \"\";\r\n height: 100%;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.absol-selectmenu-holder-item > .absol-selectlist-item {\r\n display: inline-block;\r\n width: 100%;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-selectmenu .absol-selectlist-item-text {\r\n padding-right: 28px;\r\n}\r\n\r\n.absol-selectmenu .absol-scroll-button {\r\n background-color: rgba(0, 0, 0, 0.1);\r\n border-radius: 3px;\r\n}\r\n\r\n.absol-selectmenu .absol-scroll-button:hover {\r\n background-color: rgba(0, 0, 0, 0.2);\r\n}\r\n\r\n.absol-scroll-bar-v-container {\r\n width: 10px;\r\n}\r\n\r\n.absol-selectmenu .absol-search-text-input {\r\n margin: 4px;\r\n}\r\n\r\n.absol-selectmenu-render-space .absol-selectlist-item span {\r\n padding-right: 0;\r\n}\r\n\r\n\r\n.absol-selectmenu .absol-selectlist-item-desc-container {\r\n right: 30px;\r\n}\r\n\r\n\r\n.absol-selectmenu-dropdown-box .absol-bscroller {\r\n overflow-y: auto;\r\n}\r\n\r\n\r\n.as-select-anchor {\r\n position: fixed;\r\n z-index: 1000001;\r\n}\r\n\r\n\r\n.as-select-anchor.as-hidden {\r\n left: 0;\r\n top: 0;\r\n z-index: -1000;\r\n visibility: hidden;\r\n opacity: 0;\r\n}\r\n\r\n\r\n.as-select-menu {\r\n --select-list-estimate-width: 0px;\r\n --select-list-desc-width: 0px;\r\n width: calc(var(--select-list-estimate-width) + 32px);\r\n min-width: calc(var(--select-list-estimate-width) + 32px);\r\n}\r\n\r\n/***********************************************************************************************************************/\r\n\r\n.am-selectmenu-modal {\r\n z-index: 100005;\r\n position: fixed;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n text-align: center;\r\n box-sizing: border-box;\r\n}\r\n\r\n.am-selectmenu-modal>div{\r\n display: inline-block;\r\n text-align: initial;\r\n}\r\n\r\n.am-selectmenu-popup-box {\r\n max-width: calc(100vw - 60px);\r\n -webkit-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n -moz-box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n box-shadow: 2px 2px 6px 0px rgba(0, 0, 90, 0.55);\r\n background-color: #ffffff;\r\n border-radius: 0.5em;\r\n font-family: Arial, Helvetica, sans-serif;\r\n}\r\n\r\n.am-selectmenu-popup-box-header{\r\n height: calc(2em + 10px);\r\n display: block;\r\n white-space: nowrap;\r\n box-sizing: border-box;\r\n padding-top: 5px;\r\n padding-bottom: 5px;\r\n padding-left: 10px;\r\n border-bottom: solid 1px #dddddd;\r\n background-color: rgba(169, 169, 169,0.2);\r\n}\r\n\r\n.am-selectmenu-popup-box-header .absol-search-text-input{\r\n display: inline-block;\r\n width: calc(100% - 2em - 25px);\r\n vertical-align: middle;\r\n box-sizing: border-box;\r\n background-color: white;\r\n}\r\n\r\n.am-selectmenu-popup-box-close-btn{\r\n display: inline-block;\r\n vertical-align: middle;\r\n border-radius:50%;\r\n padding: 0;\r\n height: 2em;\r\n width: 2em;\r\n font-size: inherit;\r\n border: none;\r\n outline: none;\r\n margin-right: 10px;\r\n background-color: rgb(255, 255, 255);\r\n color: rgb(190, 30, 30);\r\n}\r\n\r\n.am-selectmenu-popup-box-close-btn:active{\r\n color: red;\r\n}\r\n\r\n\r\n.am-selectmenu-popup-box-close-btn:before{\r\n content: \"\";\r\n display: inline-block;\r\n height: 2em;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-selectmenu-popup-box-close-btn span{\r\n font-size: 1.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1;\r\n}\r\n\r\n.am-selectmenu-scroller {\r\n max-height: calc(100vh - 140px);\r\n overflow-y: auto;\r\n box-sizing: border-box;\r\n}\r\n\r\n.am-selectlist.am-selectmeu-list{\r\n min-width: 30vw;\r\n}\r\n\r\n.am-selectlist.am-selectmeu-list.as-searching{\r\n width: 100%;\r\n}\r\n\r\n.am-selectmenu-popup-box .absol-search-text-input{\r\n display: none;\r\n}\r\n\r\n\r\n.am-selectmenu-popup-box.am-enable-search .absol-search-text-input{\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.am-selectmenu{\r\n white-space: nowrap;\r\n background: white;\r\n overflow: hidden;\r\n box-sizing: border-box;\r\n padding-right: 35px;\r\n max-width: 95vw;\r\n width: var(--recommend-width);\r\n}\r\n\r\n.am-selectmenu.disabled .absol-selectmenu-btn{\r\n background-color: #ebebe4;\r\n}\r\n\r\n.am-selectmenu .absol-selectmenu-btn{\r\n background: white;\r\n}\r\n\r\n.am-selectmenu::before{\r\n content: \"\";\r\n height: 100%;\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.am-selectmenu-holder-item{\r\n display: inline-table;\r\n vertical-align: middle;\r\n width: 100%;\r\n table-layout: auto;\r\n}\r\n\r\n.am-selectmenu-holder-item>.am-selectlist-item{\r\n display: table-row;\r\n}\r\n\r\n.am-selectmenu-holder-item .am-selectlist-item-text-ctn,\r\n.am-selectmenu-holder-item .am-selectlist-item-desc-ctn{\r\n display: table-cell;\r\n padding-left: 10px;\r\n white-space: nowrap;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n width: auto;\r\n}\r\n\r\n\r\n.am-selectmenu.disabled {\r\n pointer-events: none;\r\n background-color: #ebebe4;\r\n}", ""]); /***/ }), /***/ 7464: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-select-table-render-space {\r\n position: fixed;\r\n top: 0;\r\n left: 0;\r\n z-index: -1000;\r\n visibility: hidden;\r\n font-size: 14px;\r\n}\r\n\r\n.absol-select-table {\r\n border: solid 1px #a9a9a9;\r\n min-width: 26em;\r\n overflow: hidden;\r\n}\r\n\r\n.absol-select-table-header {\r\n display: block;\r\n position: relative;\r\n box-sizing: content-box;\r\n height: 2.2857142857em;\r\n}\r\n\r\n.absol-select-table-searchtextinput-container {\r\n position: absolute;\r\n left: 0.14285714285em;\r\n top: 0.14285714285em;\r\n height: 2em;\r\n right: 10em;\r\n /* background-color: cyan; */\r\n}\r\n\r\n.absol-select-table.disable-move-all .absol-select-table-buttons-container {\r\n display: none;\r\n}\r\n\r\n.absol-select-table.disable-move-all .absol-select-table-searchtextinput-container {\r\n right: 0.14285714285em !important;\r\n}\r\n\r\n.absol-select-table-buttons-container {\r\n position: absolute;\r\n right: 0.14285714285em;\r\n top: 0.14285714285em;\r\n width: 10.7142857143em;\r\n height: 2em;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-select-table-buttons-container>button {\r\n height: 2em;\r\n font-size: 1em;\r\n background-color: transparent;\r\n border: none;\r\n padding: 0 0.5em;\r\n margin: 0;\r\n text-decoration: underline;\r\n cursor: pointer;\r\n}\r\n\r\n.absol-select-table-buttons-container>button:focus {\r\n outline: none;\r\n}\r\n\r\n.absol-select-table-buttons-container>button:hover {\r\n color: #a9a9a9;\r\n}\r\n\r\n.absol-select-table-buttons-container>button:active {\r\n color: #a9a9ff;\r\n}\r\n\r\n.absol-select-table-body {\r\n margin: 0.14285714285em;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-select-table-items-scroller {\r\n width: 50%;\r\n display: inline-block;\r\n box-sizing: border-box;\r\n vertical-align: top;\r\n overflow-y: auto;\r\n}\r\n\r\n.absol-select-table-items-scroller .absol-scroll-button {\r\n background-color: rgba(1, 1, 30, 0.1);\r\n}\r\n\r\n.absol-select-table-items-scroller .absol-scroll-bar-v-container {\r\n width: 0.69em;\r\n}\r\n\r\n.absol-select-table-selected-search-items-container,\r\n.absol-select-table-nonselected-search-items-container,\r\n.absol-select-table.searching .absol-select-table-selected-items-container,\r\n.absol-select-table.searching .absol-select-table-nonselected-items-container {\r\n display: none;\r\n}\r\n\r\n.absol-select-table.searching .absol-select-table-selected-search-items-container,\r\n.absol-select-table.searching .absol-select-table-nonselected-search-items-container {\r\n display: block;\r\n padding-right: 0.7em;\r\n}\r\n\r\n.absol-select-table-nonselected-items-container,\r\n.absol-select-table-selected-items-container {\r\n padding-right: 0.7em;\r\n}\r\n\r\n.absol-select-table-nonselected-items-container>.absol-select-table-item,\r\n.absol-select-table-selected-items-container>.absol-select-table-item,\r\n.absol-select-table-nonselected-search-items-container>.absol-select-table-item,\r\n.absol-select-table-selected-search-items-container>.absol-select-table-item {\r\n margin: 0.14285714285em;\r\n}\r\n\r\n.absol-select-table-item {\r\n display: block;\r\n line-height: 2em;\r\n min-height: 2em;\r\n position: relative;\r\n background-color: rgba(169, 169, 169, 0.05);\r\n border: solid 1px rgb(235, 235, 235);\r\n border-radius: 0.2em;\r\n overflow: hidden;\r\n -webkit-user-select: none;\r\n /* Safari 3.1+ */\r\n -moz-user-select: none;\r\n /* Firefox 2+ */\r\n -ms-user-select: none;\r\n /* IE 10+ */\r\n user-select: none;\r\n /* Standard syntax */\r\n padding-left: 0.69em;\r\n padding-right: 1.8em;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-select-table-item:hover {\r\n background-color: rgba(169, 169, 169, 0.1);\r\n}\r\n\r\n.absol-select-table-item-right-container {\r\n right: 0.3em;\r\n bottom: 0.3em;\r\n top: 0.3em;\r\n padding: 0.2em;\r\n width: 1.4em;\r\n position: absolute;\r\n border-radius: 0.2em;\r\n box-sizing: border-box;\r\n ;\r\n}\r\n\r\n.absol-select-table-item-right-container:hover {\r\n background-color: rgba(169, 169, 169, 0.3);\r\n}\r\n\r\nspan.absol-select-table-item-text {\r\n white-space: normal;\r\n \r\n}\r\n\r\n.absol-select-table-item-right-container-table{\r\n display: table;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n.absol-select-table-item-right-container-cell{\r\n display: table-cell;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-select-table-item-right-container svg {\r\n width: 1em;\r\n height: 1em;\r\n display: none;\r\n}\r\n\r\n/* clearfix\r\n.absol-select-table-none-nonselected-items-container::after,\r\n.absol-select-table-none-selected-items-container::after {\r\n content: \"\";\r\n display:table;\r\n clear: both;\r\n} */\r\n\r\n.absol-select-table-selected-items-container .absol-select-table-item-right-container svg.sub-icon,\r\n.absol-select-table-selected-search-items-container .absol-select-table-item-right-container svg.sub-icon {\r\n display: block;\r\n stroke: rgb(243, 61, 61);\r\n fill: rgb(226, 100, 100);\r\n}\r\n\r\n.absol-select-table-nonselected-items-container .absol-select-table-item-right-container svg.add-icon,\r\n.absol-select-table-nonselected-search-items-container .absol-select-table-item-right-container svg.add-icon {\r\n display: block;\r\n fill: rgb(100, 226, 167);\r\n stroke: rgb(61, 185, 243);\r\n}\r\n\r\n.absol-select-table.portrait {}", ""]); /***/ }), /***/ 2645: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".am-select-tree-leaf-box {\r\n min-width: 10em;\r\n}\r\n\r\n.am-select-tree-leaf-box-body {\r\n overflow-y: auto;\r\n max-height: calc(80vh - 2em);\r\n}\r\n\r\n.am-select-tree-leaf-box.as-enable-search .am-select-tree-leaf-box-body {\r\n max-height: calc(80vh - 4em - 10px);\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item {\r\n display: block;\r\n white-space: nowrap;\r\n position: relative;\r\n width: 100%;\r\n overflow: hidden;\r\n --level: 0;\r\n --icon-width: 0px;\r\n}\r\n\r\n.am-select-tree-leaf-item:active {\r\n background-color: #efefef;\r\n}\r\n\r\n.am-select-tree-leaf-item.as-selected {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item.as-has-icon {\r\n --icon-width: 2.7em;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-toggle-ctn,\r\n.am-select-tree-leaf-item-icon-ctn,\r\n.am-select-tree-leaf-item-checkbox-ctn {\r\n position: absolute;\r\n white-space: nowrap;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.am-select-tree-leaf-item-toggle-ctn {\r\n left: calc(2em * var(--level) + 0.2em);\r\n width: 1.5em;\r\n text-align: center;\r\n}\r\n\r\n.am-select-tree-leaf-item-toggle-ctn > svg {\r\n width: 0.7em;\r\n height: 0.7em;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-icon-ctn {\r\n left: calc(2em * var(--level) + 1.7em);\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-icon-ctn > svg {\r\n display: inline-block;\r\n vertical-align: middle;\r\n\r\n}\r\n\r\n.am-select-tree-leaf-item-icon-ctn {\r\n\r\n}\r\n\r\n.am-select-tree-leaf-item.as-status-open svg .toggle-close,\r\n.am-select-tree-leaf-item.as-status-close svg .toggle-open,\r\n.am-select-tree-leaf-item:not(.as-status-close):not(.as-status-open) .am-select-tree-leaf-item-toggle-ctn {\r\n display: none;\r\n}\r\n\r\n.am-select-tree-leaf-item-icon-ctn::before,\r\n.am-select-tree-leaf-item-toggle-ctn::before,\r\n.am-select-tree-leaf-item-checkbox-ctn::before {\r\n content: \"\";\r\n height: 100%;\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n.am-select-tree-leaf-item-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n.am-select-tree-leaf-item-icon-ctn > span {\r\n font-size: 1.8em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-icon-ctn img,\r\n.am-select-tree-leaf-item-icon-ctn svg {\r\n width: 1.8em;\r\n height: 1.8em;\r\n display: inline-block;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-text {\r\n width: var(--text-width);\r\n box-sizing: border-box;\r\n padding: 0.3em 0.5em 0.3em calc(1.2em + 2em * var(--level) + var(--icon-width));\r\n display: inline-block;\r\n vertical-align: middle;\r\n line-height: 1.5;\r\n white-space: normal;\r\n}\r\n\r\n\r\n.am-select-tree-leaf-item-desc {\r\n display: none;\r\n vertical-align: middle;\r\n}\r\n", ""]); /***/ }), /***/ 9235: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-select-tree-leaf-item:not(.as-is-leaf) > .absol-exp-node > .absol-exp-node-name,\r\n.as-select-tree-leaf-item:not(.as-is-leaf) > .absol-exp-node > .absol-exp-node-ext-icon,\r\n.as-select-tree-leaf-item.as-no-select > .absol-exp-node > .absol-exp-node-name,\r\n.as-select-tree-leaf-item.as-no-select > .absol-exp-node > .absol-exp-node-ext-icon\r\n{\r\n color: #888;\r\n}\r\n\r\n.as-select-tree-leaf-item:not(.as-is-leaf) > .absol-exp-node > .absol-exp-node-desc {\r\n color: rgb(169, 169, 172)\r\n}\r\n\r\n.as-select-tree-leaf-item > .absol-exp-node:hover,\r\n.as-select-tree-leaf-item > .absol-exp-node:focus,\r\n.as-select-tree-leaf-item > .absol-exp-node:active {\r\n background-color: transparent;\r\n}\r\n\r\n.as-select-tree-leaf-item.as-is-leaf:not(.as-no-select) > .absol-exp-node:hover {\r\n background-color: #efefef;\r\n}\r\n\r\n.as-select-tree-leaf-item.as-selected > .absol-exp-node {\r\n background-color: #dfdfdf;\r\n}\r\n\r\n.am-select-tree-menu.absol-selectmenu {\r\n width: auto;\r\n}\r\n\r\n.am-select-tree-menu .absol-selectmenu-holder-item {\r\n position: relative;\r\n left: unset;\r\n right: unset;\r\n top: unset;\r\n bottom: unset;\r\n height: 100%;\r\n max-width: 100%;\r\n}\r\n\r\n\r\n.am-select-tree-menu .absol-selectlist-item-text {\r\n max-width: calc(100vw - 200px);/**TODO: find better solution*/\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n}", ""]); /***/ }), /***/ 1542: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-selecttreemenu .absol-tree-list-item-desc-container{\r\n right: 30px;\r\n}\r\n\r\n\r\n.absol-selectmenu-holder-item .absol-tree-list-item-parent:hover {\r\n background-color: transparent;\r\n}\r\n\r\n.am-select-tree-menu {\r\n max-width: var(--as-width-limit);\r\n}", ""]); /***/ }), /***/ 1914: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-single-page {\r\n position: relative;\r\n overflow: hidden;\r\n}\r\n\r\n\r\n.absol-single-page-header {\r\n box-sizing: border-box;\r\n z-index: 2;\r\n display: block;\r\n}\r\n\r\n.absol-single-page-footer {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.absol-single-page-scroller-viewport {\r\n min-height: 100%;\r\n display: block;\r\n position: relative;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-single-page-scroller {\r\n position: relative;\r\n overflow-y: auto;\r\n}\r\n\r\n.absol-single-page.as-has-header {\r\n display: grid;\r\n grid-template-rows: auto 1fr;\r\n}\r\n\r\n.absol-single-page:not(.as-has-header) .absol-single-page-scroller{\r\n width: 100%;\r\n height: 100%;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.absol-single-page.as-viewport-full > .absol-single-page-scroller > .absol-single-page-scroller-viewport {\r\n height: 100%;\r\n width: 100%;\r\n overflow: hidden;\r\n}\r\n\r\n.absol-single-page.as-no-scroll > .absol-single-page-scroller {\r\n overflow: hidden;\r\n}", ""]); /***/ }), /***/ 6362: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-snackbar {\r\n visibility: hidden;\r\n min-width: 250px;\r\n margin-left: -125px;\r\n background-color: #333;\r\n color: #fff;\r\n text-align: center;\r\n border-radius: 2px;\r\n padding: 16px;\r\n position: fixed;\r\n z-index: 1000000000;\r\n left: 50%;\r\n bottom: 0;\r\n font-size: 17px;\r\n opacity: 0;\r\n transition: opacity 0.25s ease-in, bottom 0.25s ease-in;\r\n\r\n}\r\n\r\n.as-snackbar.as-show {\r\n visibility: visible;\r\n bottom: 30px;\r\n opacity: 1;\r\n}\r\n\r\n.as-snackbar.as-hiding{\r\n transition: opacity 0.5s ease-out, bottom 0.5s ease-out;\r\n visibility: visible;\r\n bottom: 0;\r\n opacity: 0;\r\n}\r\n\r\n", ""]); /***/ }), /***/ 5906: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-solid-color-picker:not(.as-solid-color-picker-mode-swatches) .as-solid-color-picker-swatches-select-ctn,\r\n.as-solid-color-picker:not(.as-solid-color-picker-mode-swatches) .as-solid-color-picker-swatches-ctn,\r\n.as-solid-color-picker:not(.as-solid-color-picker-mode-picker) .as-solid-color-picker-spectrum,\r\n.as-solid-color-picker:not(.as-solid-color-picker-mode-picker) .as-solid-color-picker-hue,\r\n.as-solid-color-picker:not(.as-solid-color-picker-mode-picker) .as-solid-color-picker-alpha,\r\n.as-solid-color-picker:not(.as-solid-color-picker-mode-picker) .as-solid-color-picker-near {\r\n display: none;\r\n}\r\n\r\n.as-solid-color-picker:not(.as-has-opacity) .as-solid-color-picker-color-opacity,\r\n.as-solid-color-picker:not(.as-has-opacity) .as-solid-color-picker-alpha {\r\n visibility: hidden;\r\n}\r\n\r\n.as-solid-color-picker .as-hanger {\r\n user-select: none;\r\n touch-action: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n}\r\n\r\n.as-solid-color-picker {\r\n display: inline-block;\r\n border: 1px solid black;\r\n font-size: 12px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n outline: none;\r\n background-color: white;\r\n}\r\n\r\n.as-solid-color-picker-body {\r\n padding-bottom: 10px;\r\n padding-left: 10px;\r\n padding-right: 10px;\r\n box-sizing: border-box;\r\n border-bottom: 1px solid #dddddd;\r\n}\r\n\r\n.as-solid-color-picker-header {\r\n padding: 10px;\r\n}\r\n\r\n.as-solid-color-picker-mode {\r\n font-size: 0.9em;\r\n}\r\n\r\n.as-solid-color-picker-mode button {\r\n height: 1.5em;\r\n min-width: 7em;\r\n}\r\n\r\n.as-solid-color-picker-swatches-name {\r\n color: #006ce5;\r\n text-decoration: underline;\r\n cursor: pointer;\r\n}\r\n\r\n.as-solid-color-picker-swatches-select-ctn {\r\n line-height: 2em;\r\n}\r\n\r\n.as-solid-color-picker-swatches-ctn {\r\n overflow-y: auto;\r\n width: 20em;\r\n height: 20em;\r\n box-sizing: content-box;\r\n}\r\n\r\n.as-solid-color-picker-swatches-ctn .as-swatches-table {\r\n width: 100%;\r\n}\r\n\r\n.as-solid-color-picker-swatches-ctn .as-swatches-table-row,\r\n.as-solid-color-picker-recent-swatches-ctn .as-swatches-table-row {\r\n height: 2em;\r\n}\r\n\r\n.as-solid-color-picker-recent-swatches-ctn .as-swatches-table-cell {\r\n width: 1.6666666em;\r\n}\r\n\r\n\r\n.as-solid-color-picker-recent-title {\r\n line-height: 1.5em;\r\n margin-top: 0.5em;\r\n font-weight: bold;\r\n}\r\n\r\n.as-solid-color-picker-recent-swatches-ctn {\r\n overflow-y: auto;\r\n width: 20em;\r\n height: 4em;\r\n box-sizing: content-box;\r\n}\r\n\r\n.as-solid-color-picker-footer {\r\n padding: 10px;\r\n}\r\n\r\n.as-solid-color-picker-footer .as-flexicon-button {\r\n font-size: inherit;\r\n height: 2em;\r\n box-sizing: border-box;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-solid-color-picker-selected {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 2em;\r\n width: 5em;\r\n border: 1px solid #ddd;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-solid-color-picker-color-hex,\r\n.as-solid-color-picker-color-opacity {\r\n font-size: inherit;\r\n width: 6em;\r\n}\r\n\r\n.as-solid-color-picker-color-hex input {\r\n margin-left: 0;\r\n}\r\n\r\n.as-flexicon-input.as-solid-color-picker-color-opacity.as-flexicon-input-has-icon.as-flexicon-input-has-unit input {\r\n width: calc(100% - 4em);\r\n}\r\n\r\n.as-solid-color-picker.as-nullable .as-solid-color-picker-none-ctn{\r\n display: inline-block;\r\n\r\n}\r\n\r\n.as-solid-color-picker-none-ctn {\r\n display: none;\r\n margin-top: 5px;\r\n padding: 5px;\r\n cursor: default;\r\n user-select: none;\r\n}\r\n\r\n.as-solid-color-picker-none-ctn.as-selected {\r\n box-shadow: rgba(0, 0, 0, 0.7) 0px 0px 0.3em 0.125em inset;\r\n}\r\n\r\n.as-solid-color-picker-none-ctn:hover {\r\n color: var(--as-transparent-button-text-hover-color);\r\n}\r\n\r\n\r\n.as-solid-color-picker-none-ctn:active {\r\n color: var(--as-transparent-button-text-active-color);\r\n}\r\n\r\n.as-solid-color-picker-none-ctn > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-solid-color-picker-none-cell {\r\n width: 1.5em;\r\n height: 1.5em;\r\n margin-right: 0.3em;\r\n}\r\n\r\n\r\n.as-solid-color-picker-color-opacity input {\r\n padding-left: 0;\r\n padding-right: 0;\r\n}\r\n\r\n.as-solid-color-picker-footer > *:not(:first-child) {\r\n margin-left: 0.5em;\r\n}\r\n\r\n.as-swatches-table-cell .as-solid-color-picker-selected-dot {\r\n left: calc(50% - 0.5em);\r\n top: calc(50% - 0.5em);\r\n}\r\n\r\n.as-solid-color-picker-selected-dot {\r\n position: absolute;\r\n width: 1em;\r\n height: 1em;\r\n box-shadow: inset 0px 0px 0.3em 0.125em rgba(255, 255, 255, 0.7);\r\n z-index: 1;\r\n border-radius: 50%;\r\n}\r\n\r\n\r\n.as-solid-color-picker-spectrum {\r\n width: 20em;\r\n height: 13.3em;\r\n background-color: red;\r\n position: relative;\r\n}\r\n\r\n.as-solid-color-picker-spectrum-dot {\r\n width: 1em;\r\n height: 1em;\r\n box-shadow: inset 0px 0px 0.3em 0.125em rgba(0, 0, 0, 0.7);\r\n z-index: 1;\r\n border-radius: 50%;\r\n position: absolute;\r\n bottom: calc(100% - 0.5em);\r\n left: calc(100% - 0.5em);\r\n}\r\n\r\n\r\n.as-solid-color-picker-hue {\r\n width: 20em;\r\n height: 2em;\r\n background: linear-gradient(to right, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);\r\n position: relative;\r\n}\r\n\r\n.as-solid-color-picker-hue-dot {\r\n width: 1em;\r\n height: 1em;\r\n box-shadow: inset 0px 0px 0.3em 0.125em rgba(0, 0, 0, 0.7);\r\n z-index: 1;\r\n border-radius: 50%;\r\n position: absolute;\r\n top: calc(50% - 0.5em);\r\n left: calc(0% - 0.5em);\r\n}\r\n\r\n\r\n.as-solid-color-picker-alpha {\r\n background-image: url('');\r\n background-size: 1.5em;\r\n image-rendering: optimizeSpeed;\r\n image-rendering: -moz-crisp-edges;\r\n image-rendering: -o-crisp-edges;\r\n image-rendering: -webkit-optimize-contrast;\r\n image-rendering: pixelated;\r\n image-rendering: optimize-contrast;\r\n -ms-interpolation-mode: nearest-neighbor;\r\n\r\n width: 20em;\r\n height: 2em;\r\n position: relative;\r\n}\r\n\r\n.as-solid-color-picker-alpha-color {\r\n background: linear-gradient(to right, rgba(255, 0, 0, 0.0) 0%, rgba(255, 0, 0, 1) 100%);\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-solid-color-picker-alpha-dot {\r\n width: 1em;\r\n height: 1em;\r\n box-shadow: inset 0px 0px 0.3em 0.125em rgba(0, 0, 0, 0.7);\r\n z-index: 1;\r\n border-radius: 50%;\r\n position: absolute;\r\n top: calc(50% - 0.5em);\r\n left: calc(100% - 0.5em);\r\n}\r\n\r\n\r\n.as-solid-color-picker-near {\r\n margin-top: 0.5em;\r\n width: 20em;\r\n height: 4.2em;\r\n}\r\n\r\n.as-solid-color-picker-near .as-swatches-table-cell-color {\r\n transition: transform 0.1s;\r\n}\r\n\r\n\r\n.as-solid-color-picker-near .as-swatches-table-cell-color:hover {\r\n transform: scale(1.2);\r\n z-index: 2;\r\n}", ""]); /***/ }), /***/ 7765: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-span-input {\r\n white-space: pre;\r\n}\r\n\r\n.absol-span-input:focus {\r\n outline-color: rgba(30, 150, 255, 0.3);\r\n outline-width: 1px;\r\n}\r\n\r\n.absol-span-input:empty::before {\r\n content: \" \";\r\n display: inline;\r\n white-space: pre;\r\n}\r\n\r\n.absol-span-input.absol-span-input-empty-minus:empty::before {\r\n content: \"-\";\r\n}", ""]); /***/ }), /***/ 4200: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-spectrum-color {\r\n position: relative;\r\n touch-action: none;\r\n user-select: none;\r\n -moz-user-select: none;\r\n -webkit-user-select: none;\r\n}\r\n\r\n.as-spectrum-color-sat {\r\n width: 100%;\r\n height: 100%;\r\n box-sizing: content-box;\r\n background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0)));\r\n background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0));\r\n background-image: -moz-linear-gradient(left, #fff, rgba(204, 154, 129, 0));\r\n background-image: -o-linear-gradient(left, #fff, rgba(204, 154, 129, 0));\r\n background-image: -ms-linear-gradient(left, #fff, rgba(204, 154, 129, 0));\r\n background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0));\r\n -ms-filter: \"progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)\";\r\n filter: progid:DXImageTransform.Microsoft.gradient(GradientType=1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81');\r\n}\r\n\r\n\r\n.as-spectrum-color-val {\r\n width: 100%;\r\n height: 100%;\r\n box-sizing: content-box;\r\n background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0)));\r\n background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0));\r\n background-image: -moz-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));\r\n background-image: -o-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));\r\n background-image: -ms-linear-gradient(bottom, #000, rgba(204, 154, 129, 0));\r\n background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0));\r\n -ms-filter: \"progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)\";\r\n filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000');\r\n}", ""]); /***/ }), /***/ 3848: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-static-tabbar {\r\n position: relative;\r\n}\r\n\r\n.absol-static-tabbar-button {\r\n height: 2em;\r\n background-color: transparent;\r\n border: none;\r\n font-size: 1em;\r\n padding-left: 0.5em;\r\n padding-right: 0.5em;\r\n color: rgb(104, 104, 104);\r\n}\r\n\r\n.absol-static-tabbar-button:hover {\r\n color: rgb(30, 30, 55);\r\n}\r\n\r\n.absol-static-tabbar-button.active {\r\n color: black;\r\n}\r\n\r\n.absol-static-tabbar-button:focus {\r\n outline: none;\r\n}\r\n\r\n.absol-static-tabbar-button>span {\r\n font-size: 0.7em;\r\n}\r\n\r\n.absol-static-tabbar-hline {\r\n border-bottom: solid 1px rgb(127, 127, 128);\r\n height: 100%;\r\n}\r\n\r\n.absol-static-tabbar-active-box {\r\n position: absolute;\r\n bottom: 0;\r\n top: 0;\r\n left: 0;\r\n width: 0;\r\n transition: left 0.15s, width 0.15s;\r\n padding-left: 0.5em;\r\n padding-right: 0.5em;\r\n box-sizing: border-box;\r\n /* z-index: 1; */\r\n}\r\n\r\n.absol-static-tabbar.dark .absol-static-tabbar-hline{\r\n border-bottom-color: white;\r\n}\r\n\r\n.absol-static-tabbar.dark .absol-static-tabbar-button.active{\r\n color: white;\r\n}\r\n\r\n.absol-static-tabbar.dark .absol-static-tabbar-button {\r\n color: rgb(204, 204, 204);\r\n}", ""]); /***/ }), /***/ 1636: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-color-cell {\r\n position: relative;\r\n background-image: url('');\r\n background-size: 1.5em;\r\n image-rendering: optimizeSpeed;\r\n /* STOP SMOOTHING, GIVE ME SPEED */\r\n image-rendering: -moz-crisp-edges;\r\n /* Firefox */\r\n image-rendering: -o-crisp-edges;\r\n /* Opera */\r\n image-rendering: -webkit-optimize-contrast;\r\n /* Chrome (and eventually Safari) */\r\n image-rendering: pixelated;\r\n /* Chrome */\r\n image-rendering: optimize-contrast;\r\n /* CSS3 Proposed */\r\n -ms-interpolation-mode: nearest-neighbor;\r\n /* IE8+ */\r\n}\r\n\r\n.as-color-cell.as-null .as-color-cell-value {\r\n background-color: transparent !important;\r\n background-size: contain;\r\n background-position: center;\r\n }\r\n\r\n.as-color-cell-value {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-swatches-table {\r\n display: table;\r\n table-layout: fixed;\r\n}\r\n\r\n.as-swatches-table-row {\r\n display: table-row;\r\n}\r\n\r\n\r\n.as-swatches-table-cell.as-color-cell {\r\n position: relative;\r\n display: table-cell;\r\n background-size: 1.5em;\r\n\r\n}\r\n", ""]); /***/ }), /***/ 2631: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-switch {\r\n position: relative;\r\n display: inline-block;\r\n width: 2.2em;\r\n height: 1.2em;\r\n vertical-align: middle;\r\n}\r\n\r\n.absol-switch input {\r\n opacity: 0;\r\n width: 0;\r\n height: 0;\r\n}\r\n\r\n.absol-switch:not(.as-read-only) .absol-switch-slider{\r\n cursor: pointer;\r\n}\r\n\r\n.absol-switch-slider {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n background-color: #ccc;\r\n -webkit-transition: .4s;\r\n transition: .4s;\r\n border-radius: 0.6em;\r\n}\r\n\r\n.absol-switch-slider:before {\r\n position: absolute;\r\n content: \"\";\r\n height: 1em;\r\n width: 1em;\r\n left: 0.1em;\r\n bottom: 0.1em;\r\n background-color: white;\r\n -webkit-transition: .4s;\r\n transition: .4s;\r\n border-radius: 0.5em;\r\n}\r\n\r\ninput:checked+.absol-switch-slider {\r\n background-color: #2196F3;\r\n}\r\n\r\ninput:focus+.absol-switch-slider {\r\n box-shadow: 0 0 1px #2196F3;\r\n}\r\n\r\ninput:checked+.absol-switch-slider:before {\r\n -webkit-transform: translateX(1em);\r\n -ms-transform: translateX(1em);\r\n transform: translateX(1em);\r\n}\r\n\r\n/* Rounded absol-switch-sliders */\r\n.absol-switch.square .absol-switch-slider {\r\n border-radius: 0;\r\n}\r\n\r\n.absol-switch.square .absol-switch-slider:before {\r\n border-radius: 0;\r\n}\r\n\r\n.absol-switch.disabled {\r\n pointer-events: none;\r\n}\r\n\r\n.absol-switch.disabled .absol-switch-slider:before{\r\n background-color: rgb(234, 234, 234);\r\n}\r\n\r\n.absol-switch.disabled input:checked+.absol-switch-slider {\r\n background-color: rgb(141, 188, 226);\r\n}\r\n\r\n.absol-switch.disabled .absol-switch-slider {\r\n background-color: rgb(171, 171, 171);\r\n}\r\n\r\n", ""]); /***/ }), /***/ 6725: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.as-table-of-text-input-wrapper {\r\n border: 1px solid #dddddd;\r\n}\r\n\r\n.as-table-of-text-input-content-ctn {\r\n overflow: auto;\r\n}\r\n\r\n\r\n.as-table-of-text-input {\r\n width: 100%;\r\n border-collapse: collapse;\r\n color: black;\r\n font-family: 'Aptos Narrow', Calibri, sans-serif, 'Mongolian Baiti', 'Microsoft Yi Baiti', 'Javanese Text', 'Yu Gothic';\r\n font-size: 11pt;\r\n margin: 10px;\r\n}\r\n\r\n.as-table-of-text-input-wrapper.as-size-a4 .as-table-of-text-input {\r\n width: 445pt;\r\n}\r\n\r\n.as-table-of-text-input pre {\r\n font: inherit;\r\n line-height: 1.75;\r\n}\r\n\r\n.as-table-of-text-input.as-inline {\r\n display: inline-table;\r\n}\r\n\r\n.as-table-of-text-input-cell {\r\n vertical-align: top;\r\n padding: 0px 5px;\r\n border: 1px dashed #808080;\r\n position: relative;\r\n}\r\n\r\n.as-table-of-text-input-cell.as-focus::before {\r\n pointer-events: none;\r\n content: \"\";\r\n position: absolute;\r\n border: 1px dashed var(--variant-color-primary);\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n}\r\n\r\n.as-table-of-text-input-cell .as-preinput {\r\n outline: none;\r\n display: block;\r\n}\r\n\r\n.as-table-of-text-input-cell.as-bold {\r\n font-weight: bold;\r\n}\r\n\r\n.as-table-of-text-input-cell.as-italic {\r\n font-style: italic;\r\n}\r\n\r\n.as-table-of-text-input-tool {\r\n background-color: #f8f8f8;\r\n font-size: 14px;\r\n /*-webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);*/\r\n /*-moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);*/\r\n /*box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);*/\r\n /*border-radius: 4px;*/\r\n padding: 3px;\r\n border-bottom: 1px solid #dddddd;\r\n}\r\n\r\n.as-table-of-text-input-tool > button,\r\n.as-table-of-text-input-tool-group > button {\r\n height: 30px;\r\n width: 30px;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n.as-table-of-text-input-tool-group {\r\n display: inline-block;\r\n vertical-align: middle;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-table-of-text-input-tool-group:not(:last-child) {\r\n border-right: 1px solid #dddddd;\r\n}\r\n\r\n\r\n.as-table-of-text-input-tool button.as-checked {\r\n color: #2977ff;\r\n /*background-color: rgb(240, 247, 255);*/\r\n box-shadow: inset gray 0px 0px 4px -2px;\r\n}\r\n", ""]); /***/ }), /***/ 6038: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-table-scroller .absol-table-scroller-viewport {\r\n width: calc(100% + var(--scrollbar-width));\r\n height: calc(100% + var(--scrollbar-width));\r\n}\r\n\r\n.absol-table-scroller .absol-table-scroller-header-hscroller-viewport {\r\n margin-bottom: calc(0px - var(--scrollbar-width))\r\n}\r\n\r\n\r\n.absol-table-scroller {\r\n --scrollbar-width: 17px;\r\n --new-pos-y: 0;\r\n position: relative;\r\n padding-right: 17px;\r\n padding-bottom: 17px;\r\n --tvs-scroll-padding-bottom: 0px;\r\n overflow: hidden;\r\n}\r\n\r\n.absol-table-scroller:not(.as-scroll-vertical) {\r\n padding-right: 0;\r\n}\r\n\r\n\r\n.absol-table-scroller:not(.as-scroll-horizontal) {\r\n padding-bottom: 0;\r\n}\r\n\r\n.as-table-scroller-origin-table-ctn {\r\n padding-bottom: var(--tvs-scroll-padding-bottom);\r\n\r\n}\r\n\r\n\r\n.as-table-scroller-vertical-scroller {\r\n overflow-y: scroll;\r\n height: 100%;\r\n box-sizing: border-box;\r\n margin-right: calc(0px - var(--scrollbar-width));\r\n}\r\n\r\n.as-table-scroller-fixed-y-header-ctn {\r\n position: absolute;\r\n z-index: 4;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n overflow: hidden;\r\n}\r\n\r\n.as-table-scroller-fixed-y-header,\r\n.as-table-scroller-fixed-xy-header {\r\n table-layout: fixed;\r\n}\r\n\r\n.as-table-scroller-fixed-y-header td,\r\n.as-table-scroller-fixed-y-header tr,\r\n.as-table-scroller-fixed-y-header th,\r\n.as-table-scroller-fixed-xy-header td,\r\n.as-table-scroller-fixed-xy-header tr,\r\n.as-table-scroller-fixed-xy-header th {\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-table-scroller-fixed-x-col-ctn {\r\n position: absolute;\r\n z-index: 5;\r\n top: 0;\r\n left: 0;\r\n overflow: hidden;\r\n}\r\n\r\n.as-table-scroller-fixed-xy-header-ctn {\r\n position: absolute;\r\n z-index: 12;\r\n top: 0;\r\n left: 0;\r\n overflow: hidden;\r\n}\r\n\r\n.as-table-scroller-fixed-y-header-scroller {\r\n overflow-x: scroll;\r\n margin-bottom: calc(var(--scrollbar-width) * -1);\r\n}\r\n\r\n.as-mobile-theme .as-table-scroller-fixed-y-header-scroller::-webkit-scrollbar,\r\n.as-mobile-theme .absol-table-scroller-header-hscroller-viewport::-webkit-scrollbar {\r\n display: none;\r\n}\r\n\r\n\r\n.as-table-scroller-horizontal-scroller-viewport {\r\n overflow: hidden;\r\n position: relative;\r\n}\r\n\r\n.as-table-scroller-horizontal-scroller {\r\n overflow-x: scroll;\r\n width: 100%;\r\n box-sizing: border-box;\r\n margin-bottom: calc(var(--scrollbar-width) * -1);\r\n}\r\n\r\n.absol-table-scroller-content {\r\n position: relative;\r\n overflow: hidden;\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.absol-table-scroller-render-space {\r\n position: fixed;\r\n overflow: scroll;\r\n left: 0;\r\n top: 0;\r\n max-width: calc(99vw - 30px);\r\n max-height: calc(99vh - 30px);\r\n opacity: 0;\r\n z-index: -1000;\r\n visibility: hidden;\r\n}\r\n\r\n\r\n.absol-table-scroller-viewport {\r\n box-sizing: border-box;\r\n overflow: scroll;\r\n width: calc(100% + 17px);\r\n height: calc(100% + 17px);\r\n background-color: white;\r\n}\r\n\r\n.absol-table-scroller-fixed-viewport {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n z-index: 10;\r\n overflow: hidden;\r\n background-color: white;\r\n /*pointer-events: none;*/\r\n}\r\n\r\n.absol-table-scroller-fixed-viewport > table > thead,\r\n.absol-table-scroller-fixed-viewport > table {\r\n /*border-top-color: transparent !important;*/\r\n}\r\n\r\n.absol-table-scroller-fixed-hidden {\r\n visibility: hidden !important;\r\n opacity: 0 !important;\r\n border-color: transparent !important;\r\n\r\n}\r\n\r\n.absol-table-scroller-header-hscroller {\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n right: 0;\r\n z-index: 9;\r\n overflow: hidden;\r\n /*pointer-events: none;*/\r\n}\r\n\r\n.absol-table-scroller-header-hscroller-viewport {\r\n max-width: 100%;\r\n overflow-x: scroll;\r\n margin-bottom: -17px; /*default*/\r\n background-color: white;\r\n}\r\n\r\n.absol-table-scroller-header-hscroller-viewport table {\r\n table-layout: fixed;\r\n}\r\n\r\n\r\n.absol-table-scroller-left-vscroller {\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n bottom: 0;\r\n z-index: 7;\r\n /* width: 200px; */\r\n overflow-x: hidden;\r\n /*pointer-events: none;*/\r\n}\r\n\r\n.absol-table-scroller-left-vscroller-viewport {\r\n max-height: 100%;\r\n overflow-y: scroll;\r\n min-width: calc(100% + 19px);\r\n overflow-x: hidden;\r\n background-color: white;\r\n}\r\n\r\n\r\n.absol-table-scroller-head-line,\r\n.absol-table-scroller-left-line {\r\n z-index: 30;\r\n /*pointer-events: none;*/\r\n position: absolute;\r\n}\r\n\r\n.absol-table-scroller-head-line {\r\n left: 0;\r\n border-bottom: solid 2px rgb(169, 169, 170);\r\n width: 100%;\r\n}\r\n\r\n.absol-table-scroller-left-line {\r\n top: 0;\r\n border-right: solid 2px rgb(169, 169, 170);\r\n height: 100%;\r\n}\r\n\r\n\r\n.absol-table-scroller.as-scroll-vertical .absol-table-scroller-head-line {\r\n width: 100%;\r\n}\r\n\r\n.absol-table-scroller.as-scroll-horizontal .absol-table-scroller-left-line {\r\n height: 100%;\r\n}\r\n\r\n\r\n.absol-table-scroller:not(.as-scroll-vertical) .absol-table-scroller-head-line {\r\n display: none;\r\n}\r\n\r\n.absol-table-scroller:not(.as-scroll-horizontal) .absol-table-scroller-left-line {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-table-scroller-vscrollbar-container {\r\n position: absolute;\r\n top: 0;\r\n right: 0px;\r\n width: 17px;\r\n bottom: 0;\r\n z-index: 31;\r\n}\r\n\r\n.absol-table-scroller-vscrollbar-container .absol-scrollbar-button {\r\n left: 1px;\r\n right: 1px;\r\n}\r\n\r\n\r\n.absol-table-scroller-vscrollbar-container > div,\r\n.absol-table-scroller-hscrollbar-container > div {\r\n width: 100%;\r\n height: 100%;\r\n}\r\n\r\n.absol-table-scroller-hscrollbar-container {\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n height: 17px;\r\n bottom: 0;\r\n z-index: 31;\r\n}\r\n\r\n\r\n.absol-table-scroller-hscrollbar-container .absol-scrollbar-button {\r\n top: 1px;\r\n bottom: 1px;\r\n}\r\n\r\n\r\n.absol-table-scroller:not(.as-scroll-vertical) .absol-table-scroller-vscrollbar-container {\r\n display: none;\r\n}\r\n\r\n.absol-table-scroller:not(.as-scroll-horizontal) .absol-table-scroller-hscrollbar-container {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-table-scroller.as-scroll-horizontal .absol-table-scroller-vscrollbar-container {\r\n bottom: 17px;\r\n}\r\n\r\n.absol-table-scroller.as-scroll-vertical .absol-table-scroller-hscrollbar-container {\r\n right: 17px;\r\n}\r\n\r\n.absol-table-scroller-fixed-table {\r\n table-layout: fixed;\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.absol-table-scroller-fixed-table *,\r\n.absol-table-scroller-header-hscroller * {\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-table-scroller .as-drag-zone {\r\n cursor: move;\r\n}\r\n\r\n\r\n.absol-table-scroller tr.as-dragging {\r\n position: relative;\r\n z-index: 1;\r\n -webkit-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n -moz-box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n box-shadow: 2px 2px 9px 0px rgba(20, 20, 20, 1);\r\n opacity: 0.8;\r\n}\r\n\r\n.absol-table-scroller td.as-transparent-fix {\r\n visibility: hidden;\r\n opacity: 0;\r\n}\r\n\r\n.absol-table-scroller.as-dragging tbody tr:not(.as-dragging) {\r\n transition: transform 0.1s;\r\n}\r\n\r\n\r\n.absol-table-scroller-viewport thead .as-rotated-text-anchor,\r\n.absol-table-scroller-fixed-viewport thead .as-rotated-text-anchor,\r\n.absol-table-scroller-left-vscroller thead .as-rotated-text-anchor {\r\n display: none;\r\n}\r\n\r\n.absol-table-scroller .as-rotated-text-anchor {\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.as-table-scroller-row-index::before {\r\n content: attr(data-idx);\r\n}\r\n\r\n/*.absol-table-scroller.as-has-new-pos.as-dragging::before {*/\r\n/* content: \"\";*/\r\n/* position: absolute;*/\r\n/* left: 0;*/\r\n/* top: var(--new-pos-y);*/\r\n/* right: 0;*/\r\n/* border-top: 2px solid blue;*/\r\n/* z-index: 8;*/\r\n/* transition: top 0.1s;*/\r\n/*}*/\r\n\r\n", ""]); /***/ }), /***/ 7526: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-table-vscroller {\r\n position: relative;\r\n --tvs-scroll-padding-bottom: 1px;\r\n}\r\n\r\n.absol-table-vscroller-head {\r\n position: absolute;\r\n z-index: 2;\r\n width: 300px;\r\n height: 20px;\r\n top: 0;\r\n left: 0;\r\n}\r\n\r\n.absol-table-vscroller-head-line{\r\n position: absolute;\r\n left: 0;\r\n z-index: 3;\r\n pointer-events: none;\r\n border-bottom:solid 2px rgb(169, 169, 170); \r\n width: 100%;\r\n}\r\n\r\n.absol-table-vscroller.scroll-v .absol-table-vscroller-head-line{\r\n width: calc(100% - 7px);\r\n}\r\n\r\n.absol-table-vscroller-viewport {\r\n max-height: 100%;\r\n padding-bottom: var(--tvs-scroll-padding-bottom);\r\n padding-top: 1px;\r\n overflow-y: auto;\r\n}\r\n\r\n.absol-table-vscroller-viewport > table{\r\n box-sizing: border-box;\r\n width: 100%;\r\n}", ""]); /***/ }), /***/ 8601: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-tabbar {\r\n height: 2em;\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.absol-tabbar .absol-hscroller-viewport {\r\n overflow-y: hidden;\r\n}\r\n\r\n.absol-tabbar .absol-tabbar-button,\r\n.absol-tabbar .as-tab-bar-add-btn {\r\n height: 100%;\r\n}\r\n\r\n/* .absol-tabbar .absol-scrollbar-container {\r\n height: 5px;\r\n} */\r\n\r\n.absol-tabbar .absol-scrollbar-container.horizontal {\r\n bottom: -2px;\r\n}\r\n\r\n.absol-tabbar .absol-scrollbar-container {\r\n opacity: 0;\r\n transition: opacity 0.2s;\r\n background: rgba(169, 169, 169, 0.1);\r\n}\r\n\r\n.absol-tabbar:hover .absol-scrollbar-container,\r\n.absol-tabbar:active .absol-scrollbar-container {\r\n opacity: 1;\r\n}\r\n\r\n.absol-tabbar .absol-scrollbar-button {\r\n background-color: rgba(33, 33, 40, 0.1);\r\n}\r\n\r\n.absol-tabbar .absol-scrollbar-button:hover {\r\n background-color: rgba(33, 33, 40, 0.3);\r\n}\r\n\r\n\r\n.absol-tabbar .absol-scrollbar-button:active,\r\n.absol-tabbar .absol-hscrollbar.absol-active .absol-scrollbar-button {\r\n background-color: rgba(47, 47, 55, 0.4);\r\n\r\n}\r\n\r\n\r\n.absol-tabbar-button {\r\n padding-left: 1em;\r\n padding-right: 1em;\r\n background-color: rgb(45, 45, 45);\r\n color: rgb(200, 200, 200);\r\n margin-right: 1px;\r\n border: none;\r\n outline: none;\r\n font-size: 1em;\r\n white-space: nowrap;\r\n}\r\n\r\n.as-tab-bar-add-btn {\r\n padding-left: 0.5em;\r\n padding-right: 0.5em;\r\n background-color: rgb(45, 45, 45);\r\n color: rgb(200, 200, 200);\r\n margin-right: 1px;\r\n border: none;\r\n outline: none;\r\n font-size: 1em;\r\n white-space: nowrap;\r\n}\r\n\r\n\r\n.as-tab-bar-button-ext-icon-ctn:empty {\r\n display: none\r\n}\r\n\r\n.as-tab-bar-button-ext-icon-ctn {\r\n display: inline-block;\r\n vertical-align: middle;\r\n padding-right: 0.35em;\r\n margin-left: -0.5em;\r\n}\r\n\r\n.absol-tabbar-button-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n max-width: 300px;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\n.as-tab-bar-button-ext-icon-ctn span {\r\n font-size: 1.2em;\r\n}\r\n\r\n\r\n.absol-tabbar .absol-tabbar-button-active {\r\n background-color: rgb(30, 30, 30);\r\n color: rgb(250, 250, 252);\r\n}\r\n\r\n.absol-tabbar-button-text,\r\n.absol-tabbar-button-icon-container > span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: 1em;\r\n}\r\n\r\n.absol-tabbar-button .absol-tabbar-button-close,\r\n.absol-tabbar-button .absol-tabbar-button-close-circle {\r\n visibility: hidden;\r\n color: rgb(190, 190, 190);\r\n}\r\n\r\n.absol-tabbar-button.as-prevent-closing .absol-tabbar-button-close,\r\n.absol-tabbar-button.as-prevent-closing .absol-tabbar-button-close-circle {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-tabbar-button.as-prevent-closing .absol-tabbar-button-icon-container {\r\n pointer-events: none;\r\n}\r\n\r\n.absol-tabbar-button-icon-container {\r\n display: inline-block;\r\n vertical-align: middle;\r\n margin-left: 0.5em;\r\n}\r\n\r\n\r\n.absol-tabbar-button:not(.as-prevent-closing):hover .absol-tabbar-button-close,\r\n.absol-tabbar-button-active:not(.as-prevent-closing) .absol-tabbar-button-close,\r\n.absol-tabbar-button:hover:not(.as-prevent-closing) .absol-tabbar-button-close-circle,\r\n.absol-tabbar-button-active:not(.as-prevent-closing) .absol-tabbar-button-close-circle {\r\n visibility: visible;\r\n color: red;\r\n}\r\n\r\n.absol-tabbar-button-active .absol-tabbar-button-modified-flag {\r\n color: lightblue;\r\n}\r\n\r\n.absol-tabbar-button-modified-flag {\r\n color: mediumaquamarine;\r\n}\r\n\r\n.absol-tabbar-button:not(.absol-tabbar-button-modified) .absol-tabbar-button-modified-flag,\r\n.absol-tabbar-button.absol-tabbar-button-modified:not(.active) .absol-tabbar-button-icon-container:hover .absol-tabbar-button-modified-flag,\r\n.absol-tabbar-button.absol-tabbar-button-modified .absol-tabbar-button-icon-container:not(:hover) .absol-tabbar-button-close,\r\n.absol-tabbar-button:not(.absol-tabbar-button-modified) .absol-tabbar-button-icon-container:not(:hover) .absol-tabbar-button-close-circle,\r\n.absol-tabbar-button:not(.absol-tabbar-button-modified) .absol-tabbar-button-icon-container:hover .absol-tabbar-button-close,\r\n.absol-tabbar-button.absol-tabbar-button-modified .absol-tabbar-button-close-circle,\r\n.absol-tabbar-button.absol-tabbar-button-modified .absol-tabbar-button-icon-container:not(:hover) .absol-tabbar-button-close {\r\n display: none;\r\n}\r\n\r\n\r\n.absol-button-range {\r\n}\r\n\r\n\r\n.absol-tabview {\r\n position: relative;\r\n}\r\n\r\n.as-tabview-title {\r\n padding: 10px 10px;\r\n font-weight: bold;\r\n font-size: 14px;\r\n color: rgb(230, 230, 205);\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.bsc-white .as-tabview-title,\r\n.bsc-white .as-np-db-btn{\r\n color: var(--tab-button-font-color-hover);\r\n}\r\n\r\n\r\n.absol-tabview-container {\r\n position: absolute;\r\n top: 2em;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n overflow: auto;\r\n background-color: white;\r\n}\r\n\r\n\r\n.absol-tabview-container.absol-tabview-container-hidden {\r\n z-index: -9999;\r\n visibility: hidden;\r\n opacity: 0;\r\n\r\n}\r\n\r\n.absol-tabview-container.absol-tabview-container-hidden *,\r\n.absol-tabview-container.absol-tabview-container-hidden {\r\n pointer-events: none;\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n}\r\n\r\n\r\n.absol-tabview-container > div,\r\n.absol-tabview-container > pre {\r\n width: 100%;\r\n height: 100%;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-tabview-container > pre {\r\n margin: 0;\r\n}\r\n\r\n.absol-frame > iframe {\r\n border: none;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-tabview .absol-tabbar-button {\r\n border-radius: 0.7em 0.7em 0 0;\r\n height: 2em;\r\n box-sizing: border-box;\r\n border: solid 1px #ccc;\r\n background-color: white;\r\n color: black;\r\n padding-left: 1em;\r\n padding-right: 0.357em;\r\n margin-right: 0.357em;\r\n}\r\n\r\n.absol-tabview .as-tab-bar-add-btn {\r\n border-radius: 0.7em 0.7em 0 0;\r\n height: 2em;\r\n box-sizing: border-box;\r\n border: solid 1px #ccc;\r\n background-color: white;\r\n color: black;\r\n}\r\n\r\n.absol-tabview .absol-tabbar {\r\n height: 2em;\r\n overflow-y: hidden;\r\n border-bottom: 1px solid #ccc;\r\n box-sizing: border-box;\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n}\r\n\r\n.absol-tabview .absol-tabbar-button-active {\r\n background-color: #5bc0de;\r\n border-color: #46b8da;\r\n color: white;\r\n}\r\n\r\n/* .absol-tabview .absol-tabbar-button-close {\r\n color: rgb(170, 170, 170);\r\n line-height: 1.5em;\r\n margin-left: 1em;\r\n font-size: 1.3em;\r\n} */\r\n\r\n.absol-tabview .absol-tabbar-button-close:hover {\r\n color: red;\r\n}\r\n\r\n\r\n/************** Mini version - like window form ***********************/\r\n\r\n.absol-tabview.xp-tiny .absol-tabbar {\r\n height: 1.5em;\r\n border-bottom: none;\r\n}\r\n\r\n.absol-tabview.xp-tiny .absol-tabbar-button,\r\n.absol-tabview.xp-tiny .as-tab-bar-add-btn {\r\n height: 1.4em;\r\n padding-left: 5px;\r\n padding-right: 5px;\r\n border-radius: 0;\r\n vertical-align: bottom;\r\n margin: 0.1em 0 0 0;\r\n background-color: rgb(242, 242, 242);\r\n color: black;\r\n position: relative;\r\n}\r\n\r\n.absol-tabview.xp-tiny::before {\r\n content: \"\";\r\n position: absolute;\r\n top: calc(1.5em - 4px);\r\n z-index: 0;\r\n left: 0;\r\n right: 0;\r\n height: 4px;\r\n border-bottom: solid 1px #ccc;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-tabview.xp-tiny .absol-tabbar-button.absol-tabbar-button-active {\r\n height: 1.5em;\r\n margin-top: 0;\r\n background-color: white;\r\n border-top-color: #ccc;\r\n border-left-color: #ccc;\r\n border-right-color: #ccc;\r\n border-bottom-color: white;\r\n}\r\n\r\n\r\n.absol-hscroller.absol-tabbar.disabled .absol-scrollbar-container {\r\n visibility: hidden;\r\n}\r\n\r\n.absol-tabview.absol-tabview.xp-tiny .absol-tabbar-button-close {\r\n line-height: 1.4em;\r\n}\r\n\r\n.absol-tabview.xp-tiny .absol-tabbar-button-icon-container {\r\n display: none;\r\n}\r\n\r\n.absol-tabview.xp-tiny .absol-tabview-container {\r\n top: 1.5em;\r\n}\r\n\r\n.absol-tabview.xp-tiny .absol-tab-absol {\r\n border-left: solid 1px #ccc;\r\n border-right: solid 1px #ccc;\r\n border-bottom: solid 1px #ccc;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.absol-tabview.as-without-close-button > .absol-tabbar .absol-tabbar-button .absol-tabbar-button-icon-container {\r\n display: none;\r\n}\r\n\r\n.absol-tabview.as-without-close-button > .absol-tabbar .absol-tabbar-button {\r\n padding-right: 1em;\r\n}\r\n\r\n.absol-tabview > .absol-tabbar .as-tab-bar-add-btn {\r\n display: none;\r\n}\r\n\r\n.absol-tabview.as-has-add-btn > .absol-tabbar .as-tab-bar-add-btn {\r\n display: inline-block;\r\n}\r\n\r\n\r\n/************************ Like Metro theme *********************/\r\n\r\n.absol-tabview.metro-flat > .absol-tabbar .absol-tabbar-button,\r\n.absol-tabview.metro-flat > .absol-tabbar .as-tab-bar-add-btn {\r\n border-radius: 0;\r\n margin-right: 0;\r\n margin-left: 0;\r\n border-left: none;\r\n border-top: none;\r\n border-bottom: none;\r\n border-right: solid 1px rgba(169, 169, 169, 0.3);\r\n font-size: 1em;\r\n}\r\n\r\n.absol-tabview.metro-flat > .absol-tabbar {\r\n box-shadow: 0px -1px 0px 0px #ccc;\r\n}\r\n\r\n/************************ Round Out theme *********************/\r\n\r\n/*.absol-tabview.rond-out > .absol-tabbar .absol-tabbar-button*/\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar {\r\n border-bottom: calc(0.1em + 1px) solid #3B4453;;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabview-container {\r\n top: 2.1em;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar {\r\n height: 2.1em;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active {\r\n background-color: #3B4453;\r\n color: white;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button {\r\n background-color: #313946;\r\n color: rgb(169, 169, 170);\r\n\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button::before,\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button::after {\r\n content: \"\";\r\n position: absolute;\r\n bottom: 0;\r\n width: 1em;\r\n height: 1em;\r\n z-index: 1;\r\n background-size: cover;\r\n background-image: url('');\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active::before,\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active::after,\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active {\r\n z-index: 3;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active::before,\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button.absol-tabbar-button-active::after {\r\n background-image: url('');\r\n}\r\n\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button {\r\n position: relative;\r\n margin-right: 0;\r\n border: none;\r\n border-radius: 0.8em 0.8em 0 0;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-hscroller-viewport {\r\n padding-left: 1.2em;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button::before {\r\n left: -0.98em;\r\n background-position: left;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .absol-tabbar-button::after {\r\n right: -0.98em;\r\n background-position: right;\r\n\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .as-tab-bar-add-btn {\r\n background-color: #313946;\r\n color: rgb(169, 169, 170);\r\n font-weight: bold;\r\n border: 4px solid #222933;\r\n border-radius: 0.8em 0.8em 0 0.8em;\r\n}\r\n\r\n.absol-tabview.cad-dark > .absol-tabbar .as-tab-bar-add-btn:active {\r\n color: white;\r\n background-color: #3B4453;\r\n font-weight: bold;\r\n}\r\n\r\n.as-tabview-right-ctn {\r\n position: absolute;\r\n z-index: 150;\r\n right: 0;\r\n top: 0;\r\n}\r\n\r\n\r\n\r\n.bsc-white .as-tabview-right-ctn {\r\n top: -10px;\r\n}\r\n\r\n.as-tabview-right-ctn> div{\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.bsc-white .as-tabview-right-ctn::before {\r\n content: \"\";\r\n height: 50px;\r\n display: inline-block;\r\n vertical-align: middle;\r\n}", ""]); /***/ }), /***/ 3970: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-textarea2 {\r\n overflow: hidden;\r\n resize: none;\r\n box-sizing: border-box;\r\n --content-height: 1.425em;\r\n height: var(--content-height);\r\n font: inherit;\r\n}\r\n\r\n.absol-textarea2.as-border-none {\r\n border: none;\r\n outline: none;\r\n}\r\n\r\n.absol-textarea2:disabled {\r\n background-color: var(--as-disabled-background-color);\r\n}", ""]); /***/ }), /***/ 6690: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-text-clipboard {\r\n opacity: 0;\r\n font-size: 1px;\r\n height: 1px;\r\n width: 1px;\r\n}", ""]); /***/ }), /***/ 466: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".ac-time-input {\r\n box-sizing: border-box;\r\n height: calc(2em + 2px);\r\n width: 9em;\r\n border: solid 1px #d6d6d6;\r\n border-radius: 2px;\r\n font-size: 1rem;\r\n outline: none;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n display: inline-block;\r\n vertical-align: middle;\r\n background-color: white;\r\n position: relative;\r\n}\r\n\r\n.ac-time-input.as-disabled {\r\n color: rgb(102, 102, 102);\r\n pointer-events: none;\r\n}\r\n\r\n.ac-time-input.as-must-not-null .as-time-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n.ac-time-input.as-read-only.as-border-none {\r\n border: none;\r\n}\r\n\r\n.ac-time-input.as-read-only.as-border-none .as-time-input-icon-btn {\r\n display: none;\r\n}\r\n\r\n.ac-time-input.as-read-only.as-border-none input {\r\n padding-left: 0;\r\n}\r\n\r\n.ac-time-input input {\r\n font: inherit;\r\n outline: none;\r\n width: calc(100% - 2em - 2px);\r\n height: 100%;\r\n border: none;\r\n display: block;\r\n padding: 0 0 0 var(--as-input-horizontal-padding);\r\n -webkit-user-select: auto;\r\n user-select: auto;\r\n -webkit-user-drag: none;\r\n color: inherit;\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n}\r\n\r\n.ac-time-input.as-disabled {\r\n background-color: var(--as-disabled-background-color);\r\n}\r\n\r\n.as-time-input-icon-btn {\r\n border-right: none;\r\n border-top: none;\r\n border-bottom: none;\r\n border-left: 1px solid #ddd;\r\n position: absolute;\r\n padding: 0;\r\n top: 0;\r\n bottom: 0;\r\n right: 0;\r\n width: calc(2em + 1px);\r\n box-sizing: border-box;\r\n background-color: rgba(169, 169, 169, 0.1);\r\n cursor: pointer;\r\n border-radius: 0;\r\n font-size: inherit;\r\n color: inherit;\r\n}\r\n\r\n.ac-time-input.as-read-only .as-time-input-icon-btn {\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-time-input-icon-btn > span {\r\n font-size: calc(16em / 14);\r\n}\r\n\r\n\r\n.as-time-input-icon-btn:hover {\r\n background-color: rgba(169, 169, 169, 0.25);\r\n}\r\n\r\n.as-time-input-icon-btn:active {\r\n background-color: rgba(169, 169, 169, 0.5);\r\n}\r\n\r\n\r\n.as-time-input-icon-btn.as-disabled {\r\n color: rgb(102, 102, 102);\r\n pointer-events: none;\r\n}\r\n\r\n\r\n.as-time-input-clear-btn {\r\n font-size: inherit;\r\n position: absolute;\r\n right: calc(2em + 2px);\r\n height: 2em;\r\n top: calc(50% - 1em);\r\n box-sizing: border-box;\r\n background-color: transparent;\r\n border: none;\r\n color: #bbb;\r\n visibility: hidden;\r\n}\r\n\r\n\r\n.ac-time-input.as-value-null .as-time-input-clear-btn {\r\n display: none;\r\n}\r\n\r\n.as-time-input-clear-btn:hover {\r\n color: rgb(132, 132, 132);\r\n}\r\n\r\n.as-time-input-clear-btn:active {\r\n color: #525555;\r\n}\r\n\r\ninput:focus + .as-time-input-clear-btn,\r\n.ac-time-input .as-time-input-clear-btn {\r\n visibility: visible;\r\n}\r\n\r\n.as-dropdown-box-common-style .as-time-input-picker {\r\n border: none;\r\n box-shadow: none;\r\n}\r\n\r\n\r\n/*.ac-time-input-picker-ctn {*/\r\n/* position: fixed;*/\r\n/*}*/\r\n\r\n/*.ac-time-input > span {*/\r\n/* font-size: 1em;*/\r\n/* line-height: 2em;*/\r\n/*}*/\r\n\r\n/*.ac-time-input-picker-ctn-hidden {*/\r\n/* z-index: -1000;*/\r\n/* opacity: 0;*/\r\n/* visibility: hidden;*/\r\n/*}*/\r\n\r\n/*.ac-time-input-picker-ctn-hidden:not(.absol-follower) {*/\r\n/* transition: all 0.1s;*/\r\n/*}*/\r\n\r\n/*.ac-time-input.as-disabled {*/\r\n/* color: rgb(102, 102, 102);*/\r\n/* pointer-events: none;*/\r\n/*}*/", ""]); /***/ }), /***/ 449: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".ac-time-picker {\r\n /*like chrome-calender*/\r\n display: inline-block;\r\n font-family: Arial, Helvetica, sans-serif;\r\n font-size: 1rem;\r\n padding: 0.6em;\r\n border: solid 1px rgb(191, 191, 191);\r\n box-shadow: 1px 1px 2px rgb(240, 240, 240);\r\n z-index: 100;\r\n touch-action: manipulation;\r\n user-select: none;\r\n background-color: rgb(255, 255, 255);\r\n white-space: initial;\r\n}\r\n\r\n\r\n@media screen and (orientation: portrait) {\r\n .ac-time-picker.ac-time-picker-touch {\r\n font-size: 5vw;\r\n }\r\n}\r\n\r\n@media screen and (orientation: landscape) {\r\n .ac-time-picker.ac-time-picker-touch {\r\n font-size: 4vh;\r\n }\r\n}\r\n\r\n\r\n.ac-time-picker:not(.ac-time-picker-clock-mode) .ac-time-picker-set-clock,\r\n.ac-time-picker:not(.ac-time-picker-clock-mode) .ac-time-picker-keyboard-btn,\r\n.ac-time-picker:not(.ac-time-picker-touch) .ac-time-picker-keyboard-btn,\r\n.ac-time-picker:not(.ac-time-picker-time-mode) .ac-time-picker-set-time,\r\n.ac-time-picker:not(.ac-time-picker-time-mode) .ac-time-picker-clock-btn {\r\n display: none;\r\n}\r\n\r\n.ac-time-picker-set-clock-header {\r\n font-size: 2.8em;\r\n text-align: center;\r\n min-width: 4.28571428571em;\r\n font-weight: bold;\r\n\r\n}\r\n\r\n.ac-time-picker-set-clock-header > span {\r\n font-size: inherit;\r\n}\r\n\r\n.ac-time-picker-clock {\r\n width: 12em;\r\n height: 12em;\r\n}\r\n\r\n.ac-time-picker-clock-hour-pm {\r\n fill: rgb(20, 20, 20);\r\n font-size: 0.7em;\r\n}\r\n\r\n\r\n.ac-time-picker-clock-hour-am {\r\n fill: black;\r\n font-size: 0.8em;\r\n}\r\n\r\n.ac-time-picker-clock-minute {\r\n fill: black;\r\n font-size: 0.8em;\r\n}\r\n\r\n\r\n.ac-time-picker-clock-center,\r\n.ac-time-picker-clock-select-circle {\r\n fill: rgb(115, 166, 248);\r\n}\r\n\r\n.ac-time-picker-clock-select-center {\r\n fill: white;\r\n}\r\n\r\n.ac-time-picker-clock-select-line {\r\n stroke-width: 1;\r\n stroke: rgb(115, 166, 248);\r\n}\r\n\r\n\r\n.ac-time-picker-hour,\r\n.ac-time-picker-minute {\r\n outline: none;\r\n}\r\n\r\n.ac-time-picker-edit-hour .ac-time-picker-hour,\r\n.ac-time-picker-edit-minute .ac-time-picker-minute {\r\n color: rgb(62, 125, 189);\r\n}\r\n\r\n.ac-time-picker:not(.ac-time-picker-edit-hour) .ac-time-picker-clock-hour-ctn,\r\n.ac-time-picker:not(.ac-time-picker-edit-minute) .ac-time-picker-clock-minute-ctn {\r\n visibility: hidden;\r\n}\r\n\r\n.ac-time-picker:not(.ac-time-picker-edit-hour):not(.ac-time-picker-edit-minute) .ac-time-picker-clock {\r\n display: none;\r\n}\r\n\r\n.ac-time-picker-hour:empty::before,\r\n.ac-time-picker-minute:empty::before {\r\n content: \"0\";\r\n display: inline;\r\n}\r\n\r\n.ac-time-picker-footer {\r\n display: block;\r\n position: relative;\r\n min-height: 1.5em;\r\n min-width: 12em;\r\n}\r\n\r\n.ac-time-picker-footer-right {\r\n position: absolute;\r\n right: 0;\r\n top: 0;\r\n}\r\n\r\n.ac-time-picker-footer button {\r\n font-size: 1em;\r\n height: 1.5em;\r\n padding-top: 0;\r\n padding-bottom: 0;\r\n border: none;\r\n background-color: transparent;\r\n outline: none;\r\n padding-left: 0.3em;\r\n padding-right: 0.3em;\r\n}\r\n\r\n.ac-time-picker-footer button:hover,\r\n.ac-time-picker-footer button:focus {\r\n background-color: rgba(170, 170, 170, 0.3);\r\n}\r\n\r\n.ac-time-picker-footer > button {\r\n margin-right: 1em;\r\n}\r\n\r\n.ac-time-picker-footer-right > button {\r\n margin-left: 1em;\r\n}\r\n\r\n\r\n.ac-time-picker-footer button .mdi {\r\n font-size: 1.3em;\r\n}\r\n\r\n\r\n/* .ac-time-picker:not(.ac-time-picker-touch) .ac-time-picker-keyboard-btn {\r\n display: none;\r\n} */\r\n\r\n/* keyboard-outline */\r\n\r\n.ac-time-picker-set-time-header {\r\n font-size: 1.4em;\r\n font-weight: bold;\r\n margin-bottom: 1em;\r\n}\r\n\r\n.ac-time-picker-set-time-label {\r\n font-size: 1em;\r\n font-weight: bold;\r\n margin-bottom: 0.3em;\r\n}\r\n\r\n.ac-time-picker-set-time-input-group {\r\n margin-bottom: 0.3em;\r\n font-size: 1em;\r\n white-space: nowrap;\r\n}\r\n\r\n.ac-time-picker-set-time-input-hm > input {\r\n height: 1.2em;\r\n line-height: 1.2em;\r\n width: 2em;\r\n text-align: center;\r\n font-size: 1em;\r\n border-top: none;\r\n border-left: none;\r\n border-right: none;\r\n border-bottom: 1px solid rgb(70, 70, 72);\r\n outline: none;\r\n}\r\n\r\n.ac-time-picker-set-time-input-label-hm {\r\n font-size: 1em;\r\n white-space: nowrap;\r\n\r\n}\r\n\r\n.ac-time-picker-set-time-input-label-hm span {\r\n display: inline-block;\r\n vertical-align: middle;\r\n font-size: 1em;\r\n\r\n}\r\n\r\n\r\n.ac-time-picker-set-time-input-label-hm > span:first-child {\r\n width: 2em;\r\n}", ""]); /***/ }), /***/ 9838: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-time-range-24-input {\r\n white-space: nowrap;\r\n display: inline-block;\r\n min-width: 318px;\r\n}\r\n\r\n.as-time-range-24-input.as-read-only.as-border-none {\r\n min-width: unset;\r\n}\r\n\r\n.as-time-range-24-input > div:first-child {\r\n margin-right: 10px;\r\n}\r\n\r\n\r\n.as-time-range-24-input.as-read-only.as-border-none .ac-time-input {\r\n display: none;\r\n}\r\n\r\n.as-time-range-24-input.as-read-only.as-border-none::after{\r\n content: attr(data-text);\r\n vertical-align: middle;\r\n display: inline-block;\r\n}\r\n\r\n.as-time-range-24-input.as-read-only.as-border-none::before{\r\n content: \"\";\r\n vertical-align: middle;\r\n display: inline-block;\r\n height: calc(2em + 2px);\r\n}\r\n\r\n\r\n.as-chrome-time-24-picker-follower .as-chrome-time-24-picker {\r\n border: none;\r\n box-shadow: none;\r\n}", ""]); /***/ }), /***/ 1874: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-time-select-input {\r\n display: inline-block;\r\n position: relative;\r\n height: calc(2em + 2px);\r\n border: solid 1px #d6d6d6;\r\n border-radius: 2px;\r\n box-sizing: border-box;\r\n cursor: pointer;\r\n font-size: 1rem;\r\n outline: none;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n white-space: nowrap;\r\n padding-right: 30px;\r\n --list-min-width: unset;\r\n width: calc(var(--list-min-width) + 2em + 2px);\r\n min-width: calc(var(--list-min-width) + 2em + 2px);\r\n}\r\n\r\n.as-time-select-input.as-disabled {\r\n pointer-events: none;\r\n background-color: #ebebe4;\r\n}\r\n\r\n.as-time-select-input-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n width: 100%;\r\n outline: none;\r\n border: none;\r\n box-sizing: border-box;\r\n padding-left: 10px;\r\n padding-right: 0;\r\n background-color: transparent;\r\n font-size: inherit;\r\n}", ""]); /***/ }), /***/ 1531: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-toast-list {\r\n position: fixed;\r\n z-index: 1100000000;\r\n width: 25em;\r\n max-height: calc(100vh - 20px);\r\n overflow-y: auto;\r\n}\r\n\r\n.as-toast-list > .as-toast {\r\n box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.35);\r\n}\r\n\r\n\r\n.as-toast-list.as-se {\r\n bottom: 10px;\r\n right: 10px;\r\n}\r\n\r\n.as-toast-list.as-sw {\r\n bottom: 10px;\r\n left: 10px;\r\n}\r\n\r\n.as-toast-list.as-ne {\r\n top: 10px;\r\n right: 10px;\r\n}\r\n\r\n.as-toast-list.as-nw {\r\n top: 10px;\r\n left: 10px;\r\n}\r\n\r\n\r\n.as-toast-list.as-sc {\r\n bottom: 10px;\r\n left: calc(50% - 177px);\r\n}\r\n\r\n.as-toast-list:empty {\r\n visibility: hidden;\r\n}\r\n\r\n.as-toast-list.as-ne > .as-toast,\r\n.as-toast-list.as-nw > .as-toast {\r\n margin-bottom: 5px;\r\n}\r\n\r\n.as-toast-list.as-sc > .as-toast,\r\n.as-toast-list.as-se > .as-toast,\r\n.as-toast-list.as-sw > .as-toast {\r\n margin-top: 5px;\r\n}\r\n\r\n\r\n.as-toast {\r\n display: block;\r\n max-width: calc(100vw - 20px);\r\n overflow: hidden;\r\n background-color: white;\r\n background-clip: padding-box;\r\n border: 1px solid rgba(0, 0, 0, 0.1);\r\n font-family: Roboto, sans-serif;\r\n font-size: 1rem;\r\n}\r\n\r\n.as-toast-header {\r\n display: flex;\r\n display: -ms-flex;\r\n -ms-flex-align: center;\r\n align-items: center;\r\n padding: 0.25em 0.75em;\r\n color: #6c757d;\r\n background-clip: padding-box;\r\n border-bottom: 1px solid rgba(0, 0, 0, 0.05);\r\n}\r\n\r\n.as-toast-header strong {\r\n text-align: left;\r\n margin-right: auto;\r\n}\r\n\r\n.as-toast-variant-color {\r\n margin-right: 0.5em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n background-color: var(--variant-color-primary);\r\n width: 1.25em;\r\n height: 1.25em;\r\n}\r\n\r\n\r\n.as-toast-close-btn {\r\n padding: 0;\r\n background-color: transparent;\r\n border: none;\r\n outline: none;\r\n color: inherit;\r\n margin-left: 0.25em;\r\n margin-bottom: 0.25em;\r\n font-size: inherit;\r\n width: 24px;\r\n height: 24px;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-toast-close-btn:hover {\r\n color: black;\r\n background-color: var(--icon-background-cover-hover);\r\n}\r\n\r\n.as-toast-close-btn span {\r\n /*font-size: 1.5em;*/\r\n font-size: 20px;\r\n text-shadow: 0 1px 0 currentColor;\r\n}\r\n\r\n.as-toast-body {\r\n\r\n}\r\n\r\n.as-toast-message {\r\n padding: 0.75em;\r\n}\r\n\r\n\r\n.as-toast.as-not-appeared {\r\n opacity: 0;\r\n transition: opacity 0.2s;\r\n}\r\n\r\n.as-toast.as-not-appeared.as-appearing {\r\n opacity: 1;\r\n}\r\n\r\n.as-toast.as-appeared {\r\n transition: opacity 0.5s;\r\n opacity: 1;\r\n}\r\n\r\n.as-toast.as-disappearing {\r\n opacity: 0;\r\n}\r\n\r\n.as-toast.as-variant-sticky-note {\r\n background-color: #ffff88;\r\n}\r\n\r\n\r\n.as-toast.as-variant-sticky-note .as-toast-variant-color,\r\n.as-toast.as-variant-background .as-toast-variant-color {\r\n display: none;\r\n}\r\n\r\n.as-toast.as-variant-sticky-note .as-toast-title {\r\n color: #1e1ec8;\r\n}", ""]); /***/ }), /***/ 3573: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-toc-list {\r\n\r\n}\r\n\r\n.as-toc-list.as-searching .as-toc-list-body,\r\n.as-toc-list:not(.as-searching) .as-toc-list-searching {\r\n display: none;\r\n}\r\n\r\n.as-toc-item {\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n display: flex;\r\n height: 30px;\r\n align-items: stretch;\r\n --level: 0;\r\n}\r\n\r\n.as-toc-item:not(.as-status-close) .as-toc-item-toggle-ico-ctn .toggle-close,\r\n.as-toc-item:not(.as-status-open) .as-toc-item-toggle-ico-ctn .toggle-open {\r\n display: none;\r\n}\r\n\r\n.as-toc-item.as-status-none .as-toc-item-toggle-ico-ctn {\r\n visibility: hidden;\r\n}\r\n\r\n.as-toc-item.as-active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n\r\n.as-toc-item:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-toc-item > div {\r\n white-space: nowrap;\r\n width: 30px;\r\n}\r\n\r\n.as-toc-item > div::before,\r\n.as-toc-item > div > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-toc-item > div::before {\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-toc-item-name-ctn {\r\n flex-grow: 1;\r\n\r\n}\r\n\r\n.as-toc-item-name {\r\n user-select: none;\r\n max-width: 100%;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n}\r\n\r\ndiv.as-toc-item-toggle-ico-ctn {\r\n padding-left: calc(20px * var(--level));\r\n box-sizing: content-box !important;\r\n}\r\n\r\n.as-toc-item-toggle-ico-ctn .toggler-ico {\r\n width: 0.7em;\r\n height: 0.7em;\r\n}\r\n\r\n.as-toc-item-toggle-ico-ctn .toggler-ico path {\r\n fill: rgb(104, 104, 104);\r\n}\r\n\r\n.as-toc-item-ext-icon-ctn:empty {\r\n display: none;\r\n}\r\n\r\n.as-toc-item-ext-icon-ctn > img,\r\n.as-toc-item-ext-icon-ctn > svg {\r\n width: 20px;\r\n height: 20px;\r\n}\r\n\r\n.as-toc-item-ext-icon-ctn > span {\r\n font-size: 20px;\r\n}\r\n\r\n\r\n.as-toc-item-toggle-ico-ctn,\r\n.as-toc-item-check-ctn,\r\n.as-toc-item-quick-menu-ctn,\r\n.as-toc-item-ext-icon-ctn {\r\n text-align: center;\r\n width: 30px;\r\n}\r\n\r\n.as-toc-item-quick-menu-ctn span {\r\n font-size: 20px;\r\n}\r\n\r\n.as-toc-item-quick-menu-ctn button {\r\n border: none;\r\n background-color: transparent;\r\n padding: 0;\r\n width: 24px;\r\n height: 24px;\r\n}\r\n\r\n.as-toc-item-quick-menu-ctn button.as-quick-menu-attached {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.as-toc-item-quick-menu-ctn button:hover {\r\n background-color: var(--icon-background-cover-hover);\r\n}\r\n\r\n.as-toc-item:not(.as-has-quick-menu) .as-toc-item-quick-menu-ctn {\r\n visibility: hidden;\r\n pointer-events: none;\r\n opacity: 0;\r\n}\r\n\r\n.as-toc-item-name-ctn input {\r\n font: inherit;\r\n border: none;\r\n /*background-color: transparent;*/\r\n width: 8px;\r\n padding-left: 2px;\r\n padding-right: 2px;\r\n margin-left: -2px;\r\n margin-right: -2px;\r\n outline: none;\r\n box-sizing: content-box;\r\n background-color: #5bc0de;\r\n max-width: 100%;\r\n}\r\n\r\n.as-toc-item:not(.as-renaming) .as-toc-item-name-ctn input,\r\n.as-toc-item.as-renaming .as-toc-item-name {\r\n display: none;\r\n}\r\n", ""]); /***/ }), /***/ 7380: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-token-field {\r\n font-size: 1rem;\r\n border: 1px solid #dddddd;\r\n}\r\n\r\n.as-token-field-input-text {\r\n font: inherit;\r\n padding: 0;\r\n box-sizing: border-box;\r\n min-width: 4.3em;\r\n border: none;\r\n outline: none;\r\n height: var(--select-box-item-height);\r\n line-height: var(--select-box-item-height);\r\n vertical-align: top;\r\n margin-top: 2px;\r\n}\r\n\r\n.absol-selectbox-item.as-token-field-item {\r\n font: inherit;\r\n margin: 2px;\r\n outline: none;\r\n}\r\n\r\n.as-token-field-item:focus {\r\n background-color: var(--select-box-focus-item-color);\r\n}\r\n", ""]); /***/ }), /***/ 5623: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-tokenize-hyper-input {\r\n margin: 0;\r\n padding: 0;\r\n white-space: pre-wrap;\r\n -moz-user-modify: read-write;\r\n -webkit-user-modify: read-write;\r\n word-break: normal;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n}\r\n\r\n\r\n.as-emoji-token{\r\n font-size: inherit;\r\n overflow: hidden;\r\n box-sizing: border-box;\r\n display: inline;\r\n white-space: pre;\r\n background-size: 1.2em;\r\n background-position:left;\r\n background-repeat: no-repeat;\r\n}\r\n\r\n.as-tag-token{\r\n font-size: inherit;\r\n display: inline;\r\n white-space: pre;\r\n font-weight: bold;\r\n color: #1e1ec8;\r\n}\r\n\r\n\r\n\r\n", ""]); /***/ }), /***/ 1880: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --tool-tip-arrow-pos: 50%;\r\n --tool-tip-background-color: gray;\r\n --tool-tip-text-color: white;\r\n}\r\n\r\n.absol-tooltip {\r\n margin: 0;\r\n position: relative;\r\n box-sizing: border-box;\r\n display: inline-block;\r\n color: var(--tool-tip-text-color);\r\n}\r\n\r\n.absol-tooltip-content {\r\n display: block;\r\n border-radius: 0.25em;\r\n background-color: var(--tool-tip-background-color);\r\n padding: 0.25em 0.5em;\r\n font-size: inherit;\r\n}\r\n\r\n\r\n.absol-tooltip-arrow {\r\n width: 0;\r\n height: 0;\r\n position: absolute;\r\n box-sizing: content-box;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-tooltip.top .absol-tooltip-arrow {\r\n border-left: 0.4em solid transparent;\r\n border-right: 0.3em solid transparent;\r\n\r\n border-top: 0.3em solid var(--tool-tip-background-color);\r\n bottom: 0;\r\n left: calc(var(--tool-tip-arrow-pos) - 0.3em);\r\n}\r\n\r\n\r\n.absol-tooltip.top {\r\n padding-bottom: 0.28em;\r\n}\r\n\r\n\r\n.absol-tooltip.bottom .absol-tooltip-arrow {\r\n border-left: 0.3em solid transparent;\r\n border-right: 0.4em solid transparent;\r\n border-bottom: 0.3em solid var(--tool-tip-background-color);\r\n\r\n top: 0;\r\n left: calc(var(--tool-tip-arrow-pos) - 0.3em);\r\n}\r\n\r\n.absol-tooltip.bottom {\r\n padding-top: 0.28em;\r\n}\r\n\r\n\r\n.absol-tooltip.left .absol-tooltip-arrow {\r\n border-top: 0.3em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-left: 0.4em solid var(--tool-tip-background-color);\r\n\r\n right: 0;\r\n top: calc(var(--tool-tip-arrow-pos) - 0.3em);\r\n}\r\n\r\n.absol-tooltip.left {\r\n padding-right: 0.38em;\r\n}\r\n\r\n\r\n.absol-tooltip.right .absol-tooltip-arrow {\r\n border-top: 0.4em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-right: 0.4em solid var(--tool-tip-background-color);\r\n\r\n left: 0;\r\n top: calc(var(--tool-tip-arrow-pos) - 0.3em);\r\n}\r\n\r\n.absol-tooltip.ne .absol-tooltip-arrow {\r\n border-top: 0.3em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-left: 0.4em solid var(--tool-tip-background-color);\r\n bottom: -0.3em;\r\n left: 0;\r\n}\r\n\r\n.absol-tooltip.nw .absol-tooltip-arrow {\r\n border-top: 0.3em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-right: 0.4em solid var(--tool-tip-background-color);\r\n bottom: -0.3em;\r\n right: 0;\r\n}\r\n\r\n.absol-tooltip.se .absol-tooltip-arrow {\r\n border-top: 0.3em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-left: 0.4em solid var(--tool-tip-background-color);\r\n top: -0.3em;\r\n left: 0;\r\n}\r\n\r\n.absol-tooltip.sw .absol-tooltip-arrow {\r\n border-top: 0.3em solid transparent;\r\n border-bottom: 0.4em solid transparent;\r\n border-right: 0.4em solid var(--tool-tip-background-color);\r\n top: -0.25em;\r\n right: 0;\r\n}\r\n\r\n.absol-tooltip.right {\r\n padding-left: 0.38em;\r\n}\r\n\r\n\r\n.absol-tooltip-root {\r\n position: relative;\r\n width: 0;\r\n height: 0;\r\n}\r\n\r\n.absol-tooltip-root-holder {\r\n position: fixed;\r\n z-index: 100000000;\r\n left: 0;\r\n top: 0;\r\n}\r\n\r\n.as-copyable-icon-tooltip {\r\n font-size: inherit;\r\n display: inline-block;\r\n vertical-align: middle;\r\n color: #428bca;\r\n border: none;\r\n padding: 0;\r\n margin: 0;\r\n background-color: transparent;\r\n}\r\n\r\n.as-copyable-icon-tooltip:hover {\r\n background-color: var(--as-transparent-button-hover-color);\r\n}\r\n\r\n.as-copyable-icon-tooltip:active {\r\n background-color: var(--as-transparent-button-active-color);\r\n}\r\n\r\n.as-cit-icon {\r\n font-size: inherit;\r\n color: inherit;\r\n display: block;\r\n}\r\n\r\n.as-cit-icon::before {\r\n display: block;\r\n}\r\n", ""]); /***/ }), /***/ 5418: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-trackbar {\r\n height: 1.2em;\r\n min-width: 7em;\r\n display: inline-block;\r\n vertical-align: middle;\r\n -webkit-touch-callout: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n user-select: none;\r\n padding: 0 0.6em;\r\n box-sizing: border-box;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-trackbar::before {\r\n content: \"\";\r\n display: inline-block;\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.absol-trackbar-line {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 100%;\r\n position: relative;\r\n height: 0.4em;\r\n box-sizing: border-box;\r\n background-color: rgb(200, 200, 200);\r\n -webkit-box-shadow: 0 0 0.2em 0.1em rgb(160, 160, 160) inset;\r\n -moz-box-shadow: 0 0 0.2em 0.1em rgb(160, 160, 160) inset;\r\n box-shadow: 0 0 0.2em 0.1em rgb(160, 160, 160) inset;\r\n border-radius: 0.15em;\r\n}\r\n\r\n.absol-trackbar-button {\r\n position: absolute;\r\n z-index: 1;\r\n top: -0.4em;\r\n /* bottom: -0.4em; */\r\n height: 1.2em;\r\n left: 0;\r\n width: 1.2em;\r\n margin-left: -0.6em ;\r\n background: rgb(245, 245, 245);\r\n border-radius: 50%;\r\n border: solid 1px rgb(139, 139, 139);\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-trackbar:not(.as-read-only) .absol-trackbar-button,\r\n.absol-trackbar:not(.as-read-only) .absol-trackbar-line {\r\n cursor: pointer;\r\n}\r\n\r\n.absol-trackbar.as-disabled {\r\n pointer-events: none;\r\n}\r\n\r\n.absol-trackbar.as-disabled .absol-trackbar-button {\r\n background: rgb(225, 225, 225);\r\n border: solid 1px rgb(200, 200, 200);\r\n}\r\n\r\n.absol-trackbar.as-disabled .absol-trackbar-line {\r\n background-color: rgb(220, 220, 220);\r\n -webkit-box-shadow: 0 0 0.2em 0.1em rgb(200, 200, 200) inset;\r\n -moz-box-shadow: 0 0 0.2em 0.1em rgb(200, 200, 200) inset;\r\n box-shadow: 0 0 0.2em 0.1em rgb(200, 200, 200) inset;\r\n}", ""]); /***/ }), /***/ 7242: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-trackbar-input {\r\n box-sizing: border-box;\r\n display: inline-block;\r\n white-space: nowrap;\r\n position: relative;\r\n min-width: 13.5em;\r\n height: 2em;\r\n --input-width: 4em;\r\n font-size: 1rem;\r\n}\r\n\r\n.absol-trackbar-input::after {\r\n content: \"\";\r\n vertical-align: middle;\r\n height: 100%;\r\n}\r\n\r\n.absol-trackbar-input > .absol-trackbar {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: calc(100% - var(--input-width) - 5px);\r\n}\r\n\r\n\r\n.absol-trackbar-input > .as-flexicon-input {\r\n width: var(--input-width);\r\n vertical-align: middle;\r\n height: 2em;\r\n box-sizing: border-box;\r\n margin-left: 5px;\r\n}\r\n\r\n.absol-trackbar-input.as-disabled {\r\n pointer-events: none;\r\n color: #777777;\r\n\r\n}\r\n\r\n.absol-trackbar-input input {\r\n color: inherit;\r\n font-size: inherit;\r\n}\r\n\r\n.absol-trackbar-input.as-border-none .as-flexicon-input {\r\n border: none;\r\n}", ""]); /***/ }), /***/ 389: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-tree-chart * {\r\n box-sizing: border-box;\r\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\r\n\r\n}\r\n\r\n.as-tree-chart {\r\n --root-background-color: #ED7D31;\r\n --root-text-color: white;\r\n\r\n --vert-node-background-color: #4472C4;\r\n --vert-node-text-color: white;\r\n\r\n --horz-node-background-color: #A9D18E;\r\n --horz-node-text-color: black;\r\n\r\n --leaf-node-background-color: #F8CBAD;\r\n --leaf-node-text-color: black;\r\n\r\n\r\n font-size: 1rem;\r\n display: inline-block;\r\n}\r\n\r\n.as-tree-chart-node {\r\n display: inline-block;\r\n white-space: normal;\r\n vertical-align: top;\r\n position: relative;\r\n}\r\n\r\n.as-tree-chart-content-ctn {\r\n text-align: center;\r\n position: relative;\r\n}\r\n\r\n.as-tree-chart-node[data-level=\"0\"] >.as-tree-chart-content-ctn> .as-tree-chart-content {\r\n background-color: var(--root-background-color);\r\n color: var(--root-text-color);\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-child-ctn .as-tree-chart-content{\r\n background-color: var(--horz-node-background-color);\r\n color: var(--horz-node-text-color);\r\n}\r\n\r\n.as-tree-chart-node.as-is-leaf >.as-tree-chart-content-ctn> .as-tree-chart-content {\r\n background-color: var(--leaf-node-background-color);\r\n color: var(--leaf-node-text-color);\r\n}\r\n\r\n\r\n\r\n.as-tree-chart-content {\r\n padding: 5px;\r\n border-radius: 4px;\r\n border: 1px solid black;\r\n text-align: center;\r\n position: relative;\r\n display: inline-block;\r\n background-color: var(--vert-node-background-color);\r\n color: var(--vert-node-text-color);\r\n}\r\n\r\n.as-tree-chart-icon,\r\n.as-tree-chart-text {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-tree-chart-icon {\r\n font-size: 1.25em;\r\n padding-right: 0.25em;\r\n}\r\n\r\n.as-tree-chart-node.as-has-children > .as-tree-chart-content-ctn {\r\n padding-bottom: 10px;\r\n}\r\n\r\n.as-tree-chart-node.as-has-children > .as-tree-chart-content-ctn::after {\r\n content: \"\";\r\n position: absolute;\r\n bottom: 0;\r\n left: 50%;\r\n height: 10px;\r\n border-left: 1px solid black;\r\n}\r\n\r\n.as-tree-chart-child-ctn {\r\n white-space: nowrap;\r\n padding-top: 10px;\r\n text-align: center;\r\n vertical-align: top;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-tree-chart-node:not(.as-horizontal) > .as-tree-chart-child-ctn > .as-tree-chart-node:not(:last-child) {\r\n margin-right: 10px;\r\n}\r\n\r\n.as-tree-chart-child-ctn > .as-tree-chart-node:not(:first-child):not(:last-child)::before {\r\n content: \"\";\r\n border-top: 1px solid black;\r\n position: absolute;\r\n left: 0;\r\n right: -10px;\r\n top: -10px;\r\n}\r\n\r\n.as-tree-chart-child-ctn > .as-tree-chart-node:first-child:not(:last-child)::before {\r\n content: \"\";\r\n border-top: 1px solid black;\r\n position: absolute;\r\n left: 50%;\r\n right: -10px;\r\n top: -10px;\r\n}\r\n\r\n.as-tree-chart-child-ctn > .as-tree-chart-node > .as-tree-chart-content-ctn .as-tree-chart-content::before {\r\n content: \"\";\r\n position: absolute;\r\n left: 50%;\r\n height: 10px;\r\n top: -11px;\r\n border-left: 1px solid black;\r\n}\r\n\r\n.as-tree-chart-child-ctn > .as-tree-chart-node:not(:first-child):last-child > .as-tree-chart-content-ctn::before {\r\n content: \"\";\r\n border-top: 1px solid black;\r\n position: absolute;\r\n left: 0;\r\n width: calc(50% + 1px);\r\n top: -10px;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-child-ctn .as-tree-chart-content {\r\n text-align: left;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal > .as-tree-chart-content-ctn .as-tree-chart-content {\r\n display: block;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-node {\r\n display: block;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-child-ctn {\r\n padding-left: 20px;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-child-ctn .as-tree-chart-content-ctn {\r\n text-align: left;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-content-ctn::after {\r\n left: 10px;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-node:not(:last-child)::before {\r\n right: unset;\r\n bottom: 0;\r\n border-top: none;\r\n border-left: 1px solid black;\r\n left: -10px;\r\n height: unset;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-child-ctn > .as-tree-chart-node > .as-tree-chart-content-ctn .as-tree-chart-content::before {\r\n border-left: none;\r\n border-top: 1px solid black;\r\n left: -10px;\r\n width: 10px;\r\n top: 50%;\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-node:last-child > .as-tree-chart-content-ctn::before {\r\n content: \"\";\r\n position: absolute;\r\n left: -10px;\r\n top: -10px;\r\n height: calc(50% + 10px);\r\n border-top: none;\r\n border-left: 1px solid black;\r\n /*width: unset;*/\r\n}\r\n\r\n.as-tree-chart-node.as-horizontal .as-tree-chart-node.as-has-children:last-child > .as-tree-chart-content-ctn::before {\r\n height: calc(50% + 5px);\r\n /*width: unset;*/\r\n}\r\n", ""]); /***/ }), /***/ 6332: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-tree-list {}\r\n\r\n.absol-tree-list-item {}\r\n\r\n.absol-tree-list-item-parent:hover {\r\n background: #efefef;\r\n cursor: pointer;\r\n}\r\n\r\n.absol-tree-list-item-parent {\r\n padding-left: 0.3em;\r\n padding-right: 0.6em;\r\n position: relative;\r\n}\r\n\r\n.absol-tree-list-item.active>.absol-tree-list-item-parent {\r\n background: #dfdfdf;\r\n}\r\n\r\n.absol-tree-list-item-parent>span {\r\n line-height: 20px;\r\n white-space: nowrap;\r\n}\r\n\r\n.absol-tree-list-item-child {}\r\n\r\n.absol-tree-list-item>.absol-tree-list-item-child:empty {\r\n display: none;\r\n}\r\n\r\n.absol-tree-list-item-desc-container {\r\n right: 0.3em;\r\n top: 0;\r\n bottom: 0;\r\n position: absolute;\r\n}\r\n\r\n.absol-tree-list-item-desc {\r\n font-style: italic;\r\n line-height: 20px;\r\n white-space: nowrap;\r\n margin-left: 1em;\r\n color: rgb(37, 37, 37);\r\n}\r\n\r\n.absol-tree-list-item-desc:empty {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 2889: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.as-tree-table {\r\n font-size: 1rem;\r\n font-family: Arial, Helvetica, sans-serif;\r\n border-collapse: collapse;\r\n}\r\n\r\n.as-tree-table-toggle {\r\n position: absolute;\r\n left: 5px;\r\n top: 0;\r\n bottom: 0;\r\n vertical-align: middle;\r\n padding-right: 0.3em;\r\n white-space: nowrap;\r\n user-select: none;\r\n}\r\n\r\n\r\n\r\n.as-tree-table-toggle::before {\r\n display: inline-block;\r\n vertical-align: middle;\r\n content: \"\";\r\n height: 100%;\r\n}\r\n\r\n.as-tree-table-head {\r\n background-color: #d6d6d6;\r\n}\r\n\r\n\r\n.as-tree-table-head-cell {\r\n font-weight: bold;\r\n padding: 10px;\r\n border: 1px solid #ddd;\r\n position: relative;\r\n}\r\n\r\n\r\n.as-tree-table-row {\r\n height: calc(40em / 14);\r\n page-break-inside: avoid;\r\n break-inside: avoid;\r\n}\r\n\r\n.as-tree-table-row:nth-child(odd) {\r\n background-color: rgb(245, 245, 245);\r\n}\r\n\r\n.as-tree-table-row:nth-child(even) {\r\n background-color: white;\r\n}\r\n\r\n.as-tree-table-cell {\r\n padding: 5px;\r\n border: 1px solid #ddd;\r\n position: relative;\r\n page-break-inside: avoid;\r\n break-inside: avoid;\r\n}\r\n\r\n.as-tree-table-cell[data-type=\"number\"] {\r\n text-align: right;\r\n}\r\n\r\n.as-tree-table-row.as-is-opened .as-tree-table-toggle .toggle-close,\r\n.as-tree-table-row:not(.as-is-opened) .as-tree-table-toggle .toggle-open {\r\n display: none;\r\n}\r\n\r\n.as-tree-table-toggle .toggler-ico {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n\r\n\r\n.as-tree-table-row:not(.as-has-sub-row) .as-tree-table-toggle .toggler-ico {\r\n visibility: hidden;\r\n}\r\n\r\n/*.as-tree-table-row {*/\r\n/* height: var(--table-row-height);*/\r\n/*}*/\r\n\r\n.as-printer-content .as-tree-table-toggle svg{\r\n display: none;\r\n}\r\n\r\n.as-printer-content .as-tree-table-head-cell,\r\n.as-printer-content .as-tree-table-cell{\r\n border-color: black;\r\n}\r\n\r\n.as-tree-table-cell>span:first-child:last-child{\r\n page-break-inside: avoid;\r\n break-inside: avoid;\r\n}\r\n\r\n@media print {\r\n div[align=\"center\"]> .as-tree-table{\r\n display: block !important;\r\n }\r\n /*trick avoid break row*/\r\n .as-tree-table tbody tr td:before,\r\n .as-tree-table tbody tr td:after {\r\n content: \"\";\r\n height: 4px;\r\n display: block;\r\n }\r\n\r\n .as-tree-table-head {\r\n display: table-header-group !important;\r\n }\r\n\r\n .as-tree-table-head + tbody tr:first-child th {\r\n display: none;\r\n }\r\n}", ""]); /***/ }), /***/ 5995: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --variant-color-primary: #007bff;\r\n --variant-color-secondary: #6c757d;\r\n --variant-color-success: #28a745;\r\n --variant-color-warning: #ffc107;\r\n --variant-color-danger: #dc3545;\r\n --variant-color-info: #17a2b8;\r\n --variant-color-light: #f8f9fa;\r\n --variant-color-dark: #343a40;\r\n --variant-color-error: #ff4052;\r\n --variant-color-link: #007bff;\r\n --variant-color-note: #ffff88;\r\n\r\n\r\n --variant-medium-contract-color-primary: #e2edd5;\r\n --variant-medium-contract-color-secondary: #fca75b;\r\n --variant-medium-contract-color-success: #fce8e8;\r\n --variant-medium-contract-color-info: #fcf5e8;\r\n --variant-medium-contract-color-warning: #5e5a75;\r\n --variant-medium-contract-color-error:#e0dfce;\r\n --variant-medium-contract-color-danger: #e5e8d5;\r\n --variant-medium-contract-color-light: #7a5b3c;\r\n --variant-medium-contract-color-dark: #bf7d3b;\r\n --variant-medium-contract-color-link: #dde8c9;\r\n --variant-medium-contract-color-note: #1e1ec8;\r\n}", ""]); /***/ }), /***/ 3396: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ":root {\r\n --as-vertical-timeline-item-height: 40px;\r\n}\r\n\r\n.as-vertical-timeline {\r\n display: inline-block;\r\n color: white;\r\n font-size: 14px;\r\n font-family: Arial, Helvetica, sans-serif;\r\n text-align: left;\r\n padding: 5px;\r\n}\r\n\r\n.as-vertical-timeline-item {\r\n height: var(--as-vertical-timeline-item-height);\r\n white-space: nowrap;\r\n}\r\n\r\n.as-vertical-timeline-item.as-inactive {\r\n color: rgba(200, 200, 200, 0.5);\r\n}\r\n\r\n.as-vertical-timeline-item.as-active .as-vertical-timeline-tile {\r\n text-shadow: 1px 0 0 currentColor;\r\n}\r\n\r\n.as-vertical-timeline-item:not(:first-child) .as-vertical-timeline-icon-ctn::before {\r\n content: \"\";\r\n display: inline-block;\r\n height: calc(var(--as-vertical-timeline-item-height) - 30px);\r\n border-left: 2px solid currentColor;\r\n position: absolute;\r\n left: calc(50% - 1px);\r\n bottom: calc(100% + 2px);\r\n}\r\n\r\n\r\n.as-vertical-timeline-icon-ctn {\r\n display: inline-block;\r\n margin-right: 20px;\r\n position: relative;\r\n vertical-align: middle;\r\n\r\n}\r\n\r\n.as-vertical-timeline-icon-ctn span {\r\n font-size: 24px;\r\n}\r\n\r\n\r\n.as-vertical-timeline-tile {\r\n display: inline-block;\r\n vertical-align: middle;\r\n\r\n}\r\n\r\n\r\n/*//check-circle*/", ""]); /***/ }), /***/ 7829: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-vertical-tree-diagram {\r\n --node-name-max-width: 200px;\r\n}\r\n\r\n\r\n.as-vertical-tree-diagram-node {\r\n\r\n}\r\n\r\n.template-ctn {\r\n display: none;\r\n}\r\n\r\n.as-vertical-tree-diagram-node, .as-vertical-tree-diagram-node * {\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-vertical-tree-diagram-node {\r\n display: inline-block;\r\n vertical-align: top;\r\n position: relative;\r\n background: white;\r\n}\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node:not(:first-child) {\r\n margin-left: 10px;\r\n}\r\n\r\n.as-vertical-tree-diagram-node-name-ctn {\r\n text-align: center;\r\n padding-bottom: 9px;\r\n}\r\n\r\n.as-vertical-tree-diagram-node-name {\r\n display: inline-block;\r\n padding: 5px;\r\n border: 1px solid #333;\r\n position: relative;\r\n white-space: normal;\r\n max-width: var(--node-name-max-width);\r\n}\r\n\r\n.as-vertical-tree-diagram-node.as-has-child > .as-vertical-tree-diagram-node-name-ctn .as-vertical-tree-diagram-node-name::before {\r\n content: \"\";\r\n position: absolute;\r\n height: 10px;\r\n left: 50%;\r\n top: 100%;\r\n border-left: 1px solid #333;\r\n}\r\n\r\n.as-vertical-tree-diagram-node.as-has-child.as-has-1-child > .as-vertical-tree-diagram-node-name-ctn .as-vertical-tree-diagram-node-name::before {\r\n height: 20px;\r\n}\r\n\r\n.as-vertical-tree-diagram-child-ctn {\r\n padding-top: 10px;\r\n\r\n}\r\n\r\n.as-vertical-tree-diagram-node:not(.as-has-1-child) > .as-vertical-tree-diagram-child-ctn {\r\n border-top: 1px solid #333;\r\n}\r\n\r\n.as-vertical-tree-diagram-node:not(.as-has-child) > .as-vertical-tree-diagram-child-ctn {\r\n display: none;\r\n}\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node::before {\r\n content: \"\";\r\n position: absolute;\r\n z-index: 1;\r\n left: 50%;\r\n bottom: 100%;\r\n height: 10px;\r\n border-left: 1px solid black;\r\n}\r\n\r\n.as-vertical-tree-diagram-node.as-has-1-child > .as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node::before,\r\n.as-vertical-tree-diagram-node.as-has-1-child > .as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node::after {\r\n display: none;\r\n}\r\n\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node:last-child::before {\r\n left: unset;\r\n right: 50%;\r\n}\r\n\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node:first-child::after {\r\n content: \"\";\r\n position: absolute;\r\n z-index: 2;\r\n right: 50%;\r\n left: 0;\r\n bottom: 100%;\r\n height: 11px;\r\n background-color: white;\r\n}\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node:last-child::after {\r\n content: \"\";\r\n position: absolute;\r\n z-index: 2;\r\n left: 50%;\r\n right: 0;\r\n bottom: 100%;\r\n height: 11px;\r\n background-color: white;\r\n}\r\n\r\n.as-vertical-tree-diagram-child-ctn > .as-vertical-tree-diagram-node:first-child:last-child::after {\r\n display: none;\r\n}", ""]); /***/ }), /***/ 2872: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\r\n.as-video-url-dialog-url {\r\n max-width: calc(100vw - 8em - 40px);\r\n width: 500px;\r\n min-height: 30px;\r\n box-sizing: border-box;\r\n}\r\n\r\n.as-video-url-dialog input[type=\"number\"] {\r\n width: 5em;\r\n}\r\n\r\n.as-video-url-dialog-row> label {\r\n display: inline-block;\r\n vertical-align: middle;\r\n width: 6em;\r\n}\r\n\r\n.as-video-url-dialog-row {\r\n padding-bottom: 10px;\r\n white-space: pre;\r\n}\r\n\r\n.as-video-url-dialog-row > * {\r\n display: inline-block;\r\n vertical-align: middle;\r\n}\r\n\r\n.as-video-url-dialog-video-image{\r\n max-width: 200px;\r\n max-height: 200px;\r\n\r\n}", ""]); /***/ }), /***/ 9163: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "/*margin for border size*/\r\n.as-vruler {\r\n position: relative;\r\n width: 1.5em;\r\n border: solid 1px black;\r\n overflow: hidden;\r\n font-family: courier, \"courier new\", monospace;\r\n box-sizing: border-box;\r\n}\r\n\r\n\r\n.as-vruler-line {\r\n position: absolute;\r\n right: 0;\r\n width: 25%;\r\n border-top: solid 1px rgb(17, 48, 43);\r\n box-sizing: border-box;\r\n\r\n}\r\n\r\n.as-vruler-line.major {\r\n width: 50%;\r\n border-top: solid 1px rgb(5, 20, 18);\r\n}\r\n\r\n.as-vruler-major-number {\r\n position: absolute;\r\n text-align: center;\r\n width: 5em;\r\n pointer-events: none;\r\n font-size: 0.7em;\r\n right: calc(52% - 2em);\r\n height: 1em;\r\n transform-origin: center;\r\n \r\n -webkit-transform:rotate(90deg);\r\n -moz-transform:rotate(90deg);\r\n -o-transform: rotate(90deg);\r\n -ms-transform:rotate(90deg);\r\n transform: rotate(-90deg);\r\n}", ""]); /***/ }), /***/ 7366: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".absol-width-height-resizer {\r\n position: relative;\r\n box-sizing: border-box;\r\n}\r\n\r\n.absol-width-height-resizer-anchor-bot-right {\r\n cursor: nwse-resize;\r\n position: absolute;\r\n z-index: 1;\r\n right: 0;\r\n bottom: 0;\r\n height: 13px;\r\n width: 13px;\r\n background-image: url('');\r\n}\r\n\r\n.absol-width-height-resizer-anchor-bot-left {\r\n cursor: nesw-resize;\r\n position: absolute;\r\n z-index: 1;\r\n left: 0;\r\n bottom: 0;\r\n height: 13px;\r\n width: 13px;\r\n background-image: url('');\r\n}\r\n\r\n.absol-width-height-resizer-anchor-top-right {\r\n cursor: nesw-resize;\r\n position: absolute;\r\n z-index: 1;\r\n right: 0;\r\n top: 0;\r\n height: 13px;\r\n width: 13px;\r\n background-image: url('')\r\n}\r\n\r\n.absol-width-height-resizer-anchor-top-left {\r\n cursor: nwse-resize;\r\n position: absolute;\r\n z-index: 1;\r\n top: 0;\r\n left: 0;\r\n height: 13px;\r\n width: 13px;\r\n background-image: url('');\r\n}\r\n\r\n.absol-width-height-resizer-content {\r\n width: 100%;\r\n height: 100%;\r\n overflow: auto;\r\n}\r\n\r\n/* .absol-width-height-resizer */", ""]); /***/ }), /***/ 8362: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-assessment-chart {\n /*border: 1px solid red;*/\n}\n\n\n.vc-assessment-chart.simple-mode .vc-assessment-chart-area,\n.vc-assessment-chart.vc-simple-mode .vc-assessment-chart-area {\n fill: none !important;\n}\n\n.vc-assessment-chart.simple-mode .vc-assessment-chart-level:not(.last),\n.vc-assessment-chart.vc-simple-mode .vc-assessment-chart-level:not(:last-child) {\n display: none;\n}\n\n.vc-assessment-chart:not(.show-range-segment) .vc-assessment-chart-range-segment {\n display: none;\n}\n\n.vc-assessment-chart-area {\n stroke-width: 3;\n}\n\n\n.vc-assessment-chart-level {\n fill: none;\n stroke-width: 1;\n stroke: rgba(12, 30, 49, 0.333)\n}\n\n\n.vc-assessment-chart-level-value text,\n.vc-assessment-chart-level-value {\n font-size: 10px;\n}\n\n.vc-assessment-chart-level-value rect {\n fill: rgba(255, 255, 255, 0.5);\n stroke: rgba(60, 60, 70, 0.6);\n stroke-width: 1;\n}\n\n.vc-assessment-chart-range-plot {\n fill: #155757d8;\n}\n\n.vc-assessment-chart-range-line {\n stroke: #155757d8;\n stroke-width: 3;\n}\n\n.vc-assessment-chart-range-area {\n fill: rgba(200, 200, 0, 0.3);\n stroke: none;\n}\n\n.vc-assessment-chart-range-area-stroke {\n fill: none;\n stroke: rgb(255, 150, 0);\n stroke-width: 1.5;\n}", ""]); /***/ }), /***/ 7025: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-bar-stack-chart {\n\n}\n\n\n.vc-bar-stack-note-name {\n font-weight: bold;\n font-size: 16px;\n}\n\n.vc-bar-stack-block-value {\n font-size: 25px;\n text-anchor: middle;\n}\n\n.vc-bar-stack-block-percent {\n text-anchor: middle;\n font-size: 20px;\n}", ""]); /***/ }), /***/ 671: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-title {\n font-weight: bold;\n font-size: 1.125em;\n text-anchor: middle;\n}\n\n\n.vc-chart {\n font-family: \"Helvetica Neue\", Arial, Helvetica, sans-serif;\n font-size: 14px;\n background-color: white;\n --vc-require-width: 100px;\n --vc-require-height: 200px;\n min-width: var(--vc-require-width);\n min-height: var(--vc-require-height);\n}\n\n.vc-oxy {\n fill: none;\n stroke: rgb(68, 114, 196);\n stroke-width: 1;\n}\n\n.vc-oxy-arrow {\n fill: rgb(68, 114, 196);\n stroke: none;\n}\n\n.vc-simple-ox {\n stroke-width: 1;\n}\n\n.vc-oy-value {\n text-anchor: end;\n}\n\n.vc-ox-label {\n text-anchor: middle;\n}\n\n.vc-white-mask {\n fill: white;\n}\n\n.vc-value-name,\n.vc-key-name {\n text-anchor: end;\n font-style: italic;\n}\n\n.vc-note {\n cursor: default;\n}\n\n.vc-note:hover text {\n fill: rgb(130, 135, 180);\n}\n\n.vc-value-text {\n text-anchor: middle;\n fill: currentColor;\n}\n\n.vc-grid {\n fill: none;\n stroke: #ddd;\n pointer-events: none;\n}\n\n@media print {\n .as-resize-box {\n display: none;\n }\n\n .vc-chart {\n max-width: 600px; /*a4 with 2in margin both*/\n height: auto;\n }\n\n}\n", ""]); /***/ }), /***/ 8392: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vchart-hidden{\n display: none;\n}\n\n.base-chart:not(:hover) .vchart-vscrollbar {\n display: none;\n}\n\n.vchart-hitbox{\n fill: rgba(0, 0, 0, 0);\n /* stroke: none; */\n}\n\n\n.vchart-debug .vchart-hitbox{\n fill: rgba(22, 129, 216, 0.247);\n stroke: rgba(22, 129, 216, 0.87);\n}\n\n\n.vchart-base{\n font-size: 14px;\n font-family: Arial;\n}\n\n\n.vchart-stroke-note-line {\n stroke-width: 2;\n}\n\n.vchart-stroke-note-text,\n.vchart-rect-note-text\n{\n font-size: 14px;\n}\n\n.vchart-rect-note-rect{\n stroke:none;\n}\n\nrect.vchart-node-grid-box{\n fill: burlywood;\n}", ""]); /***/ }), /***/ 8239: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".as-resize-box.vc-chart-resize-box {\n position: fixed;\n z-index: 8000000;\n user-select: none;\n}", ""]); /***/ }), /***/ 8658: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.vc-column rect {\n fill: rgb(123, 192, 247);\n}\n\n.column-chart:not(.vchart-show-inline-value) .column-chart-column text {\n display: none;\n}\n\n.vc-column.vc-value-zero text,\n.vc-chart:not(.vc-show-inline-value) .vc-column text {\n display: none;\n}", ""]); /***/ }), /***/ 154: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".av-funnel-chart {\n\n}\n\n.av-funnel {\n\n}\n\n.av-funnel-item-block {\n\n}\n\n.av-funnel-note-name {\n font-weight: bold;\n font-size: 16px;\n text-transform: uppercase;\n}\n\n.av-funnel-block-shape {\n stroke: white;\n stroke-width: 2;\n}\n\n.av-funnel-block-value {\n text-anchor: middle;\n font-size: 30px;\n}\n\n.av-funnel-block-percent{\n text-anchor: middle;\n font-size: 25px;\n}", ""]); /***/ }), /***/ 4964: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".grank-chart {\n font-size: 12px;\n font-family: Arial;\n}\n\n.grank-chart-plot {\n fill: rgb(145, 228, 251);\n stroke-width: 1;\n stroke: black;\n}\n\n.grank-chart-group-rect {\n stroke: black;\n fill: none;\n stroke-width: 1;\n}", ""]); /***/ }), /***/ 1708: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-horizontal-bar-chart {\n border: 1px solid black;\n font-size: 14px;\n}\n\n.vc-horizontal-bar-chart .base-chart-white-mask {\n /* fill: rgba(255, 0, 0, 0.4); */\n}\n\ng.vc-horizontal-bar-one-bar-note-container .vc-horizontal-bar-chart-bar {\n stroke: rgb(47, 82, 143);\n stroke-width: 1;\n fill: white;\n}\n\ng.vc-horizontal-bar-one-bar-note-container .vc-horizontal-bar-chart-range {\n stroke: rgb(47, 82, 143);\n stroke-width: 1;\n fill: rgb(157, 195, 230);\n}\n\ng.vc-horizontal-bar-one-bar-note-container {}\n\ng.vc-horizontal-bar-one-bar-note-container .vc-horizontal-bar-chart-range-min-line,\ng.vc-horizontal-bar-one-bar-note-container .vc-horizontal-bar-chart-range-max-line {\n stroke: rgb(47, 82, 143);\n stroke-width: 1px;\n stroke-dasharray: 2;\n}\n\n.vc-horizontal-bar-chart-key {\n text-anchor: end;\n}\n\ng.vc-horizontal-bar-keys-note-container {}\n\ng.vc-horizontal-bar-key-note {}\n\n\n\n.vc-horizontal-bar-chart-segment-text {\n text-anchor: middle;\n}\n\n\n.vc-horizontal-bar-chart-range {\n stroke: rgb(47, 82, 143);\n stroke-width: 1;\n}\n\n\ntext.vc-horizontal-bar-title {\n font-size: 15px;\n font-weight: bold;\n text-anchor: middle;\n}\n\n\n.vc-horizontal-bar-vline {\n stroke-width: 1;\n}\n\n\n.vc-horizontal-bar-chart-value-line {\n stroke: darkgray;\n stroke-width: 0.5;\n}\n\n.vc-horizontal-bar-vline-note>path {\n stroke-width: 2;\n}\n\n\n.vc-horizontal-bar-vline-note-box {\n stroke-width: 1;\n stroke: black;\n fill: none;\n}\n\n.vc-horizontal-bar-vline-container>path {\n stroke-width: 2;\n stroke: black;\n}", ""]); /***/ }), /***/ 6344: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".image-chart text{\n font-size: 14px;\n}\n\n.image-chart-ox {\n fill: none;\n stroke: #4472c4;\n stroke-width: 1;\n}\n\n.image-chart-base{\n fill:#7bc0f7;\n stroke: none;\n}\n\n.image-chart-bonus{\n fill:#ffcc7f;\n stroke: none;\n}\n\n.image-chart-range{\n stroke: black;\n stroke-width:1; \n}\n\n.image-chart-range-limit{\n fill: none;\n stroke: #000000;\n stroke-width: 1;\n}\n\n\n.image-chart.as-bonus-under-100-percent .image-chart-bonus {\n fill: #ff927f;\n}", ""]); /***/ }), /***/ 4561: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.line-chart-line {\n stroke-width: 2;\n fill: none;\n}\n\n.line-chart-plot {\n stroke: none;\n}\n\n.vc-line-chart.vc-small-col .vc-key {\n visibility: hidden;\n}\n\n.vc-line-chart .vc-plot {\n fill: var(--color);\n}\n\n.vc-line-path {\n stroke: var(--color);\n stroke-width: 2;\n fill: none;\n}\n\n.vc-line-hit-path {\n stroke-width: 6;\n fill: none;\n stroke: transparent;\n}\n\n.vc-line:hover .vc-line-hit-path{\n stroke: var(--lighter-color);\n}", ""]); /***/ }), /***/ 1132: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".mapping-chart{\n border: solid 1px gray;\n background-color: aliceblue;\n}\n\n.mapping-chart-map-line-hitbox.vchart-hitbox{\n stroke-width: 8;\n stroke: transparent;\n cursor: pointer;\n}\n\n.mapping-chart-range-text{\n stroke: none;\n fill: blue;\n font-size: 14px;\n}\n\n.mapping-chart-range-plot{\n fill:none;\n stroke: black;\n stroke-width: 2px;\n}\n\n.mapping-chart-line-plot{\n fill:green;\n stroke: red;\n stroke-width: 0.54;\n cursor: pointer;\n}\n\n.mapping-chart-title{\n font-size: 20px;\n fill: black;\n stroke: none;\n}\n\n.mapping-chart-range-line{\n stroke: black;\n stroke-width: 2px;\n}\n\n.mapping-chart-marker{\n font-size: 14px;\n /* cursor: pointer; */\n}\n\n.mapping-chart-marker:hover .mapping-chart-marker-box{\n /* fill: rgba(17, 230, 88, 0.788); */\n}\n\n.mapping-chart-marker-box{\n /* fill: rgba(17, 187, 230, 0.788); */\n fill: none;\n stroke: none;\n}\n\n\n\nsvg:not(.mapping-chart-hover-bot) .mapping-chart-marker.bot{\n visibility: hidden;\n}\n\n.mapping-chart-marker.bot:hover .mapping-chart-marker-box,\n.mapping-chart-marker.top:hover .mapping-chart-marker-box\n{\n /* fill: rgba(17, 187, 230, 0.788); */\n}\n\nsvg:not(.mapping-chart-hover-top) .mapping-chart-marker.top{\n visibility: hidden;\n}\n\n.mapping-chart-map-line{\n stroke: black;\n stroke-width: 2;\n}\n\n.mapping-chart-map-line.selected-line{\n stroke: red;\n}", ""]); /***/ }), /***/ 9799: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vchart-vscrollbar-bar{\n fill: rgba(0, 0, 0, 0.07); \n}\n\n.vchart-vscrollbar-button{\n fill:rgba(0, 0, 0, 0.1); ;\n}\n\n\n.vchart-segment-line,\n.vchart-axis,\n.vchart-line-arrow {\n stroke-width: 1;\n stroke: rgb(68, 114, 196);\n fill: rgb(68, 114, 196);\n}\n\n.vchart-scroll-arrow {\n touch-action: none;\n user-select: none;\n opacity: 0.2;\n}\n\n.vchart-scroll-arrow:hover {\n opacity: 0.6;\n}\n", ""]); /***/ }), /***/ 4596: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-note{\n\n}\n\n.vc-note-rect {\n stroke: none;\n}\n\n.vc-note-hit {\n fill: transparent;\n stroke: none;\n}\n\n.vc-note-line {\n stroke-width: 2;\n}\n\n.vc-note-text {\n font-size: 1em;\n}", ""]); /***/ }), /***/ 6660: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-piece{\n stroke-width: 1;\n stroke: white;\n}\n\n.vc-piece-value{\n font-size: 16px;\n text-anchor: middle;\n}", ""]); /***/ }), /***/ 9364: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-range-chart {\n box-sizing: border-box;\n}\n\n.base-chart,\n.range-chart {\n font-size: 12px;\n font-family: Arial, Helvetica, sans-serif;\n}\n\n\n.base-chart-title {\n font-size: 15px;\n}\n\n\n.range-chart:not(:hover) .vchart-vscrollbar {\n display: none;\n}\n\n.base-chart-title {\n font-size: 15px;\n font-weight: bold;\n}\n\n.base-chart-oxy-text {\n font-style: italic;\n fill: rgb(70, 70, 70);\n stroke: none;\n}\n\n.range-chart-value-plot {\n fill: #f7941d;\n stroke: none;\n}\n\n.range-chart-limit-line {\n stroke-width: 4;\n fill: none;\n}\n\n.range-chart-range-line {\n stroke-width: 1;\n fill: none;\n stroke: black;\n}\n\n.range-chart-limit-line.max {\n stroke: #2C82FF;\n}\n\n.range-chart-limit-line.mid {\n stroke: #58EBF4;\n}\n\n.range-chart-limit-line.min {\n stroke: #ED1C24;\n}\n\n.range-chart:not(.show-inline-value) .range-chart-inline-value {\n display: none;\n}\n\n/* .show-inline-value .range-chart-note, */\n\n.show-inline-value .range-char-note-value {\n display: none;\n}\n\n.vc-range-chart-label-full,\n.vc-range-chart-label-line,\n.vc-range-chart-label {\n text-anchor: middle;\n}\n\n.vc-range-chart.vc-ox-label-wrap .vc-range-chart-label-full,\n.vc-range-chart:not(.vc-ox-label-wrap) .vc-range-chart-label-line {\n display: none;\n}\n\n.vc-ox-value-ctn {\n text-anchor: end;\n}\n\n.vc-range-rect {\n fill: rgba(200, 230, 255, 0.5);\n}", ""]); /***/ }), /***/ 8642: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.range-group-chart-limit-line {\n stroke-width: 5;\n fill: none;\n}\n\n.range-group-chart-limit-line.max {\n stroke: rgb(230, 22, 16);\n}\n\n.range-group-chart-limit-line.min {\n stroke: rgb(20, 100, 246);\n}\n\n.range-group-chart-limit-line.normal {\n stroke: rgb(255, 218, 216);\n}\n\n.range-group-chart-plot {\n fill: rgb(145, 228, 251);\n stroke-width: 1;\n stroke: hsla(0, 90%, 48%, 0.685);\n}\n\n.range-group-chart-range-line {\n stroke-width: 1;\n fill: none;\n stroke: black;\n}", ""]); /***/ }), /***/ 7970: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.rank-chart-plot {\n stroke: black;\n stroke-width: 1;\n}\n\n.rank-chart-plot-text{\n cursor: default;\n}\n\n.rank-chart-position-rect,\n.vc-rank-position-list-rect {\n stroke: none;\n fill: rgba(0, 247, 255, 0.139);\n}", ""]); /***/ }), /***/ 9930: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vchart-resizable-div {\n position: relative;\n box-sizing: border-box;\n}\n\n.vchart-resizable-div .as-resize-box {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: none;\n}\n\n.vchart-resizable-div.vchart-resizable-div-active .as-resize-box {\n display: block;\n}", ""]); /***/ }), /***/ 1767: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-scroll-arrow-icon {\n fill: #00a5d6;\n user-select: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n}\n\n.vc-scroll-arrow-hit-box {\n fill: rgba(0, 0, 255, 0.03);\n}\n\n.vc-scroll-arrow:active .vc-scroll-arrow-hit-box {\n fill: rgba(0, 0, 255, 0.1);\n}", ""]); /***/ }), /***/ 1552: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "", ""]); /***/ }), /***/ 3001: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".correlation-chart-plot {\n stroke: rgba(0, 0, 0, 0.3);\n stroke-width: 1;\n}\n\n.correlation-chart-line {\n fill: none;\n stroke-width: 3;\n}\n\n.correlation-chart-normal-line {\n fill: none;\n stroke-width: 1;\n}\n\n.correlation-chart-plot.static {\n fill: rgba(85, 141, 218, 1);\n}\n\n.correlation-chart-line.static {\n stroke: rgba(85, 141, 218, 0.7);\n}\n\n.correlation-chart-normal-line.static {\n stroke: rgba(85, 141, 218, 0.5);\n}\n\n.correlation-chart-plot.dynamic {\n fill: rgba(255, 0, 0, 1);\n}\n\n.correlation-chart-line.dynamic {\n stroke: rgba(255, 0, 0, 0.7);\n}\n\n.correlation-chart-normal-line.dynamic {\n stroke: rgba(255, 0, 0, 0.7);\n}", ""]); /***/ }), /***/ 9396: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-stacked-horizontal-bar-chart {\r\n min-width: var(--vc-require-width);\r\n}", ""]); /***/ }), /***/ 2990: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.sunburst-chart .base-chart-title circle {\n fill: rgb(245, 203, 153);\n stroke: none;\n}\n\n.sunburst-chart-node-shape {\n fill: white;\n stroke-width: 2;\n stroke: rgb(247, 205, 155);\n}\n\n.vc-sunburst-node-name {\n font-size: 14px;\n}", ""]); /***/ }), /***/ 4614: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, ".vc-tiny-circle-blank {\r\n fill: rgb(168, 168, 168);\r\n stroke-width: 2;\r\n stroke: white;\r\n fill-rule: evenodd;\r\n}\r\n\r\n.vc-chart.vc-tiny-circle-chart {\r\n min-width: 250px;\r\n min-height: 100px;\r\n font-size: 1rem;\r\n}\r\n\r\n.vc-arc {\r\n stroke: white;\r\n stroke-width: 1;\r\n}", ""]); /***/ }), /***/ 4832: /***/ ((module, exports, __webpack_require__) => { exports = module.exports = __webpack_require__(3645)(false); // Module exports.push([module.id, "\n.vchart-tooltip-container {\n background-color: rgba(20, 20, 22, 1);\n color: rgb(231, 230, 157);\n position: absolute;\n white-space: nowrap;\n padding: 5px;\n line-height: 1.5;\n border-radius: 4px;\n bottom: 0;\n left: 0;\n}\n\n.vchart-tooltip-anchor {\n position: fixed;\n z-index: 9999999;\n pointer-events: none;\n}\n", ""]); /***/ }), /***/ 3645: /***/ ((module) => { "use strict"; /* MIT License http://www.opensource.org/licenses/mit-license.php Author Tobias Koppers @sokra */ // css base code, injected by the css-loader module.exports = function (useSourceMap) { var list = []; // return the list of modules as css string list.toString = function toString() { return this.map(function (item) { var content = cssWithMappingToString(item, useSourceMap); if (item[2]) { return '@media ' + item[2] + '{' + content + '}'; } else { return content; } }).join(''); }; // import a list of modules into the list list.i = function (modules, mediaQuery) { if (typeof modules === 'string') { modules = [[null, modules, '']]; } var alreadyImportedModules = {}; for (var i = 0; i < this.length; i++) { var id = this[i][0]; if (id != null) { alreadyImportedModules[id] = true; } } for (i = 0; i < modules.length; i++) { var item = modules[i]; // skip already imported module // this implementation is not 100% perfect for weird media query combinations // when a module is imported multiple times with different media queries. // I hope this will never occur (Hey this way we have smaller bundles) if (item[0] == null || !alreadyImportedModules[item[0]]) { if (mediaQuery && !item[2]) { item[2] = mediaQuery; } else if (mediaQuery) { item[2] = '(' + item[2] + ') and (' + mediaQuery + ')'; } list.push(item); } } }; return list; }; function cssWithMappingToString(item, useSourceMap) { var content = item[1] || ''; var cssMapping = item[3]; if (!cssMapping) { return content; } if (useSourceMap && typeof btoa === 'function') { var sourceMapping = toComment(cssMapping); var sourceURLs = cssMapping.sources.map(function (source) { return '/*# sourceURL=' + cssMapping.sourceRoot + source + ' */'; }); return [content].concat(sourceURLs).concat([sourceMapping]).join('\n'); } return [content].join('\n'); } // Adapted from convert-source-map (MIT) function toComment(sourceMap) { // eslint-disable-next-line no-undef var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))); var data = 'sourceMappingURL=data:application/json;charset=utf-8;base64,' + base64; return '/*# ' + data + ' */'; } /***/ }), /***/ 8267: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { // Expose `IntlPolyfill` as global to add locale data into runtime later on. __webpack_require__.g.IntlPolyfill = __webpack_require__(8659); // Require all locale data for `Intl`. This module will be // ignored when bundling for the browser with Browserify/Webpack. __webpack_require__(2482); // hack to export the polyfill as global Intl if needed if (!__webpack_require__.g.Intl) { __webpack_require__.g.Intl = __webpack_require__.g.IntlPolyfill; __webpack_require__.g.IntlPolyfill.__applyLocaleSensitivePrototypes(); } // providing an idiomatic api for the nodejs version of this module module.exports = __webpack_require__.g.IntlPolyfill; /***/ }), /***/ 8659: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { "use strict"; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; var jsx = function () { var REACT_ELEMENT_TYPE = typeof Symbol === "function" && Symbol.for && Symbol.for("react.element") || 0xeac7; return function createRawReactElement(type, props, key, children) { var defaultProps = type && type.defaultProps; var childrenLength = arguments.length - 3; if (!props && childrenLength !== 0) { props = {}; } if (props && defaultProps) { for (var propName in defaultProps) { if (props[propName] === void 0) { props[propName] = defaultProps[propName]; } } } else if (!props) { props = defaultProps || {}; } if (childrenLength === 1) { props.children = children; } else if (childrenLength > 1) { var childArray = Array(childrenLength); for (var i = 0; i < childrenLength; i++) { childArray[i] = arguments[i + 3]; } props.children = childArray; } return { $$typeof: REACT_ELEMENT_TYPE, type: type, key: key === undefined ? null : '' + key, ref: null, props: props, _owner: null }; }; }(); var asyncToGenerator = function (fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { return step("next", value); }, function (err) { return step("throw", err); }); } } return step("next"); }); }; }; var classCallCheck = function (instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }; 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 defineEnumerableProperties = function (obj, descs) { for (var key in descs) { var desc = descs[key]; desc.configurable = desc.enumerable = true; if ("value" in desc) desc.writable = true; Object.defineProperty(obj, key, desc); } return obj; }; var defaults = function (obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }; var defineProperty$1 = function (obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }; 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 get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } }; var inherits = function (subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }; var _instanceof = function (left, right) { if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) { return right[Symbol.hasInstance](left); } else { return left instanceof right; } }; var interopRequireDefault = function (obj) { return obj && obj.__esModule ? obj : { default: obj }; }; var interopRequireWildcard = function (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 newArrowCheck = function (innerThis, boundThis) { if (innerThis !== boundThis) { throw new TypeError("Cannot instantiate an arrow function"); } }; var objectDestructuringEmpty = function (obj) { if (obj == null) throw new TypeError("Cannot destructure undefined"); }; var objectWithoutProperties = function (obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }; var possibleConstructorReturn = function (self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }; var selfGlobal = typeof __webpack_require__.g === "undefined" ? self : __webpack_require__.g; var set = function set(object, property, value, receiver) { var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent !== null) { set(parent, property, value, receiver); } } else if ("value" in desc && desc.writable) { desc.value = value; } else { var setter = desc.set; if (setter !== undefined) { setter.call(receiver, value); } } return value; }; var slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); var slicedToArrayLoose = function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { var _arr = []; for (var _iterator = arr[Symbol.iterator](), _step; !(_step = _iterator.next()).done;) { _arr.push(_step.value); if (i && _arr.length === i) break; } return _arr; } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; var taggedTemplateLiteral = function (strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }; var taggedTemplateLiteralLoose = function (strings, raw) { strings.raw = raw; return strings; }; var temporalRef = function (val, name, undef) { if (val === undef) { throw new ReferenceError(name + " is not defined - temporal dead zone"); } else { return val; } }; var temporalUndefined = {}; var toArray = function (arr) { return Array.isArray(arr) ? arr : Array.from(arr); }; var toConsumableArray = function (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); } }; var babelHelpers$1 = Object.freeze({ jsx: jsx, asyncToGenerator: asyncToGenerator, classCallCheck: classCallCheck, createClass: createClass, defineEnumerableProperties: defineEnumerableProperties, defaults: defaults, defineProperty: defineProperty$1, get: get, inherits: inherits, interopRequireDefault: interopRequireDefault, interopRequireWildcard: interopRequireWildcard, newArrowCheck: newArrowCheck, objectDestructuringEmpty: objectDestructuringEmpty, objectWithoutProperties: objectWithoutProperties, possibleConstructorReturn: possibleConstructorReturn, selfGlobal: selfGlobal, set: set, slicedToArray: slicedToArray, slicedToArrayLoose: slicedToArrayLoose, taggedTemplateLiteral: taggedTemplateLiteral, taggedTemplateLiteralLoose: taggedTemplateLiteralLoose, temporalRef: temporalRef, temporalUndefined: temporalUndefined, toArray: toArray, toConsumableArray: toConsumableArray, typeof: _typeof, extends: _extends, instanceof: _instanceof }); var realDefineProp = function () { var sentinel = function sentinel() {}; try { Object.defineProperty(sentinel, 'a', { get: function get() { return 1; } }); Object.defineProperty(sentinel, 'prototype', { writable: false }); return sentinel.a === 1 && sentinel.prototype instanceof Object; } catch (e) { return false; } }(); // Need a workaround for getters in ES3 var es3 = !realDefineProp && !Object.prototype.__defineGetter__; // We use this a lot (and need it for proto-less objects) var hop = Object.prototype.hasOwnProperty; // Naive defineProperty for compatibility var defineProperty = realDefineProp ? Object.defineProperty : function (obj, name, desc) { if ('get' in desc && obj.__defineGetter__) obj.__defineGetter__(name, desc.get);else if (!hop.call(obj, name) || 'value' in desc) obj[name] = desc.value; }; // Array.prototype.indexOf, as good as we need it to be var arrIndexOf = Array.prototype.indexOf || function (search) { /*jshint validthis:true */ var t = this; if (!t.length) return -1; for (var i = arguments[1] || 0, max = t.length; i < max; i++) { if (t[i] === search) return i; } return -1; }; // Create an object with the specified prototype (2nd arg required for Record) var objCreate = Object.create || function (proto, props) { var obj = void 0; function F() {} F.prototype = proto; obj = new F(); for (var k in props) { if (hop.call(props, k)) defineProperty(obj, k, props[k]); } return obj; }; // Snapshot some (hopefully still) native built-ins var arrSlice = Array.prototype.slice; var arrConcat = Array.prototype.concat; var arrPush = Array.prototype.push; var arrJoin = Array.prototype.join; var arrShift = Array.prototype.shift; // Naive Function.prototype.bind for compatibility var fnBind = Function.prototype.bind || function (thisObj) { var fn = this, args = arrSlice.call(arguments, 1); // All our (presently) bound functions have either 1 or 0 arguments. By returning // different function signatures, we can pass some tests in ES3 environments if (fn.length === 1) { return function () { return fn.apply(thisObj, arrConcat.call(args, arrSlice.call(arguments))); }; } return function () { return fn.apply(thisObj, arrConcat.call(args, arrSlice.call(arguments))); }; }; // Object housing internal properties for constructors var internals = objCreate(null); // Keep internal properties internal var secret = Math.random(); // Helper functions // ================ /** * A function to deal with the inaccuracy of calculating log10 in pre-ES6 * JavaScript environments. Math.log(num) / Math.LN10 was responsible for * causing issue #62. */ function log10Floor(n) { // ES6 provides the more accurate Math.log10 if (typeof Math.log10 === 'function') return Math.floor(Math.log10(n)); var x = Math.round(Math.log(n) * Math.LOG10E); return x - (Number('1e' + x) > n); } /** * A map that doesn't contain Object in its prototype chain */ function Record(obj) { // Copy only own properties over unless this object is already a Record instance for (var k in obj) { if (obj instanceof Record || hop.call(obj, k)) defineProperty(this, k, { value: obj[k], enumerable: true, writable: true, configurable: true }); } } Record.prototype = objCreate(null); /** * An ordered list */ function List() { defineProperty(this, 'length', { writable: true, value: 0 }); if (arguments.length) arrPush.apply(this, arrSlice.call(arguments)); } List.prototype = objCreate(null); /** * Constructs a regular expression to restore tainted RegExp properties */ function createRegExpRestore() { if (internals.disableRegExpRestore) { return function () {/* no-op */}; } var regExpCache = { lastMatch: RegExp.lastMatch || '', leftContext: RegExp.leftContext, multiline: RegExp.multiline, input: RegExp.input }, has = false; // Create a snapshot of all the 'captured' properties for (var i = 1; i <= 9; i++) { has = (regExpCache['$' + i] = RegExp['$' + i]) || has; }return function () { // Now we've snapshotted some properties, escape the lastMatch string var esc = /[.?*+^$[\]\\(){}|-]/g, lm = regExpCache.lastMatch.replace(esc, '\\$&'), reg = new List(); // If any of the captured strings were non-empty, iterate over them all if (has) { for (var _i = 1; _i <= 9; _i++) { var m = regExpCache['$' + _i]; // If it's empty, add an empty capturing group if (!m) lm = '()' + lm; // Else find the string in lm and escape & wrap it to capture it else { m = m.replace(esc, '\\$&'); lm = lm.replace(m, '(' + m + ')'); } // Push it to the reg and chop lm to make sure further groups come after arrPush.call(reg, lm.slice(0, lm.indexOf('(') + 1)); lm = lm.slice(lm.indexOf('(') + 1); } } var exprStr = arrJoin.call(reg, '') + lm; // Shorten the regex by replacing each part of the expression with a match // for a string of that exact length. This is safe for the type of // expressions generated above, because the expression matches the whole // match string, so we know each group and each segment between capturing // groups can be matched by its length alone. exprStr = exprStr.replace(/(\\\(|\\\)|[^()])+/g, function (match) { return '[\\s\\S]{' + match.replace('\\', '').length + '}'; }); // Create the regular expression that will reconstruct the RegExp properties var expr = new RegExp(exprStr, regExpCache.multiline ? 'gm' : 'g'); // Set the lastIndex of the generated expression to ensure that the match // is found in the correct index. expr.lastIndex = regExpCache.leftContext.length; expr.exec(regExpCache.input); }; } /** * Mimics ES5's abstract ToObject() function */ function toObject(arg) { if (arg === null) throw new TypeError('Cannot convert null or undefined to object'); if ((typeof arg === 'undefined' ? 'undefined' : babelHelpers$1['typeof'](arg)) === 'object') return arg; return Object(arg); } function toNumber(arg) { if (typeof arg === 'number') return arg; return Number(arg); } function toInteger(arg) { var number = toNumber(arg); if (isNaN(number)) return 0; if (number === +0 || number === -0 || number === +Infinity || number === -Infinity) return number; if (number < 0) return Math.floor(Math.abs(number)) * -1; return Math.floor(Math.abs(number)); } function toLength(arg) { var len = toInteger(arg); if (len <= 0) return 0; if (len === Infinity) return Math.pow(2, 53) - 1; return Math.min(len, Math.pow(2, 53) - 1); } /** * Returns "internal" properties for an object */ function getInternalProperties(obj) { if (hop.call(obj, '__getInternalProperties')) return obj.__getInternalProperties(secret); return objCreate(null); } /** * Defines regular expressions for various operations related to the BCP 47 syntax, * as defined at http://tools.ietf.org/html/bcp47#section-2.1 */ // extlang = 3ALPHA ; selected ISO 639 codes // *2("-" 3ALPHA) ; permanently reserved var extlang = '[a-z]{3}(?:-[a-z]{3}){0,2}'; // language = 2*3ALPHA ; shortest ISO 639 code // ["-" extlang] ; sometimes followed by // ; extended language subtags // / 4ALPHA ; or reserved for future use // / 5*8ALPHA ; or registered language subtag var language = '(?:[a-z]{2,3}(?:-' + extlang + ')?|[a-z]{4}|[a-z]{5,8})'; // script = 4ALPHA ; ISO 15924 code var script = '[a-z]{4}'; // region = 2ALPHA ; ISO 3166-1 code // / 3DIGIT ; UN M.49 code var region = '(?:[a-z]{2}|\\d{3})'; // variant = 5*8alphanum ; registered variants // / (DIGIT 3alphanum) var variant = '(?:[a-z0-9]{5,8}|\\d[a-z0-9]{3})'; // ; Single alphanumerics // ; "x" reserved for private use // singleton = DIGIT ; 0 - 9 // / %x41-57 ; A - W // / %x59-5A ; Y - Z // / %x61-77 ; a - w // / %x79-7A ; y - z var singleton = '[0-9a-wy-z]'; // extension = singleton 1*("-" (2*8alphanum)) var extension = singleton + '(?:-[a-z0-9]{2,8})+'; // privateuse = "x" 1*("-" (1*8alphanum)) var privateuse = 'x(?:-[a-z0-9]{1,8})+'; // irregular = "en-GB-oed" ; irregular tags do not match // / "i-ami" ; the 'langtag' production and // / "i-bnn" ; would not otherwise be // / "i-default" ; considered 'well-formed' // / "i-enochian" ; These tags are all valid, // / "i-hak" ; but most are deprecated // / "i-klingon" ; in favor of more modern // / "i-lux" ; subtags or subtag // / "i-mingo" ; combination // / "i-navajo" // / "i-pwn" // / "i-tao" // / "i-tay" // / "i-tsu" // / "sgn-BE-FR" // / "sgn-BE-NL" // / "sgn-CH-DE" var irregular = '(?:en-GB-oed' + '|i-(?:ami|bnn|default|enochian|hak|klingon|lux|mingo|navajo|pwn|tao|tay|tsu)' + '|sgn-(?:BE-FR|BE-NL|CH-DE))'; // regular = "art-lojban" ; these tags match the 'langtag' // / "cel-gaulish" ; production, but their subtags // / "no-bok" ; are not extended language // / "no-nyn" ; or variant subtags: their meaning // / "zh-guoyu" ; is defined by their registration // / "zh-hakka" ; and all of these are deprecated // / "zh-min" ; in favor of a more modern // / "zh-min-nan" ; subtag or sequence of subtags // / "zh-xiang" var regular = '(?:art-lojban|cel-gaulish|no-bok|no-nyn' + '|zh-(?:guoyu|hakka|min|min-nan|xiang))'; // grandfathered = irregular ; non-redundant tags registered // / regular ; during the RFC 3066 era var grandfathered = '(?:' + irregular + '|' + regular + ')'; // langtag = language // ["-" script] // ["-" region] // *("-" variant) // *("-" extension) // ["-" privateuse] var langtag = language + '(?:-' + script + ')?(?:-' + region + ')?(?:-' + variant + ')*(?:-' + extension + ')*(?:-' + privateuse + ')?'; // Language-Tag = langtag ; normal language tags // / privateuse ; private use tag // / grandfathered ; grandfathered tags var expBCP47Syntax = RegExp('^(?:' + langtag + '|' + privateuse + '|' + grandfathered + ')$', 'i'); // Match duplicate variants in a language tag var expVariantDupes = RegExp('^(?!x).*?-(' + variant + ')-(?:\\w{4,8}-(?!x-))*\\1\\b', 'i'); // Match duplicate singletons in a language tag (except in private use) var expSingletonDupes = RegExp('^(?!x).*?-(' + singleton + ')-(?:\\w+-(?!x-))*\\1\\b', 'i'); // Match all extension sequences var expExtSequences = RegExp('-' + extension, 'ig'); // Default locale is the first-added locale data for us var defaultLocale = void 0; function setDefaultLocale(locale) { defaultLocale = locale; } // IANA Subtag Registry redundant tag and subtag maps var redundantTags = { tags: { "art-lojban": "jbo", "i-ami": "ami", "i-bnn": "bnn", "i-hak": "hak", "i-klingon": "tlh", "i-lux": "lb", "i-navajo": "nv", "i-pwn": "pwn", "i-tao": "tao", "i-tay": "tay", "i-tsu": "tsu", "no-bok": "nb", "no-nyn": "nn", "sgn-BE-FR": "sfb", "sgn-BE-NL": "vgt", "sgn-CH-DE": "sgg", "zh-guoyu": "cmn", "zh-hakka": "hak", "zh-min-nan": "nan", "zh-xiang": "hsn", "sgn-BR": "bzs", "sgn-CO": "csn", "sgn-DE": "gsg", "sgn-DK": "dsl", "sgn-ES": "ssp", "sgn-FR": "fsl", "sgn-GB": "bfi", "sgn-GR": "gss", "sgn-IE": "isg", "sgn-IT": "ise", "sgn-JP": "jsl", "sgn-MX": "mfs", "sgn-NI": "ncs", "sgn-NL": "dse", "sgn-NO": "nsl", "sgn-PT": "psr", "sgn-SE": "swl", "sgn-US": "ase", "sgn-ZA": "sfs", "zh-cmn": "cmn", "zh-cmn-Hans": "cmn-Hans", "zh-cmn-Hant": "cmn-Hant", "zh-gan": "gan", "zh-wuu": "wuu", "zh-yue": "yue" }, subtags: { BU: "MM", DD: "DE", FX: "FR", TP: "TL", YD: "YE", ZR: "CD", heploc: "alalc97", 'in': "id", iw: "he", ji: "yi", jw: "jv", mo: "ro", ayx: "nun", bjd: "drl", ccq: "rki", cjr: "mom", cka: "cmr", cmk: "xch", drh: "khk", drw: "prs", gav: "dev", hrr: "jal", ibi: "opa", kgh: "kml", lcq: "ppr", mst: "mry", myt: "mry", sca: "hle", tie: "ras", tkk: "twm", tlw: "weo", tnf: "prs", ybd: "rki", yma: "lrr" }, extLang: { aao: ["aao", "ar"], abh: ["abh", "ar"], abv: ["abv", "ar"], acm: ["acm", "ar"], acq: ["acq", "ar"], acw: ["acw", "ar"], acx: ["acx", "ar"], acy: ["acy", "ar"], adf: ["adf", "ar"], ads: ["ads", "sgn"], aeb: ["aeb", "ar"], aec: ["aec", "ar"], aed: ["aed", "sgn"], aen: ["aen", "sgn"], afb: ["afb", "ar"], afg: ["afg", "sgn"], ajp: ["ajp", "ar"], apc: ["apc", "ar"], apd: ["apd", "ar"], arb: ["arb", "ar"], arq: ["arq", "ar"], ars: ["ars", "ar"], ary: ["ary", "ar"], arz: ["arz", "ar"], ase: ["ase", "sgn"], asf: ["asf", "sgn"], asp: ["asp", "sgn"], asq: ["asq", "sgn"], asw: ["asw", "sgn"], auz: ["auz", "ar"], avl: ["avl", "ar"], ayh: ["ayh", "ar"], ayl: ["ayl", "ar"], ayn: ["ayn", "ar"], ayp: ["ayp", "ar"], bbz: ["bbz", "ar"], bfi: ["bfi", "sgn"], bfk: ["bfk", "sgn"], bjn: ["bjn", "ms"], bog: ["bog", "sgn"], bqn: ["bqn", "sgn"], bqy: ["bqy", "sgn"], btj: ["btj", "ms"], bve: ["bve", "ms"], bvl: ["bvl", "sgn"], bvu: ["bvu", "ms"], bzs: ["bzs", "sgn"], cdo: ["cdo", "zh"], cds: ["cds", "sgn"], cjy: ["cjy", "zh"], cmn: ["cmn", "zh"], coa: ["coa", "ms"], cpx: ["cpx", "zh"], csc: ["csc", "sgn"], csd: ["csd", "sgn"], cse: ["cse", "sgn"], csf: ["csf", "sgn"], csg: ["csg", "sgn"], csl: ["csl", "sgn"], csn: ["csn", "sgn"], csq: ["csq", "sgn"], csr: ["csr", "sgn"], czh: ["czh", "zh"], czo: ["czo", "zh"], doq: ["doq", "sgn"], dse: ["dse", "sgn"], dsl: ["dsl", "sgn"], dup: ["dup", "ms"], ecs: ["ecs", "sgn"], esl: ["esl", "sgn"], esn: ["esn", "sgn"], eso: ["eso", "sgn"], eth: ["eth", "sgn"], fcs: ["fcs", "sgn"], fse: ["fse", "sgn"], fsl: ["fsl", "sgn"], fss: ["fss", "sgn"], gan: ["gan", "zh"], gds: ["gds", "sgn"], gom: ["gom", "kok"], gse: ["gse", "sgn"], gsg: ["gsg", "sgn"], gsm: ["gsm", "sgn"], gss: ["gss", "sgn"], gus: ["gus", "sgn"], hab: ["hab", "sgn"], haf: ["haf", "sgn"], hak: ["hak", "zh"], hds: ["hds", "sgn"], hji: ["hji", "ms"], hks: ["hks", "sgn"], hos: ["hos", "sgn"], hps: ["hps", "sgn"], hsh: ["hsh", "sgn"], hsl: ["hsl", "sgn"], hsn: ["hsn", "zh"], icl: ["icl", "sgn"], ils: ["ils", "sgn"], inl: ["inl", "sgn"], ins: ["ins", "sgn"], ise: ["ise", "sgn"], isg: ["isg", "sgn"], isr: ["isr", "sgn"], jak: ["jak", "ms"], jax: ["jax", "ms"], jcs: ["jcs", "sgn"], jhs: ["jhs", "sgn"], jls: ["jls", "sgn"], jos: ["jos", "sgn"], jsl: ["jsl", "sgn"], jus: ["jus", "sgn"], kgi: ["kgi", "sgn"], knn: ["knn", "kok"], kvb: ["kvb", "ms"], kvk: ["kvk", "sgn"], kvr: ["kvr", "ms"], kxd: ["kxd", "ms"], lbs: ["lbs", "sgn"], lce: ["lce", "ms"], lcf: ["lcf", "ms"], liw: ["liw", "ms"], lls: ["lls", "sgn"], lsg: ["lsg", "sgn"], lsl: ["lsl", "sgn"], lso: ["lso", "sgn"], lsp: ["lsp", "sgn"], lst: ["lst", "sgn"], lsy: ["lsy", "sgn"], ltg: ["ltg", "lv"], lvs: ["lvs", "lv"], lzh: ["lzh", "zh"], max: ["max", "ms"], mdl: ["mdl", "sgn"], meo: ["meo", "ms"], mfa: ["mfa", "ms"], mfb: ["mfb", "ms"], mfs: ["mfs", "sgn"], min: ["min", "ms"], mnp: ["mnp", "zh"], mqg: ["mqg", "ms"], mre: ["mre", "sgn"], msd: ["msd", "sgn"], msi: ["msi", "ms"], msr: ["msr", "sgn"], mui: ["mui", "ms"], mzc: ["mzc", "sgn"], mzg: ["mzg", "sgn"], mzy: ["mzy", "sgn"], nan: ["nan", "zh"], nbs: ["nbs", "sgn"], ncs: ["ncs", "sgn"], nsi: ["nsi", "sgn"], nsl: ["nsl", "sgn"], nsp: ["nsp", "sgn"], nsr: ["nsr", "sgn"], nzs: ["nzs", "sgn"], okl: ["okl", "sgn"], orn: ["orn", "ms"], ors: ["ors", "ms"], pel: ["pel", "ms"], pga: ["pga", "ar"], pks: ["pks", "sgn"], prl: ["prl", "sgn"], prz: ["prz", "sgn"], psc: ["psc", "sgn"], psd: ["psd", "sgn"], pse: ["pse", "ms"], psg: ["psg", "sgn"], psl: ["psl", "sgn"], pso: ["pso", "sgn"], psp: ["psp", "sgn"], psr: ["psr", "sgn"], pys: ["pys", "sgn"], rms: ["rms", "sgn"], rsi: ["rsi", "sgn"], rsl: ["rsl", "sgn"], sdl: ["sdl", "sgn"], sfb: ["sfb", "sgn"], sfs: ["sfs", "sgn"], sgg: ["sgg", "sgn"], sgx: ["sgx", "sgn"], shu: ["shu", "ar"], slf: ["slf", "sgn"], sls: ["sls", "sgn"], sqk: ["sqk", "sgn"], sqs: ["sqs", "sgn"], ssh: ["ssh", "ar"], ssp: ["ssp", "sgn"], ssr: ["ssr", "sgn"], svk: ["svk", "sgn"], swc: ["swc", "sw"], swh: ["swh", "sw"], swl: ["swl", "sgn"], syy: ["syy", "sgn"], tmw: ["tmw", "ms"], tse: ["tse", "sgn"], tsm: ["tsm", "sgn"], tsq: ["tsq", "sgn"], tss: ["tss", "sgn"], tsy: ["tsy", "sgn"], tza: ["tza", "sgn"], ugn: ["ugn", "sgn"], ugy: ["ugy", "sgn"], ukl: ["ukl", "sgn"], uks: ["uks", "sgn"], urk: ["urk", "ms"], uzn: ["uzn", "uz"], uzs: ["uzs", "uz"], vgt: ["vgt", "sgn"], vkk: ["vkk", "ms"], vkt: ["vkt", "ms"], vsi: ["vsi", "sgn"], vsl: ["vsl", "sgn"], vsv: ["vsv", "sgn"], wuu: ["wuu", "zh"], xki: ["xki", "sgn"], xml: ["xml", "sgn"], xmm: ["xmm", "ms"], xms: ["xms", "sgn"], yds: ["yds", "sgn"], ysl: ["ysl", "sgn"], yue: ["yue", "zh"], zib: ["zib", "sgn"], zlm: ["zlm", "ms"], zmi: ["zmi", "ms"], zsl: ["zsl", "sgn"], zsm: ["zsm", "ms"] } }; /** * Convert only a-z to uppercase as per section 6.1 of the spec */ function toLatinUpperCase(str) { var i = str.length; while (i--) { var ch = str.charAt(i); if (ch >= "a" && ch <= "z") str = str.slice(0, i) + ch.toUpperCase() + str.slice(i + 1); } return str; } /** * The IsStructurallyValidLanguageTag abstract operation verifies that the locale * argument (which must be a String value) * * - represents a well-formed BCP 47 language tag as specified in RFC 5646 section * 2.1, or successor, * - does not include duplicate variant subtags, and * - does not include duplicate singleton subtags. * * The abstract operation returns true if locale can be generated from the ABNF * grammar in section 2.1 of the RFC, starting with Language-Tag, and does not * contain duplicate variant or singleton subtags (other than as a private use * subtag). It returns false otherwise. Terminal value characters in the grammar are * interpreted as the Unicode equivalents of the ASCII octet values given. */ function /* 6.2.2 */IsStructurallyValidLanguageTag(locale) { // represents a well-formed BCP 47 language tag as specified in RFC 5646 if (!expBCP47Syntax.test(locale)) return false; // does not include duplicate variant subtags, and if (expVariantDupes.test(locale)) return false; // does not include duplicate singleton subtags. if (expSingletonDupes.test(locale)) return false; return true; } /** * The CanonicalizeLanguageTag abstract operation returns the canonical and case- * regularized form of the locale argument (which must be a String value that is * a structurally valid BCP 47 language tag as verified by the * IsStructurallyValidLanguageTag abstract operation). It takes the steps * specified in RFC 5646 section 4.5, or successor, to bring the language tag * into canonical form, and to regularize the case of the subtags, but does not * take the steps to bring a language tag into “extlang form” and to reorder * variant subtags. * The specifications for extensions to BCP 47 language tags, such as RFC 6067, * may include canonicalization rules for the extension subtag sequences they * define that go beyond the canonicalization rules of RFC 5646 section 4.5. * Implementations are allowed, but not required, to apply these additional rules. */ function /* 6.2.3 */CanonicalizeLanguageTag(locale) { var match = void 0, parts = void 0; // A language tag is in 'canonical form' when the tag is well-formed // according to the rules in Sections 2.1 and 2.2 // Section 2.1 says all subtags use lowercase... locale = locale.toLowerCase(); // ...with 2 exceptions: 'two-letter and four-letter subtags that neither // appear at the start of the tag nor occur after singletons. Such two-letter // subtags are all uppercase (as in the tags "en-CA-x-ca" or "sgn-BE-FR") and // four-letter subtags are titlecase (as in the tag "az-Latn-x-latn"). parts = locale.split('-'); for (var i = 1, max = parts.length; i < max; i++) { // Two-letter subtags are all uppercase if (parts[i].length === 2) parts[i] = parts[i].toUpperCase(); // Four-letter subtags are titlecase else if (parts[i].length === 4) parts[i] = parts[i].charAt(0).toUpperCase() + parts[i].slice(1); // Is it a singleton? else if (parts[i].length === 1 && parts[i] !== 'x') break; } locale = arrJoin.call(parts, '-'); // The steps laid out in RFC 5646 section 4.5 are as follows: // 1. Extension sequences are ordered into case-insensitive ASCII order // by singleton subtag. if ((match = locale.match(expExtSequences)) && match.length > 1) { // The built-in sort() sorts by ASCII order, so use that match.sort(); // Replace all extensions with the joined, sorted array locale = locale.replace(RegExp('(?:' + expExtSequences.source + ')+', 'i'), arrJoin.call(match, '')); } // 2. Redundant or grandfathered tags are replaced by their 'Preferred- // Value', if there is one. if (hop.call(redundantTags.tags, locale)) locale = redundantTags.tags[locale]; // 3. Subtags are replaced by their 'Preferred-Value', if there is one. // For extlangs, the original primary language subtag is also // replaced if there is a primary language subtag in the 'Preferred- // Value'. parts = locale.split('-'); for (var _i = 1, _max = parts.length; _i < _max; _i++) { if (hop.call(redundantTags.subtags, parts[_i])) parts[_i] = redundantTags.subtags[parts[_i]];else if (hop.call(redundantTags.extLang, parts[_i])) { parts[_i] = redundantTags.extLang[parts[_i]][0]; // For extlang tags, the prefix needs to be removed if it is redundant if (_i === 1 && redundantTags.extLang[parts[1]][1] === parts[0]) { parts = arrSlice.call(parts, _i++); _max -= 1; } } } return arrJoin.call(parts, '-'); } /** * The DefaultLocale abstract operation returns a String value representing the * structurally valid (6.2.2) and canonicalized (6.2.3) BCP 47 language tag for the * host environment’s current locale. */ function /* 6.2.4 */DefaultLocale() { return defaultLocale; } // Sect 6.3 Currency Codes // ======================= var expCurrencyCode = /^[A-Z]{3}$/; /** * The IsWellFormedCurrencyCode abstract operation verifies that the currency argument * (after conversion to a String value) represents a well-formed 3-letter ISO currency * code. The following steps are taken: */ function /* 6.3.1 */IsWellFormedCurrencyCode(currency) { // 1. Let `c` be ToString(currency) var c = String(currency); // 2. Let `normalized` be the result of mapping c to upper case as described // in 6.1. var normalized = toLatinUpperCase(c); // 3. If the string length of normalized is not 3, return false. // 4. If normalized contains any character that is not in the range "A" to "Z" // (U+0041 to U+005A), return false. if (expCurrencyCode.test(normalized) === false) return false; // 5. Return true return true; } var expUnicodeExSeq = /-u(?:-[0-9a-z]{2,8})+/gi; // See `extension` below function /* 9.2.1 */CanonicalizeLocaleList(locales) { // The abstract operation CanonicalizeLocaleList takes the following steps: // 1. If locales is undefined, then a. Return a new empty List if (locales === undefined) return new List(); // 2. Let seen be a new empty List. var seen = new List(); // 3. If locales is a String value, then // a. Let locales be a new array created as if by the expression new // Array(locales) where Array is the standard built-in constructor with // that name and locales is the value of locales. locales = typeof locales === 'string' ? [locales] : locales; // 4. Let O be ToObject(locales). var O = toObject(locales); // 5. Let lenValue be the result of calling the [[Get]] internal method of // O with the argument "length". // 6. Let len be ToUint32(lenValue). var len = toLength(O.length); // 7. Let k be 0. var k = 0; // 8. Repeat, while k < len while (k < len) { // a. Let Pk be ToString(k). var Pk = String(k); // b. Let kPresent be the result of calling the [[HasProperty]] internal // method of O with argument Pk. var kPresent = Pk in O; // c. If kPresent is true, then if (kPresent) { // i. Let kValue be the result of calling the [[Get]] internal // method of O with argument Pk. var kValue = O[Pk]; // ii. If the type of kValue is not String or Object, then throw a // TypeError exception. if (kValue === null || typeof kValue !== 'string' && (typeof kValue === "undefined" ? "undefined" : babelHelpers$1["typeof"](kValue)) !== 'object') throw new TypeError('String or Object type expected'); // iii. Let tag be ToString(kValue). var tag = String(kValue); // iv. If the result of calling the abstract operation // IsStructurallyValidLanguageTag (defined in 6.2.2), passing tag as // the argument, is false, then throw a RangeError exception. if (!IsStructurallyValidLanguageTag(tag)) throw new RangeError("'" + tag + "' is not a structurally valid language tag"); // v. Let tag be the result of calling the abstract operation // CanonicalizeLanguageTag (defined in 6.2.3), passing tag as the // argument. tag = CanonicalizeLanguageTag(tag); // vi. If tag is not an element of seen, then append tag as the last // element of seen. if (arrIndexOf.call(seen, tag) === -1) arrPush.call(seen, tag); } // d. Increase k by 1. k++; } // 9. Return seen. return seen; } /** * The BestAvailableLocale abstract operation compares the provided argument * locale, which must be a String value with a structurally valid and * canonicalized BCP 47 language tag, against the locales in availableLocales and * returns either the longest non-empty prefix of locale that is an element of * availableLocales, or undefined if there is no such element. It uses the * fallback mechanism of RFC 4647, section 3.4. The following steps are taken: */ function /* 9.2.2 */BestAvailableLocale(availableLocales, locale) { // 1. Let candidate be locale var candidate = locale; // 2. Repeat while (candidate) { // a. If availableLocales contains an element equal to candidate, then return // candidate. if (arrIndexOf.call(availableLocales, candidate) > -1) return candidate; // b. Let pos be the character index of the last occurrence of "-" // (U+002D) within candidate. If that character does not occur, return // undefined. var pos = candidate.lastIndexOf('-'); if (pos < 0) return; // c. If pos ≥ 2 and the character "-" occurs at index pos-2 of candidate, // then decrease pos by 2. if (pos >= 2 && candidate.charAt(pos - 2) === '-') pos -= 2; // d. Let candidate be the substring of candidate from position 0, inclusive, // to position pos, exclusive. candidate = candidate.substring(0, pos); } } /** * The LookupMatcher abstract operation compares requestedLocales, which must be * a List as returned by CanonicalizeLocaleList, against the locales in * availableLocales and determines the best available language to meet the * request. The following steps are taken: */ function /* 9.2.3 */LookupMatcher(availableLocales, requestedLocales) { // 1. Let i be 0. var i = 0; // 2. Let len be the number of elements in requestedLocales. var len = requestedLocales.length; // 3. Let availableLocale be undefined. var availableLocale = void 0; var locale = void 0, noExtensionsLocale = void 0; // 4. Repeat while i < len and availableLocale is undefined: while (i < len && !availableLocale) { // a. Let locale be the element of requestedLocales at 0-origined list // position i. locale = requestedLocales[i]; // b. Let noExtensionsLocale be the String value that is locale with all // Unicode locale extension sequences removed. noExtensionsLocale = String(locale).replace(expUnicodeExSeq, ''); // c. Let availableLocale be the result of calling the // BestAvailableLocale abstract operation (defined in 9.2.2) with // arguments availableLocales and noExtensionsLocale. availableLocale = BestAvailableLocale(availableLocales, noExtensionsLocale); // d. Increase i by 1. i++; } // 5. Let result be a new Record. var result = new Record(); // 6. If availableLocale is not undefined, then if (availableLocale !== undefined) { // a. Set result.[[locale]] to availableLocale. result['[[locale]]'] = availableLocale; // b. If locale and noExtensionsLocale are not the same String value, then if (String(locale) !== String(noExtensionsLocale)) { // i. Let extension be the String value consisting of the first // substring of locale that is a Unicode locale extension sequence. var extension = locale.match(expUnicodeExSeq)[0]; // ii. Let extensionIndex be the character position of the initial // "-" of the first Unicode locale extension sequence within locale. var extensionIndex = locale.indexOf('-u-'); // iii. Set result.[[extension]] to extension. result['[[extension]]'] = extension; // iv. Set result.[[extensionIndex]] to extensionIndex. result['[[extensionIndex]]'] = extensionIndex; } } // 7. Else else // a. Set result.[[locale]] to the value returned by the DefaultLocale abstract // operation (defined in 6.2.4). result['[[locale]]'] = DefaultLocale(); // 8. Return result return result; } /** * The BestFitMatcher abstract operation compares requestedLocales, which must be * a List as returned by CanonicalizeLocaleList, against the locales in * availableLocales and determines the best available language to meet the * request. The algorithm is implementation dependent, but should produce results * that a typical user of the requested locales would perceive as at least as * good as those produced by the LookupMatcher abstract operation. Options * specified through Unicode locale extension sequences must be ignored by the * algorithm. Information about such subsequences is returned separately. * The abstract operation returns a record with a [[locale]] field, whose value * is the language tag of the selected locale, which must be an element of * availableLocales. If the language tag of the request locale that led to the * selected locale contained a Unicode locale extension sequence, then the * returned record also contains an [[extension]] field whose value is the first * Unicode locale extension sequence, and an [[extensionIndex]] field whose value * is the index of the first Unicode locale extension sequence within the request * locale language tag. */ function /* 9.2.4 */BestFitMatcher(availableLocales, requestedLocales) { return LookupMatcher(availableLocales, requestedLocales); } /** * The ResolveLocale abstract operation compares a BCP 47 language priority list * requestedLocales against the locales in availableLocales and determines the * best available language to meet the request. availableLocales and * requestedLocales must be provided as List values, options as a Record. */ function /* 9.2.5 */ResolveLocale(availableLocales, requestedLocales, options, relevantExtensionKeys, localeData) { if (availableLocales.length === 0) { throw new ReferenceError('No locale data has been provided for this object yet.'); } // The following steps are taken: // 1. Let matcher be the value of options.[[localeMatcher]]. var matcher = options['[[localeMatcher]]']; var r = void 0; // 2. If matcher is "lookup", then if (matcher === 'lookup') // a. Let r be the result of calling the LookupMatcher abstract operation // (defined in 9.2.3) with arguments availableLocales and // requestedLocales. r = LookupMatcher(availableLocales, requestedLocales); // 3. Else else // a. Let r be the result of calling the BestFitMatcher abstract // operation (defined in 9.2.4) with arguments availableLocales and // requestedLocales. r = BestFitMatcher(availableLocales, requestedLocales); // 4. Let foundLocale be the value of r.[[locale]]. var foundLocale = r['[[locale]]']; var extensionSubtags = void 0, extensionSubtagsLength = void 0; // 5. If r has an [[extension]] field, then if (hop.call(r, '[[extension]]')) { // a. Let extension be the value of r.[[extension]]. var extension = r['[[extension]]']; // b. Let split be the standard built-in function object defined in ES5, // 15.5.4.14. var split = String.prototype.split; // c. Let extensionSubtags be the result of calling the [[Call]] internal // method of split with extension as the this value and an argument // list containing the single item "-". extensionSubtags = split.call(extension, '-'); // d. Let extensionSubtagsLength be the result of calling the [[Get]] // internal method of extensionSubtags with argument "length". extensionSubtagsLength = extensionSubtags.length; } // 6. Let result be a new Record. var result = new Record(); // 7. Set result.[[dataLocale]] to foundLocale. result['[[dataLocale]]'] = foundLocale; // 8. Let supportedExtension be "-u". var supportedExtension = '-u'; // 9. Let i be 0. var i = 0; // 10. Let len be the result of calling the [[Get]] internal method of // relevantExtensionKeys with argument "length". var len = relevantExtensionKeys.length; // 11 Repeat while i < len: while (i < len) { // a. Let key be the result of calling the [[Get]] internal method of // relevantExtensionKeys with argument ToString(i). var key = relevantExtensionKeys[i]; // b. Let foundLocaleData be the result of calling the [[Get]] internal // method of localeData with the argument foundLocale. var foundLocaleData = localeData[foundLocale]; // c. Let keyLocaleData be the result of calling the [[Get]] internal // method of foundLocaleData with the argument key. var keyLocaleData = foundLocaleData[key]; // d. Let value be the result of calling the [[Get]] internal method of // keyLocaleData with argument "0". var value = keyLocaleData['0']; // e. Let supportedExtensionAddition be "". var supportedExtensionAddition = ''; // f. Let indexOf be the standard built-in function object defined in // ES5, 15.4.4.14. var indexOf = arrIndexOf; // g. If extensionSubtags is not undefined, then if (extensionSubtags !== undefined) { // i. Let keyPos be the result of calling the [[Call]] internal // method of indexOf with extensionSubtags as the this value and // an argument list containing the single item key. var keyPos = indexOf.call(extensionSubtags, key); // ii. If keyPos ≠ -1, then if (keyPos !== -1) { // 1. If keyPos + 1 < extensionSubtagsLength and the length of the // result of calling the [[Get]] internal method of // extensionSubtags with argument ToString(keyPos +1) is greater // than 2, then if (keyPos + 1 < extensionSubtagsLength && extensionSubtags[keyPos + 1].length > 2) { // a. Let requestedValue be the result of calling the [[Get]] // internal method of extensionSubtags with argument // ToString(keyPos + 1). var requestedValue = extensionSubtags[keyPos + 1]; // b. Let valuePos be the result of calling the [[Call]] // internal method of indexOf with keyLocaleData as the // this value and an argument list containing the single // item requestedValue. var valuePos = indexOf.call(keyLocaleData, requestedValue); // c. If valuePos ≠ -1, then if (valuePos !== -1) { // i. Let value be requestedValue. value = requestedValue, // ii. Let supportedExtensionAddition be the // concatenation of "-", key, "-", and value. supportedExtensionAddition = '-' + key + '-' + value; } } // 2. Else else { // a. Let valuePos be the result of calling the [[Call]] // internal method of indexOf with keyLocaleData as the this // value and an argument list containing the single item // "true". var _valuePos = indexOf(keyLocaleData, 'true'); // b. If valuePos ≠ -1, then if (_valuePos !== -1) // i. Let value be "true". value = 'true'; } } } // h. If options has a field [[<key>]], then if (hop.call(options, '[[' + key + ']]')) { // i. Let optionsValue be the value of options.[[<key>]]. var optionsValue = options['[[' + key + ']]']; // ii. If the result of calling the [[Call]] internal method of indexOf // with keyLocaleData as the this value and an argument list // containing the single item optionsValue is not -1, then if (indexOf.call(keyLocaleData, optionsValue) !== -1) { // 1. If optionsValue is not equal to value, then if (optionsValue !== value) { // a. Let value be optionsValue. value = optionsValue; // b. Let supportedExtensionAddition be "". supportedExtensionAddition = ''; } } } // i. Set result.[[<key>]] to value. result['[[' + key + ']]'] = value; // j. Append supportedExtensionAddition to supportedExtension. supportedExtension += supportedExtensionAddition; // k. Increase i by 1. i++; } // 12. If the length of supportedExtension is greater than 2, then if (supportedExtension.length > 2) { // a. var privateIndex = foundLocale.indexOf("-x-"); // b. if (privateIndex === -1) { // i. foundLocale = foundLocale + supportedExtension; } // c. else { // i. var preExtension = foundLocale.substring(0, privateIndex); // ii. var postExtension = foundLocale.substring(privateIndex); // iii. foundLocale = preExtension + supportedExtension + postExtension; } // d. asserting - skipping // e. foundLocale = CanonicalizeLanguageTag(foundLocale); } // 13. Set result.[[locale]] to foundLocale. result['[[locale]]'] = foundLocale; // 14. Return result. return result; } /** * The LookupSupportedLocales abstract operation returns the subset of the * provided BCP 47 language priority list requestedLocales for which * availableLocales has a matching locale when using the BCP 47 Lookup algorithm. * Locales appear in the same order in the returned list as in requestedLocales. * The following steps are taken: */ function /* 9.2.6 */LookupSupportedLocales(availableLocales, requestedLocales) { // 1. Let len be the number of elements in requestedLocales. var len = requestedLocales.length; // 2. Let subset be a new empty List. var subset = new List(); // 3. Let k be 0. var k = 0; // 4. Repeat while k < len while (k < len) { // a. Let locale be the element of requestedLocales at 0-origined list // position k. var locale = requestedLocales[k]; // b. Let noExtensionsLocale be the String value that is locale with all // Unicode locale extension sequences removed. var noExtensionsLocale = String(locale).replace(expUnicodeExSeq, ''); // c. Let availableLocale be the result of calling the // BestAvailableLocale abstract operation (defined in 9.2.2) with // arguments availableLocales and noExtensionsLocale. var availableLocale = BestAvailableLocale(availableLocales, noExtensionsLocale); // d. If availableLocale is not undefined, then append locale to the end of // subset. if (availableLocale !== undefined) arrPush.call(subset, locale); // e. Increment k by 1. k++; } // 5. Let subsetArray be a new Array object whose elements are the same // values in the same order as the elements of subset. var subsetArray = arrSlice.call(subset); // 6. Return subsetArray. return subsetArray; } /** * The BestFitSupportedLocales abstract operation returns the subset of the * provided BCP 47 language priority list requestedLocales for which * availableLocales has a matching locale when using the Best Fit Matcher * algorithm. Locales appear in the same order in the returned list as in * requestedLocales. The steps taken are implementation dependent. */ function /*9.2.7 */BestFitSupportedLocales(availableLocales, requestedLocales) { // ###TODO: implement this function as described by the specification### return LookupSupportedLocales(availableLocales, requestedLocales); } /** * The SupportedLocales abstract operation returns the subset of the provided BCP * 47 language priority list requestedLocales for which availableLocales has a * matching locale. Two algorithms are available to match the locales: the Lookup * algorithm described in RFC 4647 section 3.4, and an implementation dependent * best-fit algorithm. Locales appear in the same order in the returned list as * in requestedLocales. The following steps are taken: */ function /*9.2.8 */SupportedLocales(availableLocales, requestedLocales, options) { var matcher = void 0, subset = void 0; // 1. If options is not undefined, then if (options !== undefined) { // a. Let options be ToObject(options). options = new Record(toObject(options)); // b. Let matcher be the result of calling the [[Get]] internal method of // options with argument "localeMatcher". matcher = options.localeMatcher; // c. If matcher is not undefined, then if (matcher !== undefined) { // i. Let matcher be ToString(matcher). matcher = String(matcher); // ii. If matcher is not "lookup" or "best fit", then throw a RangeError // exception. if (matcher !== 'lookup' && matcher !== 'best fit') throw new RangeError('matcher should be "lookup" or "best fit"'); } } // 2. If matcher is undefined or "best fit", then if (matcher === undefined || matcher === 'best fit') // a. Let subset be the result of calling the BestFitSupportedLocales // abstract operation (defined in 9.2.7) with arguments // availableLocales and requestedLocales. subset = BestFitSupportedLocales(availableLocales, requestedLocales); // 3. Else else // a. Let subset be the result of calling the LookupSupportedLocales // abstract operation (defined in 9.2.6) with arguments // availableLocales and requestedLocales. subset = LookupSupportedLocales(availableLocales, requestedLocales); // 4. For each named own property name P of subset, for (var P in subset) { if (!hop.call(subset, P)) continue; // a. Let desc be the result of calling the [[GetOwnProperty]] internal // method of subset with P. // b. Set desc.[[Writable]] to false. // c. Set desc.[[Configurable]] to false. // d. Call the [[DefineOwnProperty]] internal method of subset with P, desc, // and true as arguments. defineProperty(subset, P, { writable: false, configurable: false, value: subset[P] }); } // "Freeze" the array so no new elements can be added defineProperty(subset, 'length', { writable: false }); // 5. Return subset return subset; } /** * The GetOption abstract operation extracts the value of the property named * property from the provided options object, converts it to the required type, * checks whether it is one of a List of allowed values, and fills in a fallback * value if necessary. */ function /*9.2.9 */GetOption(options, property, type, values, fallback) { // 1. Let value be the result of calling the [[Get]] internal method of // options with argument property. var value = options[property]; // 2. If value is not undefined, then if (value !== undefined) { // a. Assert: type is "boolean" or "string". // b. If type is "boolean", then let value be ToBoolean(value). // c. If type is "string", then let value be ToString(value). value = type === 'boolean' ? Boolean(value) : type === 'string' ? String(value) : value; // d. If values is not undefined, then if (values !== undefined) { // i. If values does not contain an element equal to value, then throw a // RangeError exception. if (arrIndexOf.call(values, value) === -1) throw new RangeError("'" + value + "' is not an allowed value for `" + property + '`'); } // e. Return value. return value; } // Else return fallback. return fallback; } /** * The GetNumberOption abstract operation extracts a property value from the * provided options object, converts it to a Number value, checks whether it is * in the allowed range, and fills in a fallback value if necessary. */ function /* 9.2.10 */GetNumberOption(options, property, minimum, maximum, fallback) { // 1. Let value be the result of calling the [[Get]] internal method of // options with argument property. var value = options[property]; // 2. If value is not undefined, then if (value !== undefined) { // a. Let value be ToNumber(value). value = Number(value); // b. If value is NaN or less than minimum or greater than maximum, throw a // RangeError exception. if (isNaN(value) || value < minimum || value > maximum) throw new RangeError('Value is not a number or outside accepted range'); // c. Return floor(value). return Math.floor(value); } // 3. Else return fallback. return fallback; } // 8 The Intl Object var Intl = {}; // 8.2 Function Properties of the Intl Object // 8.2.1 // @spec[tc39/ecma402/master/spec/intl.html] // @clause[sec-intl.getcanonicallocales] function getCanonicalLocales(locales) { // 1. Let ll be ? CanonicalizeLocaleList(locales). var ll = CanonicalizeLocaleList(locales); // 2. Return CreateArrayFromList(ll). { var result = []; var len = ll.length; var k = 0; while (k < len) { result[k] = ll[k]; k++; } return result; } } Object.defineProperty(Intl, 'getCanonicalLocales', { enumerable: false, configurable: true, writable: true, value: getCanonicalLocales }); // Currency minor units output from get-4217 grunt task, formatted var currencyMinorUnits = { BHD: 3, BYR: 0, XOF: 0, BIF: 0, XAF: 0, CLF: 4, CLP: 0, KMF: 0, DJF: 0, XPF: 0, GNF: 0, ISK: 0, IQD: 3, JPY: 0, JOD: 3, KRW: 0, KWD: 3, LYD: 3, OMR: 3, PYG: 0, RWF: 0, TND: 3, UGX: 0, UYI: 0, VUV: 0, VND: 0 }; // Define the NumberFormat constructor internally so it cannot be tainted function NumberFormatConstructor() { var locales = arguments[0]; var options = arguments[1]; if (!this || this === Intl) { return new Intl.NumberFormat(locales, options); } return InitializeNumberFormat(toObject(this), locales, options); } defineProperty(Intl, 'NumberFormat', { configurable: true, writable: true, value: NumberFormatConstructor }); // Must explicitly set prototypes as unwritable defineProperty(Intl.NumberFormat, 'prototype', { writable: false }); /** * The abstract operation InitializeNumberFormat accepts the arguments * numberFormat (which must be an object), locales, and options. It initializes * numberFormat as a NumberFormat object. */ function /*11.1.1.1 */InitializeNumberFormat(numberFormat, locales, options) { // This will be a internal properties object if we're not already initialized var internal = getInternalProperties(numberFormat); // Create an object whose props can be used to restore the values of RegExp props var regexpRestore = createRegExpRestore(); // 1. If numberFormat has an [[initializedIntlObject]] internal property with // value true, throw a TypeError exception. if (internal['[[initializedIntlObject]]'] === true) throw new TypeError('`this` object has already been initialized as an Intl object'); // Need this to access the `internal` object defineProperty(numberFormat, '__getInternalProperties', { value: function value() { // NOTE: Non-standard, for internal use only if (arguments[0] === secret) return internal; } }); // 2. Set the [[initializedIntlObject]] internal property of numberFormat to true. internal['[[initializedIntlObject]]'] = true; // 3. Let requestedLocales be the result of calling the CanonicalizeLocaleList // abstract operation (defined in 9.2.1) with argument locales. var requestedLocales = CanonicalizeLocaleList(locales); // 4. If options is undefined, then if (options === undefined) // a. Let options be the result of creating a new object as if by the // expression new Object() where Object is the standard built-in constructor // with that name. options = {}; // 5. Else else // a. Let options be ToObject(options). options = toObject(options); // 6. Let opt be a new Record. var opt = new Record(), // 7. Let matcher be the result of calling the GetOption abstract operation // (defined in 9.2.9) with the arguments options, "localeMatcher", "string", // a List containing the two String values "lookup" and "best fit", and // "best fit". matcher = GetOption(options, 'localeMatcher', 'string', new List('lookup', 'best fit'), 'best fit'); // 8. Set opt.[[localeMatcher]] to matcher. opt['[[localeMatcher]]'] = matcher; // 9. Let NumberFormat be the standard built-in object that is the initial value // of Intl.NumberFormat. // 10. Let localeData be the value of the [[localeData]] internal property of // NumberFormat. var localeData = internals.NumberFormat['[[localeData]]']; // 11. Let r be the result of calling the ResolveLocale abstract operation // (defined in 9.2.5) with the [[availableLocales]] internal property of // NumberFormat, requestedLocales, opt, the [[relevantExtensionKeys]] // internal property of NumberFormat, and localeData. var r = ResolveLocale(internals.NumberFormat['[[availableLocales]]'], requestedLocales, opt, internals.NumberFormat['[[relevantExtensionKeys]]'], localeData); // 12. Set the [[locale]] internal property of numberFormat to the value of // r.[[locale]]. internal['[[locale]]'] = r['[[locale]]']; // 13. Set the [[numberingSystem]] internal property of numberFormat to the value // of r.[[nu]]. internal['[[numberingSystem]]'] = r['[[nu]]']; // The specification doesn't tell us to do this, but it's helpful later on internal['[[dataLocale]]'] = r['[[dataLocale]]']; // 14. Let dataLocale be the value of r.[[dataLocale]]. var dataLocale = r['[[dataLocale]]']; // 15. Let s be the result of calling the GetOption abstract operation with the // arguments options, "style", "string", a List containing the three String // values "decimal", "percent", and "currency", and "decimal". var s = GetOption(options, 'style', 'string', new List('decimal', 'percent', 'currency'), 'decimal'); // 16. Set the [[style]] internal property of numberFormat to s. internal['[[style]]'] = s; // 17. Let c be the result of calling the GetOption abstract operation with the // arguments options, "currency", "string", undefined, and undefined. var c = GetOption(options, 'currency', 'string'); // 18. If c is not undefined and the result of calling the // IsWellFormedCurrencyCode abstract operation (defined in 6.3.1) with // argument c is false, then throw a RangeError exception. if (c !== undefined && !IsWellFormedCurrencyCode(c)) throw new RangeError("'" + c + "' is not a valid currency code"); // 19. If s is "currency" and c is undefined, throw a TypeError exception. if (s === 'currency' && c === undefined) throw new TypeError('Currency code is required when style is currency'); var cDigits = void 0; // 20. If s is "currency", then if (s === 'currency') { // a. Let c be the result of converting c to upper case as specified in 6.1. c = c.toUpperCase(); // b. Set the [[currency]] internal property of numberFormat to c. internal['[[currency]]'] = c; // c. Let cDigits be the result of calling the CurrencyDigits abstract // operation (defined below) with argument c. cDigits = CurrencyDigits(c); } // 21. Let cd be the result of calling the GetOption abstract operation with the // arguments options, "currencyDisplay", "string", a List containing the // three String values "code", "symbol", and "name", and "symbol". var cd = GetOption(options, 'currencyDisplay', 'string', new List('code', 'symbol', 'name'), 'symbol'); // 22. If s is "currency", then set the [[currencyDisplay]] internal property of // numberFormat to cd. if (s === 'currency') internal['[[currencyDisplay]]'] = cd; // 23. Let mnid be the result of calling the GetNumberOption abstract operation // (defined in 9.2.10) with arguments options, "minimumIntegerDigits", 1, 21, // and 1. var mnid = GetNumberOption(options, 'minimumIntegerDigits', 1, 21, 1); // 24. Set the [[minimumIntegerDigits]] internal property of numberFormat to mnid. internal['[[minimumIntegerDigits]]'] = mnid; // 25. If s is "currency", then let mnfdDefault be cDigits; else let mnfdDefault // be 0. var mnfdDefault = s === 'currency' ? cDigits : 0; // 26. Let mnfd be the result of calling the GetNumberOption abstract operation // with arguments options, "minimumFractionDigits", 0, 20, and mnfdDefault. var mnfd = GetNumberOption(options, 'minimumFractionDigits', 0, 20, mnfdDefault); // 27. Set the [[minimumFractionDigits]] internal property of numberFormat to mnfd. internal['[[minimumFractionDigits]]'] = mnfd; // 28. If s is "currency", then let mxfdDefault be max(mnfd, cDigits); else if s // is "percent", then let mxfdDefault be max(mnfd, 0); else let mxfdDefault // be max(mnfd, 3). var mxfdDefault = s === 'currency' ? Math.max(mnfd, cDigits) : s === 'percent' ? Math.max(mnfd, 0) : Math.max(mnfd, 3); // 29. Let mxfd be the result of calling the GetNumberOption abstract operation // with arguments options, "maximumFractionDigits", mnfd, 20, and mxfdDefault. var mxfd = GetNumberOption(options, 'maximumFractionDigits', mnfd, 20, mxfdDefault); // 30. Set the [[maximumFractionDigits]] internal property of numberFormat to mxfd. internal['[[maximumFractionDigits]]'] = mxfd; // 31. Let mnsd be the result of calling the [[Get]] internal method of options // with argument "minimumSignificantDigits". var mnsd = options.minimumSignificantDigits; // 32. Let mxsd be the result of calling the [[Get]] internal method of options // with argument "maximumSignificantDigits". var mxsd = options.maximumSignificantDigits; // 33. If mnsd is not undefined or mxsd is not undefined, then: if (mnsd !== undefined || mxsd !== undefined) { // a. Let mnsd be the result of calling the GetNumberOption abstract // operation with arguments options, "minimumSignificantDigits", 1, 21, // and 1. mnsd = GetNumberOption(options, 'minimumSignificantDigits', 1, 21, 1); // b. Let mxsd be the result of calling the GetNumberOption abstract // operation with arguments options, "maximumSignificantDigits", mnsd, // 21, and 21. mxsd = GetNumberOption(options, 'maximumSignificantDigits', mnsd, 21, 21); // c. Set the [[minimumSignificantDigits]] internal property of numberFormat // to mnsd, and the [[maximumSignificantDigits]] internal property of // numberFormat to mxsd. internal['[[minimumSignificantDigits]]'] = mnsd; internal['[[maximumSignificantDigits]]'] = mxsd; } // 34. Let g be the result of calling the GetOption abstract operation with the // arguments options, "useGrouping", "boolean", undefined, and true. var g = GetOption(options, 'useGrouping', 'boolean', undefined, true); // 35. Set the [[useGrouping]] internal property of numberFormat to g. internal['[[useGrouping]]'] = g; // 36. Let dataLocaleData be the result of calling the [[Get]] internal method of // localeData with argument dataLocale. var dataLocaleData = localeData[dataLocale]; // 37. Let patterns be the result of calling the [[Get]] internal method of // dataLocaleData with argument "patterns". var patterns = dataLocaleData.patterns; // 38. Assert: patterns is an object (see 11.2.3) // 39. Let stylePatterns be the result of calling the [[Get]] internal method of // patterns with argument s. var stylePatterns = patterns[s]; // 40. Set the [[positivePattern]] internal property of numberFormat to the // result of calling the [[Get]] internal method of stylePatterns with the // argument "positivePattern". internal['[[positivePattern]]'] = stylePatterns.positivePattern; // 41. Set the [[negativePattern]] internal property of numberFormat to the // result of calling the [[Get]] internal method of stylePatterns with the // argument "negativePattern". internal['[[negativePattern]]'] = stylePatterns.negativePattern; // 42. Set the [[boundFormat]] internal property of numberFormat to undefined. internal['[[boundFormat]]'] = undefined; // 43. Set the [[initializedNumberFormat]] internal property of numberFormat to // true. internal['[[initializedNumberFormat]]'] = true; // In ES3, we need to pre-bind the format() function if (es3) numberFormat.format = GetFormatNumber.call(numberFormat); // Restore the RegExp properties regexpRestore(); // Return the newly initialised object return numberFormat; } function CurrencyDigits(currency) { // When the CurrencyDigits abstract operation is called with an argument currency // (which must be an upper case String value), the following steps are taken: // 1. If the ISO 4217 currency and funds code list contains currency as an // alphabetic code, then return the minor unit value corresponding to the // currency from the list; else return 2. return currencyMinorUnits[currency] !== undefined ? currencyMinorUnits[currency] : 2; } /* 11.2.3 */internals.NumberFormat = { '[[availableLocales]]': [], '[[relevantExtensionKeys]]': ['nu'], '[[localeData]]': {} }; /** * When the supportedLocalesOf method of Intl.NumberFormat is called, the * following steps are taken: */ /* 11.2.2 */ defineProperty(Intl.NumberFormat, 'supportedLocalesOf', { configurable: true, writable: true, value: fnBind.call(function (locales) { // Bound functions only have the `this` value altered if being used as a constructor, // this lets us imitate a native function that has no constructor if (!hop.call(this, '[[availableLocales]]')) throw new TypeError('supportedLocalesOf() is not a constructor'); // Create an object whose props can be used to restore the values of RegExp props var regexpRestore = createRegExpRestore(), // 1. If options is not provided, then let options be undefined. options = arguments[1], // 2. Let availableLocales be the value of the [[availableLocales]] internal // property of the standard built-in object that is the initial value of // Intl.NumberFormat. availableLocales = this['[[availableLocales]]'], // 3. Let requestedLocales be the result of calling the CanonicalizeLocaleList // abstract operation (defined in 9.2.1) with argument locales. requestedLocales = CanonicalizeLocaleList(locales); // Restore the RegExp properties regexpRestore(); // 4. Return the result of calling the SupportedLocales abstract operation // (defined in 9.2.8) with arguments availableLocales, requestedLocales, // and options. return SupportedLocales(availableLocales, requestedLocales, options); }, internals.NumberFormat) }); /** * This named accessor property returns a function that formats a number * according to the effective locale and the formatting options of this * NumberFormat object. */ /* 11.3.2 */defineProperty(Intl.NumberFormat.prototype, 'format', { configurable: true, get: GetFormatNumber }); function GetFormatNumber() { var internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); // Satisfy test 11.3_b if (!internal || !internal['[[initializedNumberFormat]]']) throw new TypeError('`this` value for format() is not an initialized Intl.NumberFormat object.'); // The value of the [[Get]] attribute is a function that takes the following // steps: // 1. If the [[boundFormat]] internal property of this NumberFormat object // is undefined, then: if (internal['[[boundFormat]]'] === undefined) { // a. Let F be a Function object, with internal properties set as // specified for built-in functions in ES5, 15, or successor, and the // length property set to 1, that takes the argument value and // performs the following steps: var F = function F(value) { // i. If value is not provided, then let value be undefined. // ii. Let x be ToNumber(value). // iii. Return the result of calling the FormatNumber abstract // operation (defined below) with arguments this and x. return FormatNumber(this, /* x = */Number(value)); }; // b. Let bind be the standard built-in function object defined in ES5, // 15.3.4.5. // c. Let bf be the result of calling the [[Call]] internal method of // bind with F as the this value and an argument list containing // the single item this. var bf = fnBind.call(F, this); // d. Set the [[boundFormat]] internal property of this NumberFormat // object to bf. internal['[[boundFormat]]'] = bf; } // Return the value of the [[boundFormat]] internal property of this // NumberFormat object. return internal['[[boundFormat]]']; } function formatToParts() { var value = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0]; var internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); if (!internal || !internal['[[initializedNumberFormat]]']) throw new TypeError('`this` value for formatToParts() is not an initialized Intl.NumberFormat object.'); var x = Number(value); return FormatNumberToParts(this, x); } Object.defineProperty(Intl.NumberFormat.prototype, 'formatToParts', { configurable: true, enumerable: false, writable: true, value: formatToParts }); /* * @spec[stasm/ecma402/number-format-to-parts/spec/numberformat.html] * @clause[sec-formatnumbertoparts] */ function FormatNumberToParts(numberFormat, x) { // 1. Let parts be ? PartitionNumberPattern(numberFormat, x). var parts = PartitionNumberPattern(numberFormat, x); // 2. Let result be ArrayCreate(0). var result = []; // 3. Let n be 0. var n = 0; // 4. For each part in parts, do: for (var i = 0; parts.length > i; i++) { var part = parts[i]; // a. Let O be ObjectCreate(%ObjectPrototype%). var O = {}; // a. Perform ? CreateDataPropertyOrThrow(O, "type", part.[[type]]). O.type = part['[[type]]']; // a. Perform ? CreateDataPropertyOrThrow(O, "value", part.[[value]]). O.value = part['[[value]]']; // a. Perform ? CreateDataPropertyOrThrow(result, ? ToString(n), O). result[n] = O; // a. Increment n by 1. n += 1; } // 5. Return result. return result; } /* * @spec[stasm/ecma402/number-format-to-parts/spec/numberformat.html] * @clause[sec-partitionnumberpattern] */ function PartitionNumberPattern(numberFormat, x) { var internal = getInternalProperties(numberFormat), locale = internal['[[dataLocale]]'], nums = internal['[[numberingSystem]]'], data = internals.NumberFormat['[[localeData]]'][locale], ild = data.symbols[nums] || data.symbols.latn, pattern = void 0; // 1. If x is not NaN and x < 0, then: if (!isNaN(x) && x < 0) { // a. Let x be -x. x = -x; // a. Let pattern be the value of numberFormat.[[negativePattern]]. pattern = internal['[[negativePattern]]']; } // 2. Else, else { // a. Let pattern be the value of numberFormat.[[positivePattern]]. pattern = internal['[[positivePattern]]']; } // 3. Let result be a new empty List. var result = new List(); // 4. Let beginIndex be Call(%StringProto_indexOf%, pattern, "{", 0). var beginIndex = pattern.indexOf('{', 0); // 5. Let endIndex be 0. var endIndex = 0; // 6. Let nextIndex be 0. var nextIndex = 0; // 7. Let length be the number of code units in pattern. var length = pattern.length; // 8. Repeat while beginIndex is an integer index into pattern: while (beginIndex > -1 && beginIndex < length) { // a. Set endIndex to Call(%StringProto_indexOf%, pattern, "}", beginIndex) endIndex = pattern.indexOf('}', beginIndex); // a. If endIndex = -1, throw new Error exception. if (endIndex === -1) throw new Error(); // a. If beginIndex is greater than nextIndex, then: if (beginIndex > nextIndex) { // i. Let literal be a substring of pattern from position nextIndex, inclusive, to position beginIndex, exclusive. var literal = pattern.substring(nextIndex, beginIndex); // ii. Add new part record { [[type]]: "literal", [[value]]: literal } as a new element of the list result. arrPush.call(result, { '[[type]]': 'literal', '[[value]]': literal }); } // a. Let p be the substring of pattern from position beginIndex, exclusive, to position endIndex, exclusive. var p = pattern.substring(beginIndex + 1, endIndex); // a. If p is equal "number", then: if (p === "number") { // i. If x is NaN, if (isNaN(x)) { // 1. Let n be an ILD String value indicating the NaN value. var n = ild.nan; // 2. Add new part record { [[type]]: "nan", [[value]]: n } as a new element of the list result. arrPush.call(result, { '[[type]]': 'nan', '[[value]]': n }); } // ii. Else if isFinite(x) is false, else if (!isFinite(x)) { // 1. Let n be an ILD String value indicating infinity. var _n = ild.infinity; // 2. Add new part record { [[type]]: "infinity", [[value]]: n } as a new element of the list result. arrPush.call(result, { '[[type]]': 'infinity', '[[value]]': _n }); } // iii. Else, else { // 1. If the value of numberFormat.[[style]] is "percent" and isFinite(x), let x be 100 × x. if (internal['[[style]]'] === 'percent' && isFinite(x)) x *= 100; var _n2 = void 0; // 2. If the numberFormat.[[minimumSignificantDigits]] and numberFormat.[[maximumSignificantDigits]] are present, then if (hop.call(internal, '[[minimumSignificantDigits]]') && hop.call(internal, '[[maximumSignificantDigits]]')) { // a. Let n be ToRawPrecision(x, numberFormat.[[minimumSignificantDigits]], numberFormat.[[maximumSignificantDigits]]). _n2 = ToRawPrecision(x, internal['[[minimumSignificantDigits]]'], internal['[[maximumSignificantDigits]]']); } // 3. Else, else { // a. Let n be ToRawFixed(x, numberFormat.[[minimumIntegerDigits]], numberFormat.[[minimumFractionDigits]], numberFormat.[[maximumFractionDigits]]). _n2 = ToRawFixed(x, internal['[[minimumIntegerDigits]]'], internal['[[minimumFractionDigits]]'], internal['[[maximumFractionDigits]]']); } // 4. If the value of the numberFormat.[[numberingSystem]] matches one of the values in the "Numbering System" column of Table 2 below, then if (numSys[nums]) { (function () { // a. Let digits be an array whose 10 String valued elements are the UTF-16 string representations of the 10 digits specified in the "Digits" column of the matching row in Table 2. var digits = numSys[nums]; // a. Replace each digit in n with the value of digits[digit]. _n2 = String(_n2).replace(/\d/g, function (digit) { return digits[digit]; }); })(); } // 5. Else use an implementation dependent algorithm to map n to the appropriate representation of n in the given numbering system. else _n2 = String(_n2); // ###TODO### var integer = void 0; var fraction = void 0; // 6. Let decimalSepIndex be Call(%StringProto_indexOf%, n, ".", 0). var decimalSepIndex = _n2.indexOf('.', 0); // 7. If decimalSepIndex > 0, then: if (decimalSepIndex > 0) { // a. Let integer be the substring of n from position 0, inclusive, to position decimalSepIndex, exclusive. integer = _n2.substring(0, decimalSepIndex); // a. Let fraction be the substring of n from position decimalSepIndex, exclusive, to the end of n. fraction = _n2.substring(decimalSepIndex + 1, decimalSepIndex.length); } // 8. Else: else { // a. Let integer be n. integer = _n2; // a. Let fraction be undefined. fraction = undefined; } // 9. If the value of the numberFormat.[[useGrouping]] is true, if (internal['[[useGrouping]]'] === true) { // a. Let groupSepSymbol be the ILND String representing the grouping separator. var groupSepSymbol = ild.group; // a. Let groups be a List whose elements are, in left to right order, the substrings defined by ILND set of locations within the integer. var groups = []; // ----> implementation: // Primary group represents the group closest to the decimal var pgSize = data.patterns.primaryGroupSize || 3; // Secondary group is every other group var sgSize = data.patterns.secondaryGroupSize || pgSize; // Group only if necessary if (integer.length > pgSize) { // Index of the primary grouping separator var end = integer.length - pgSize; // Starting index for our loop var idx = end % sgSize; var start = integer.slice(0, idx); if (start.length) arrPush.call(groups, start); // Loop to separate into secondary grouping digits while (idx < end) { arrPush.call(groups, integer.slice(idx, idx + sgSize)); idx += sgSize; } // Add the primary grouping digits arrPush.call(groups, integer.slice(end)); } else { arrPush.call(groups, integer); } // a. Assert: The number of elements in groups List is greater than 0. if (groups.length === 0) throw new Error(); // a. Repeat, while groups List is not empty: while (groups.length) { // i. Remove the first element from groups and let integerGroup be the value of that element. var integerGroup = arrShift.call(groups); // ii. Add new part record { [[type]]: "integer", [[value]]: integerGroup } as a new element of the list result. arrPush.call(result, { '[[type]]': 'integer', '[[value]]': integerGroup }); // iii. If groups List is not empty, then: if (groups.length) { // 1. Add new part record { [[type]]: "group", [[value]]: groupSepSymbol } as a new element of the list result. arrPush.call(result, { '[[type]]': 'group', '[[value]]': groupSepSymbol }); } } } // 10. Else, else { // a. Add new part record { [[type]]: "integer", [[value]]: integer } as a new element of the list result. arrPush.call(result, { '[[type]]': 'integer', '[[value]]': integer }); } // 11. If fraction is not undefined, then: if (fraction !== undefined) { // a. Let decimalSepSymbol be the ILND String representing the decimal separator. var decimalSepSymbol = ild.decimal; // a. Add new part record { [[type]]: "decimal", [[value]]: decimalSepSymbol } as a new element of the list result. arrPush.call(result, { '[[type]]': 'decimal', '[[value]]': decimalSepSymbol }); // a. Add new part record { [[type]]: "fraction", [[value]]: fraction } as a new element of the list result. arrPush.call(result, { '[[type]]': 'fraction', '[[value]]': fraction }); } } } // a. Else if p is equal "plusSign", then: else if (p === "plusSign") { // i. Let plusSignSymbol be the ILND String representing the plus sign. var plusSignSymbol = ild.plusSign; // ii. Add new part record { [[type]]: "plusSign", [[value]]: plusSignSymbol } as a new element of the list result. arrPush.call(result, { '[[type]]': 'plusSign', '[[value]]': plusSignSymbol }); } // a. Else if p is equal "minusSign", then: else if (p === "minusSign") { // i. Let minusSignSymbol be the ILND String representing the minus sign. var minusSignSymbol = ild.minusSign; // ii. Add new part record { [[type]]: "minusSign", [[value]]: minusSignSymbol } as a new element of the list result. arrPush.call(result, { '[[type]]': 'minusSign', '[[value]]': minusSignSymbol }); } // a. Else if p is equal "percentSign" and numberFormat.[[style]] is "percent", then: else if (p === "percentSign" && internal['[[style]]'] === "percent") { // i. Let percentSignSymbol be the ILND String representing the percent sign. var percentSignSymbol = ild.percentSign; // ii. Add new part record { [[type]]: "percentSign", [[value]]: percentSignSymbol } as a new element of the list result. arrPush.call(result, { '[[type]]': 'literal', '[[value]]': percentSignSymbol }); } // a. Else if p is equal "currency" and numberFormat.[[style]] is "currency", then: else if (p === "currency" && internal['[[style]]'] === "currency") { // i. Let currency be the value of numberFormat.[[currency]]. var currency = internal['[[currency]]']; var cd = void 0; // ii. If numberFormat.[[currencyDisplay]] is "code", then if (internal['[[currencyDisplay]]'] === "code") { // 1. Let cd be currency. cd = currency; } // iii. Else if numberFormat.[[currencyDisplay]] is "symbol", then else if (internal['[[currencyDisplay]]'] === "symbol") { // 1. Let cd be an ILD string representing currency in short form. If the implementation does not have such a representation of currency, use currency itself. cd = data.currencies[currency] || currency; } // iv. Else if numberFormat.[[currencyDisplay]] is "name", then else if (internal['[[currencyDisplay]]'] === "name") { // 1. Let cd be an ILD string representing currency in long form. If the implementation does not have such a representation of currency, then use currency itself. cd = currency; } // v. Add new part record { [[type]]: "currency", [[value]]: cd } as a new element of the list result. arrPush.call(result, { '[[type]]': 'currency', '[[value]]': cd }); } // a. Else, else { // i. Let literal be the substring of pattern from position beginIndex, inclusive, to position endIndex, inclusive. var _literal = pattern.substring(beginIndex, endIndex); // ii. Add new part record { [[type]]: "literal", [[value]]: literal } as a new element of the list result. arrPush.call(result, { '[[type]]': 'literal', '[[value]]': _literal }); } // a. Set nextIndex to endIndex + 1. nextIndex = endIndex + 1; // a. Set beginIndex to Call(%StringProto_indexOf%, pattern, "{", nextIndex) beginIndex = pattern.indexOf('{', nextIndex); } // 9. If nextIndex is less than length, then: if (nextIndex < length) { // a. Let literal be the substring of pattern from position nextIndex, inclusive, to position length, exclusive. var _literal2 = pattern.substring(nextIndex, length); // a. Add new part record { [[type]]: "literal", [[value]]: literal } as a new element of the list result. arrPush.call(result, { '[[type]]': 'literal', '[[value]]': _literal2 }); } // 10. Return result. return result; } /* * @spec[stasm/ecma402/number-format-to-parts/spec/numberformat.html] * @clause[sec-formatnumber] */ function FormatNumber(numberFormat, x) { // 1. Let parts be ? PartitionNumberPattern(numberFormat, x). var parts = PartitionNumberPattern(numberFormat, x); // 2. Let result be an empty String. var result = ''; // 3. For each part in parts, do: for (var i = 0; parts.length > i; i++) { var part = parts[i]; // a. Set result to a String value produced by concatenating result and part.[[value]]. result += part['[[value]]']; } // 4. Return result. return result; } /** * When the ToRawPrecision abstract operation is called with arguments x (which * must be a finite non-negative number), minPrecision, and maxPrecision (both * must be integers between 1 and 21) the following steps are taken: */ function ToRawPrecision(x, minPrecision, maxPrecision) { // 1. Let p be maxPrecision. var p = maxPrecision; var m = void 0, e = void 0; // 2. If x = 0, then if (x === 0) { // a. Let m be the String consisting of p occurrences of the character "0". m = arrJoin.call(Array(p + 1), '0'); // b. Let e be 0. e = 0; } // 3. Else else { // a. Let e and n be integers such that 10ᵖ⁻¹ ≤ n < 10ᵖ and for which the // exact mathematical value of n × 10ᵉ⁻ᵖ⁺¹ – x is as close to zero as // possible. If there are two such sets of e and n, pick the e and n for // which n × 10ᵉ⁻ᵖ⁺¹ is larger. e = log10Floor(Math.abs(x)); // Easier to get to m from here var f = Math.round(Math.exp(Math.abs(e - p + 1) * Math.LN10)); // b. Let m be the String consisting of the digits of the decimal // representation of n (in order, with no leading zeroes) m = String(Math.round(e - p + 1 < 0 ? x * f : x / f)); } // 4. If e ≥ p, then if (e >= p) // a. Return the concatenation of m and e-p+1 occurrences of the character "0". return m + arrJoin.call(Array(e - p + 1 + 1), '0'); // 5. If e = p-1, then else if (e === p - 1) // a. Return m. return m; // 6. If e ≥ 0, then else if (e >= 0) // a. Let m be the concatenation of the first e+1 characters of m, the character // ".", and the remaining p–(e+1) characters of m. m = m.slice(0, e + 1) + '.' + m.slice(e + 1); // 7. If e < 0, then else if (e < 0) // a. Let m be the concatenation of the String "0.", –(e+1) occurrences of the // character "0", and the string m. m = '0.' + arrJoin.call(Array(-(e + 1) + 1), '0') + m; // 8. If m contains the character ".", and maxPrecision > minPrecision, then if (m.indexOf(".") >= 0 && maxPrecision > minPrecision) { // a. Let cut be maxPrecision – minPrecision. var cut = maxPrecision - minPrecision; // b. Repeat while cut > 0 and the last character of m is "0": while (cut > 0 && m.charAt(m.length - 1) === '0') { // i. Remove the last character from m. m = m.slice(0, -1); // ii. Decrease cut by 1. cut--; } // c. If the last character of m is ".", then if (m.charAt(m.length - 1) === '.') // i. Remove the last character from m. m = m.slice(0, -1); } // 9. Return m. return m; } /** * @spec[tc39/ecma402/master/spec/numberformat.html] * @clause[sec-torawfixed] * When the ToRawFixed abstract operation is called with arguments x (which must * be a finite non-negative number), minInteger (which must be an integer between * 1 and 21), minFraction, and maxFraction (which must be integers between 0 and * 20) the following steps are taken: */ function ToRawFixed(x, minInteger, minFraction, maxFraction) { // 1. Let f be maxFraction. var f = maxFraction; // 2. Let n be an integer for which the exact mathematical value of n ÷ 10f – x is as close to zero as possible. If there are two such n, pick the larger n. var n = Math.pow(10, f) * x; // diverging... // 3. If n = 0, let m be the String "0". Otherwise, let m be the String consisting of the digits of the decimal representation of n (in order, with no leading zeroes). var m = n === 0 ? "0" : n.toFixed(0); // divering... { // this diversion is needed to take into consideration big numbers, e.g.: // 1.2344501e+37 -> 12344501000000000000000000000000000000 var idx = void 0; var exp = (idx = m.indexOf('e')) > -1 ? m.slice(idx + 1) : 0; if (exp) { m = m.slice(0, idx).replace('.', ''); m += arrJoin.call(Array(exp - (m.length - 1) + 1), '0'); } } var int = void 0; // 4. If f ≠ 0, then if (f !== 0) { // a. Let k be the number of characters in m. var k = m.length; // a. If k ≤ f, then if (k <= f) { // i. Let z be the String consisting of f+1–k occurrences of the character "0". var z = arrJoin.call(Array(f + 1 - k + 1), '0'); // ii. Let m be the concatenation of Strings z and m. m = z + m; // iii. Let k be f+1. k = f + 1; } // a. Let a be the first k–f characters of m, and let b be the remaining f characters of m. var a = m.substring(0, k - f), b = m.substring(k - f, m.length); // a. Let m be the concatenation of the three Strings a, ".", and b. m = a + "." + b; // a. Let int be the number of characters in a. int = a.length; } // 5. Else, let int be the number of characters in m. else int = m.length; // 6. Let cut be maxFraction – minFraction. var cut = maxFraction - minFraction; // 7. Repeat while cut > 0 and the last character of m is "0": while (cut > 0 && m.slice(-1) === "0") { // a. Remove the last character from m. m = m.slice(0, -1); // a. Decrease cut by 1. cut--; } // 8. If the last character of m is ".", then if (m.slice(-1) === ".") { // a. Remove the last character from m. m = m.slice(0, -1); } // 9. If int < minInteger, then if (int < minInteger) { // a. Let z be the String consisting of minInteger–int occurrences of the character "0". var _z = arrJoin.call(Array(minInteger - int + 1), '0'); // a. Let m be the concatenation of Strings z and m. m = _z + m; } // 10. Return m. return m; } // Sect 11.3.2 Table 2, Numbering systems // ====================================== var numSys = { arab: ["٠", "١", "٢", "٣", "٤", "٥", "٦", "٧", "٨", "٩"], arabext: ["۰", "۱", "۲", "۳", "۴", "۵", "۶", "۷", "۸", "۹"], bali: ["᭐", "᭑", "᭒", "᭓", "᭔", "᭕", "᭖", "᭗", "᭘", "᭙"], beng: ["০", "১", "২", "৩", "৪", "৫", "৬", "৭", "৮", "৯"], deva: ["०", "१", "२", "३", "४", "५", "६", "७", "८", "९"], fullwide: ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"], gujr: ["૦", "૧", "૨", "૩", "૪", "૫", "૬", "૭", "૮", "૯"], guru: ["੦", "੧", "੨", "੩", "੪", "੫", "੬", "੭", "੮", "੯"], hanidec: ["〇", "一", "二", "三", "四", "五", "六", "七", "八", "九"], khmr: ["០", "១", "២", "៣", "៤", "៥", "៦", "៧", "៨", "៩"], knda: ["೦", "೧", "೨", "೩", "೪", "೫", "೬", "೭", "೮", "೯"], laoo: ["໐", "໑", "໒", "໓", "໔", "໕", "໖", "໗", "໘", "໙"], latn: ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"], limb: ["᥆", "᥇", "᥈", "᥉", "᥊", "᥋", "᥌", "᥍", "᥎", "᥏"], mlym: ["൦", "൧", "൨", "൩", "൪", "൫", "൬", "൭", "൮", "൯"], mong: ["᠐", "᠑", "᠒", "᠓", "᠔", "᠕", "᠖", "᠗", "᠘", "᠙"], mymr: ["၀", "၁", "၂", "၃", "၄", "၅", "၆", "၇", "၈", "၉"], orya: ["୦", "୧", "୨", "୩", "୪", "୫", "୬", "୭", "୮", "୯"], tamldec: ["௦", "௧", "௨", "௩", "௪", "௫", "௬", "௭", "௮", "௯"], telu: ["౦", "౧", "౨", "౩", "౪", "౫", "౬", "౭", "౮", "౯"], thai: ["๐", "๑", "๒", "๓", "๔", "๕", "๖", "๗", "๘", "๙"], tibt: ["༠", "༡", "༢", "༣", "༤", "༥", "༦", "༧", "༨", "༩"] }; /** * This function provides access to the locale and formatting options computed * during initialization of the object. * * The function returns a new object whose properties and attributes are set as * if constructed by an object literal assigning to each of the following * properties the value of the corresponding internal property of this * NumberFormat object (see 11.4): locale, numberingSystem, style, currency, * currencyDisplay, minimumIntegerDigits, minimumFractionDigits, * maximumFractionDigits, minimumSignificantDigits, maximumSignificantDigits, and * useGrouping. Properties whose corresponding internal properties are not present * are not assigned. */ /* 11.3.3 */defineProperty(Intl.NumberFormat.prototype, 'resolvedOptions', { configurable: true, writable: true, value: function value() { var prop = void 0, descs = new Record(), props = ['locale', 'numberingSystem', 'style', 'currency', 'currencyDisplay', 'minimumIntegerDigits', 'minimumFractionDigits', 'maximumFractionDigits', 'minimumSignificantDigits', 'maximumSignificantDigits', 'useGrouping'], internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); // Satisfy test 11.3_b if (!internal || !internal['[[initializedNumberFormat]]']) throw new TypeError('`this` value for resolvedOptions() is not an initialized Intl.NumberFormat object.'); for (var i = 0, max = props.length; i < max; i++) { if (hop.call(internal, prop = '[[' + props[i] + ']]')) descs[props[i]] = { value: internal[prop], writable: true, configurable: true, enumerable: true }; } return objCreate({}, descs); } }); /* jslint esnext: true */ // Match these datetime components in a CLDR pattern, except those in single quotes var expDTComponents = /(?:[Eec]{1,6}|G{1,5}|[Qq]{1,5}|(?:[yYur]+|U{1,5})|[ML]{1,5}|d{1,2}|D{1,3}|F{1}|[abB]{1,5}|[hkHK]{1,2}|w{1,2}|W{1}|m{1,2}|s{1,2}|[zZOvVxX]{1,4})(?=([^']*'[^']*')*[^']*$)/g; // trim patterns after transformations var expPatternTrimmer = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g; // Skip over patterns with these datetime components because we don't have data // to back them up: // timezone, weekday, amoung others var unwantedDTCs = /[rqQASjJgwWIQq]/; // xXVO were removed from this list in favor of computing matches with timeZoneName values but printing as empty string var dtKeys = ["era", "year", "month", "day", "weekday", "quarter"]; var tmKeys = ["hour", "minute", "second", "hour12", "timeZoneName"]; function isDateFormatOnly(obj) { for (var i = 0; i < tmKeys.length; i += 1) { if (obj.hasOwnProperty(tmKeys[i])) { return false; } } return true; } function isTimeFormatOnly(obj) { for (var i = 0; i < dtKeys.length; i += 1) { if (obj.hasOwnProperty(dtKeys[i])) { return false; } } return true; } function joinDateAndTimeFormats(dateFormatObj, timeFormatObj) { var o = { _: {} }; for (var i = 0; i < dtKeys.length; i += 1) { if (dateFormatObj[dtKeys[i]]) { o[dtKeys[i]] = dateFormatObj[dtKeys[i]]; } if (dateFormatObj._[dtKeys[i]]) { o._[dtKeys[i]] = dateFormatObj._[dtKeys[i]]; } } for (var j = 0; j < tmKeys.length; j += 1) { if (timeFormatObj[tmKeys[j]]) { o[tmKeys[j]] = timeFormatObj[tmKeys[j]]; } if (timeFormatObj._[tmKeys[j]]) { o._[tmKeys[j]] = timeFormatObj._[tmKeys[j]]; } } return o; } function computeFinalPatterns(formatObj) { // From http://www.unicode.org/reports/tr35/tr35-dates.html#Date_Format_Patterns: // 'In patterns, two single quotes represents a literal single quote, either // inside or outside single quotes. Text within single quotes is not // interpreted in any way (except for two adjacent single quotes).' formatObj.pattern12 = formatObj.extendedPattern.replace(/'([^']*)'/g, function ($0, literal) { return literal ? literal : "'"; }); // pattern 12 is always the default. we can produce the 24 by removing {ampm} formatObj.pattern = formatObj.pattern12.replace('{ampm}', '').replace(expPatternTrimmer, ''); return formatObj; } function expDTComponentsMeta($0, formatObj) { switch ($0.charAt(0)) { // --- Era case 'G': formatObj.era = ['short', 'short', 'short', 'long', 'narrow'][$0.length - 1]; return '{era}'; // --- Year case 'y': case 'Y': case 'u': case 'U': case 'r': formatObj.year = $0.length === 2 ? '2-digit' : 'numeric'; return '{year}'; // --- Quarter (not supported in this polyfill) case 'Q': case 'q': formatObj.quarter = ['numeric', '2-digit', 'short', 'long', 'narrow'][$0.length - 1]; return '{quarter}'; // --- Month case 'M': case 'L': formatObj.month = ['numeric', '2-digit', 'short', 'long', 'narrow'][$0.length - 1]; return '{month}'; // --- Week (not supported in this polyfill) case 'w': // week of the year formatObj.week = $0.length === 2 ? '2-digit' : 'numeric'; return '{weekday}'; case 'W': // week of the month formatObj.week = 'numeric'; return '{weekday}'; // --- Day case 'd': // day of the month formatObj.day = $0.length === 2 ? '2-digit' : 'numeric'; return '{day}'; case 'D': // day of the year case 'F': // day of the week case 'g': // 1..n: Modified Julian day formatObj.day = 'numeric'; return '{day}'; // --- Week Day case 'E': // day of the week formatObj.weekday = ['short', 'short', 'short', 'long', 'narrow', 'short'][$0.length - 1]; return '{weekday}'; case 'e': // local day of the week formatObj.weekday = ['numeric', '2-digit', 'short', 'long', 'narrow', 'short'][$0.length - 1]; return '{weekday}'; case 'c': // stand alone local day of the week formatObj.weekday = ['numeric', undefined, 'short', 'long', 'narrow', 'short'][$0.length - 1]; return '{weekday}'; // --- Period case 'a': // AM, PM case 'b': // am, pm, noon, midnight case 'B': // flexible day periods formatObj.hour12 = true; return '{ampm}'; // --- Hour case 'h': case 'H': formatObj.hour = $0.length === 2 ? '2-digit' : 'numeric'; return '{hour}'; case 'k': case 'K': formatObj.hour12 = true; // 12-hour-cycle time formats (using h or K) formatObj.hour = $0.length === 2 ? '2-digit' : 'numeric'; return '{hour}'; // --- Minute case 'm': formatObj.minute = $0.length === 2 ? '2-digit' : 'numeric'; return '{minute}'; // --- Second case 's': formatObj.second = $0.length === 2 ? '2-digit' : 'numeric'; return '{second}'; case 'S': case 'A': formatObj.second = 'numeric'; return '{second}'; // --- Timezone case 'z': // 1..3, 4: specific non-location format case 'Z': // 1..3, 4, 5: The ISO8601 varios formats case 'O': // 1, 4: miliseconds in day short, long case 'v': // 1, 4: generic non-location format case 'V': // 1, 2, 3, 4: time zone ID or city case 'X': // 1, 2, 3, 4: The ISO8601 varios formats case 'x': // 1, 2, 3, 4: The ISO8601 varios formats // this polyfill only supports much, for now, we are just doing something dummy formatObj.timeZoneName = $0.length < 4 ? 'short' : 'long'; return '{timeZoneName}'; } } /** * Converts the CLDR availableFormats into the objects and patterns required by * the ECMAScript Internationalization API specification. */ function createDateTimeFormat(skeleton, pattern) { // we ignore certain patterns that are unsupported to avoid this expensive op. if (unwantedDTCs.test(pattern)) return undefined; var formatObj = { originalPattern: pattern, _: {} }; // Replace the pattern string with the one required by the specification, whilst // at the same time evaluating it for the subsets and formats formatObj.extendedPattern = pattern.replace(expDTComponents, function ($0) { // See which symbol we're dealing with return expDTComponentsMeta($0, formatObj._); }); // Match the skeleton string with the one required by the specification // this implementation is based on the Date Field Symbol Table: // http://unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table // Note: we are adding extra data to the formatObject even though this polyfill // might not support it. skeleton.replace(expDTComponents, function ($0) { // See which symbol we're dealing with return expDTComponentsMeta($0, formatObj); }); return computeFinalPatterns(formatObj); } /** * Processes DateTime formats from CLDR to an easier-to-parse format. * the result of this operation should be cached the first time a particular * calendar is analyzed. * * The specification requires we support at least the following subsets of * date/time components: * * - 'weekday', 'year', 'month', 'day', 'hour', 'minute', 'second' * - 'weekday', 'year', 'month', 'day' * - 'year', 'month', 'day' * - 'year', 'month' * - 'month', 'day' * - 'hour', 'minute', 'second' * - 'hour', 'minute' * * We need to cherry pick at least these subsets from the CLDR data and convert * them into the pattern objects used in the ECMA-402 API. */ function createDateTimeFormats(formats) { var availableFormats = formats.availableFormats; var timeFormats = formats.timeFormats; var dateFormats = formats.dateFormats; var result = []; var skeleton = void 0, pattern = void 0, computed = void 0, i = void 0, j = void 0; var timeRelatedFormats = []; var dateRelatedFormats = []; // Map available (custom) formats into a pattern for createDateTimeFormats for (skeleton in availableFormats) { if (availableFormats.hasOwnProperty(skeleton)) { pattern = availableFormats[skeleton]; computed = createDateTimeFormat(skeleton, pattern); if (computed) { result.push(computed); // in some cases, the format is only displaying date specific props // or time specific props, in which case we need to also produce the // combined formats. if (isDateFormatOnly(computed)) { dateRelatedFormats.push(computed); } else if (isTimeFormatOnly(computed)) { timeRelatedFormats.push(computed); } } } } // Map time formats into a pattern for createDateTimeFormats for (skeleton in timeFormats) { if (timeFormats.hasOwnProperty(skeleton)) { pattern = timeFormats[skeleton]; computed = createDateTimeFormat(skeleton, pattern); if (computed) { result.push(computed); timeRelatedFormats.push(computed); } } } // Map date formats into a pattern for createDateTimeFormats for (skeleton in dateFormats) { if (dateFormats.hasOwnProperty(skeleton)) { pattern = dateFormats[skeleton]; computed = createDateTimeFormat(skeleton, pattern); if (computed) { result.push(computed); dateRelatedFormats.push(computed); } } } // combine custom time and custom date formats when they are orthogonals to complete the // formats supported by CLDR. // This Algo is based on section "Missing Skeleton Fields" from: // http://unicode.org/reports/tr35/tr35-dates.html#availableFormats_appendItems for (i = 0; i < timeRelatedFormats.length; i += 1) { for (j = 0; j < dateRelatedFormats.length; j += 1) { if (dateRelatedFormats[j].month === 'long') { pattern = dateRelatedFormats[j].weekday ? formats.full : formats.long; } else if (dateRelatedFormats[j].month === 'short') { pattern = formats.medium; } else { pattern = formats.short; } computed = joinDateAndTimeFormats(dateRelatedFormats[j], timeRelatedFormats[i]); computed.originalPattern = pattern; computed.extendedPattern = pattern.replace('{0}', timeRelatedFormats[i].extendedPattern).replace('{1}', dateRelatedFormats[j].extendedPattern).replace(/^[,\s]+|[,\s]+$/gi, ''); result.push(computeFinalPatterns(computed)); } } return result; } // this represents the exceptions of the rule that are not covered by CLDR availableFormats // for single property configurations, they play no role when using multiple properties, and // those that are not in this table, are not exceptions or are not covered by the data we // provide. var validSyntheticProps = { second: { numeric: 's', '2-digit': 'ss' }, minute: { numeric: 'm', '2-digit': 'mm' }, year: { numeric: 'y', '2-digit': 'yy' }, day: { numeric: 'd', '2-digit': 'dd' }, month: { numeric: 'L', '2-digit': 'LL', narrow: 'LLLLL', short: 'LLL', long: 'LLLL' }, weekday: { narrow: 'ccccc', short: 'ccc', long: 'cccc' } }; function generateSyntheticFormat(propName, propValue) { if (validSyntheticProps[propName] && validSyntheticProps[propName][propValue]) { var _ref2; return _ref2 = { originalPattern: validSyntheticProps[propName][propValue], _: defineProperty$1({}, propName, propValue), extendedPattern: "{" + propName + "}" }, defineProperty$1(_ref2, propName, propValue), defineProperty$1(_ref2, "pattern12", "{" + propName + "}"), defineProperty$1(_ref2, "pattern", "{" + propName + "}"), _ref2; } } // An object map of date component keys, saves using a regex later var dateWidths = objCreate(null, { narrow: {}, short: {}, long: {} }); /** * Returns a string for a date component, resolved using multiple inheritance as specified * as specified in the Unicode Technical Standard 35. */ function resolveDateString(data, ca, component, width, key) { // From http://www.unicode.org/reports/tr35/tr35.html#Multiple_Inheritance: // 'In clearly specified instances, resources may inherit from within the same locale. // For example, ... the Buddhist calendar inherits from the Gregorian calendar.' var obj = data[ca] && data[ca][component] ? data[ca][component] : data.gregory[component], // "sideways" inheritance resolves strings when a key doesn't exist alts = { narrow: ['short', 'long'], short: ['long', 'narrow'], long: ['short', 'narrow'] }, // resolved = hop.call(obj, width) ? obj[width] : hop.call(obj, alts[width][0]) ? obj[alts[width][0]] : obj[alts[width][1]]; // `key` wouldn't be specified for components 'dayPeriods' return key !== null ? resolved[key] : resolved; } // Define the DateTimeFormat constructor internally so it cannot be tainted function DateTimeFormatConstructor() { var locales = arguments[0]; var options = arguments[1]; if (!this || this === Intl) { return new Intl.DateTimeFormat(locales, options); } return InitializeDateTimeFormat(toObject(this), locales, options); } defineProperty(Intl, 'DateTimeFormat', { configurable: true, writable: true, value: DateTimeFormatConstructor }); // Must explicitly set prototypes as unwritable defineProperty(DateTimeFormatConstructor, 'prototype', { writable: false }); /** * The abstract operation InitializeDateTimeFormat accepts the arguments dateTimeFormat * (which must be an object), locales, and options. It initializes dateTimeFormat as a * DateTimeFormat object. */ function /* 12.1.1.1 */InitializeDateTimeFormat(dateTimeFormat, locales, options) { // This will be a internal properties object if we're not already initialized var internal = getInternalProperties(dateTimeFormat); // Create an object whose props can be used to restore the values of RegExp props var regexpRestore = createRegExpRestore(); // 1. If dateTimeFormat has an [[initializedIntlObject]] internal property with // value true, throw a TypeError exception. if (internal['[[initializedIntlObject]]'] === true) throw new TypeError('`this` object has already been initialized as an Intl object'); // Need this to access the `internal` object defineProperty(dateTimeFormat, '__getInternalProperties', { value: function value() { // NOTE: Non-standard, for internal use only if (arguments[0] === secret) return internal; } }); // 2. Set the [[initializedIntlObject]] internal property of numberFormat to true. internal['[[initializedIntlObject]]'] = true; // 3. Let requestedLocales be the result of calling the CanonicalizeLocaleList // abstract operation (defined in 9.2.1) with argument locales. var requestedLocales = CanonicalizeLocaleList(locales); // 4. Let options be the result of calling the ToDateTimeOptions abstract // operation (defined below) with arguments options, "any", and "date". options = ToDateTimeOptions(options, 'any', 'date'); // 5. Let opt be a new Record. var opt = new Record(); // 6. Let matcher be the result of calling the GetOption abstract operation // (defined in 9.2.9) with arguments options, "localeMatcher", "string", a List // containing the two String values "lookup" and "best fit", and "best fit". var matcher = GetOption(options, 'localeMatcher', 'string', new List('lookup', 'best fit'), 'best fit'); // 7. Set opt.[[localeMatcher]] to matcher. opt['[[localeMatcher]]'] = matcher; // 8. Let DateTimeFormat be the standard built-in object that is the initial // value of Intl.DateTimeFormat. var DateTimeFormat = internals.DateTimeFormat; // This is what we *really* need // 9. Let localeData be the value of the [[localeData]] internal property of // DateTimeFormat. var localeData = DateTimeFormat['[[localeData]]']; // 10. Let r be the result of calling the ResolveLocale abstract operation // (defined in 9.2.5) with the [[availableLocales]] internal property of // DateTimeFormat, requestedLocales, opt, the [[relevantExtensionKeys]] // internal property of DateTimeFormat, and localeData. var r = ResolveLocale(DateTimeFormat['[[availableLocales]]'], requestedLocales, opt, DateTimeFormat['[[relevantExtensionKeys]]'], localeData); // 11. Set the [[locale]] internal property of dateTimeFormat to the value of // r.[[locale]]. internal['[[locale]]'] = r['[[locale]]']; // 12. Set the [[calendar]] internal property of dateTimeFormat to the value of // r.[[ca]]. internal['[[calendar]]'] = r['[[ca]]']; // 13. Set the [[numberingSystem]] internal property of dateTimeFormat to the value of // r.[[nu]]. internal['[[numberingSystem]]'] = r['[[nu]]']; // The specification doesn't tell us to do this, but it's helpful later on internal['[[dataLocale]]'] = r['[[dataLocale]]']; // 14. Let dataLocale be the value of r.[[dataLocale]]. var dataLocale = r['[[dataLocale]]']; // 15. Let tz be the result of calling the [[Get]] internal method of options with // argument "timeZone". var tz = options.timeZone; // 16. If tz is not undefined, then if (tz !== undefined) { // a. Let tz be ToString(tz). // b. Convert tz to upper case as described in 6.1. // NOTE: If an implementation accepts additional time zone values, as permitted // under certain conditions by the Conformance clause, different casing // rules apply. tz = toLatinUpperCase(tz); // c. If tz is not "UTC", then throw a RangeError exception. // ###TODO: accept more time zones### if (tz !== 'UTC') throw new RangeError('timeZone is not supported.'); } // 17. Set the [[timeZone]] internal property of dateTimeFormat to tz. internal['[[timeZone]]'] = tz; // 18. Let opt be a new Record. opt = new Record(); // 19. For each row of Table 3, except the header row, do: for (var prop in dateTimeComponents) { if (!hop.call(dateTimeComponents, prop)) continue; // 20. Let prop be the name given in the Property column of the row. // 21. Let value be the result of calling the GetOption abstract operation, // passing as argument options, the name given in the Property column of the // row, "string", a List containing the strings given in the Values column of // the row, and undefined. var value = GetOption(options, prop, 'string', dateTimeComponents[prop]); // 22. Set opt.[[<prop>]] to value. opt['[[' + prop + ']]'] = value; } // Assigned a value below var bestFormat = void 0; // 23. Let dataLocaleData be the result of calling the [[Get]] internal method of // localeData with argument dataLocale. var dataLocaleData = localeData[dataLocale]; // 24. Let formats be the result of calling the [[Get]] internal method of // dataLocaleData with argument "formats". // Note: we process the CLDR formats into the spec'd structure var formats = ToDateTimeFormats(dataLocaleData.formats); // 25. Let matcher be the result of calling the GetOption abstract operation with // arguments options, "formatMatcher", "string", a List containing the two String // values "basic" and "best fit", and "best fit". matcher = GetOption(options, 'formatMatcher', 'string', new List('basic', 'best fit'), 'best fit'); // Optimization: caching the processed formats as a one time operation by // replacing the initial structure from localeData dataLocaleData.formats = formats; // 26. If matcher is "basic", then if (matcher === 'basic') { // 27. Let bestFormat be the result of calling the BasicFormatMatcher abstract // operation (defined below) with opt and formats. bestFormat = BasicFormatMatcher(opt, formats); // 28. Else } else { { // diverging var _hr = GetOption(options, 'hour12', 'boolean' /*, undefined, undefined*/); opt.hour12 = _hr === undefined ? dataLocaleData.hour12 : _hr; } // 29. Let bestFormat be the result of calling the BestFitFormatMatcher // abstract operation (defined below) with opt and formats. bestFormat = BestFitFormatMatcher(opt, formats); } // 30. For each row in Table 3, except the header row, do for (var _prop in dateTimeComponents) { if (!hop.call(dateTimeComponents, _prop)) continue; // a. Let prop be the name given in the Property column of the row. // b. Let pDesc be the result of calling the [[GetOwnProperty]] internal method of // bestFormat with argument prop. // c. If pDesc is not undefined, then if (hop.call(bestFormat, _prop)) { // i. Let p be the result of calling the [[Get]] internal method of bestFormat // with argument prop. var p = bestFormat[_prop]; { // diverging p = bestFormat._ && hop.call(bestFormat._, _prop) ? bestFormat._[_prop] : p; } // ii. Set the [[<prop>]] internal property of dateTimeFormat to p. internal['[[' + _prop + ']]'] = p; } } var pattern = void 0; // Assigned a value below // 31. Let hr12 be the result of calling the GetOption abstract operation with // arguments options, "hour12", "boolean", undefined, and undefined. var hr12 = GetOption(options, 'hour12', 'boolean' /*, undefined, undefined*/); // 32. If dateTimeFormat has an internal property [[hour]], then if (internal['[[hour]]']) { // a. If hr12 is undefined, then let hr12 be the result of calling the [[Get]] // internal method of dataLocaleData with argument "hour12". hr12 = hr12 === undefined ? dataLocaleData.hour12 : hr12; // b. Set the [[hour12]] internal property of dateTimeFormat to hr12. internal['[[hour12]]'] = hr12; // c. If hr12 is true, then if (hr12 === true) { // i. Let hourNo0 be the result of calling the [[Get]] internal method of // dataLocaleData with argument "hourNo0". var hourNo0 = dataLocaleData.hourNo0; // ii. Set the [[hourNo0]] internal property of dateTimeFormat to hourNo0. internal['[[hourNo0]]'] = hourNo0; // iii. Let pattern be the result of calling the [[Get]] internal method of // bestFormat with argument "pattern12". pattern = bestFormat.pattern12; } // d. Else else // i. Let pattern be the result of calling the [[Get]] internal method of // bestFormat with argument "pattern". pattern = bestFormat.pattern; } // 33. Else else // a. Let pattern be the result of calling the [[Get]] internal method of // bestFormat with argument "pattern". pattern = bestFormat.pattern; // 34. Set the [[pattern]] internal property of dateTimeFormat to pattern. internal['[[pattern]]'] = pattern; // 35. Set the [[boundFormat]] internal property of dateTimeFormat to undefined. internal['[[boundFormat]]'] = undefined; // 36. Set the [[initializedDateTimeFormat]] internal property of dateTimeFormat to // true. internal['[[initializedDateTimeFormat]]'] = true; // In ES3, we need to pre-bind the format() function if (es3) dateTimeFormat.format = GetFormatDateTime.call(dateTimeFormat); // Restore the RegExp properties regexpRestore(); // Return the newly initialised object return dateTimeFormat; } /** * Several DateTimeFormat algorithms use values from the following table, which provides * property names and allowable values for the components of date and time formats: */ var dateTimeComponents = { weekday: ["narrow", "short", "long"], era: ["narrow", "short", "long"], year: ["2-digit", "numeric"], month: ["2-digit", "numeric", "narrow", "short", "long"], day: ["2-digit", "numeric"], hour: ["2-digit", "numeric"], minute: ["2-digit", "numeric"], second: ["2-digit", "numeric"], timeZoneName: ["short", "long"] }; /** * When the ToDateTimeOptions abstract operation is called with arguments options, * required, and defaults, the following steps are taken: */ function ToDateTimeFormats(formats) { if (Object.prototype.toString.call(formats) === '[object Array]') { return formats; } return createDateTimeFormats(formats); } /** * When the ToDateTimeOptions abstract operation is called with arguments options, * required, and defaults, the following steps are taken: */ function ToDateTimeOptions(options, required, defaults) { // 1. If options is undefined, then let options be null, else let options be // ToObject(options). if (options === undefined) options = null;else { // (#12) options needs to be a Record, but it also needs to inherit properties var opt2 = toObject(options); options = new Record(); for (var k in opt2) { options[k] = opt2[k]; } } // 2. Let create be the standard built-in function object defined in ES5, 15.2.3.5. var create = objCreate; // 3. Let options be the result of calling the [[Call]] internal method of create with // undefined as the this value and an argument list containing the single item // options. options = create(options); // 4. Let needDefaults be true. var needDefaults = true; // 5. If required is "date" or "any", then if (required === 'date' || required === 'any') { // a. For each of the property names "weekday", "year", "month", "day": // i. If the result of calling the [[Get]] internal method of options with the // property name is not undefined, then let needDefaults be false. if (options.weekday !== undefined || options.year !== undefined || options.month !== undefined || options.day !== undefined) needDefaults = false; } // 6. If required is "time" or "any", then if (required === 'time' || required === 'any') { // a. For each of the property names "hour", "minute", "second": // i. If the result of calling the [[Get]] internal method of options with the // property name is not undefined, then let needDefaults be false. if (options.hour !== undefined || options.minute !== undefined || options.second !== undefined) needDefaults = false; } // 7. If needDefaults is true and defaults is either "date" or "all", then if (needDefaults && (defaults === 'date' || defaults === 'all')) // a. For each of the property names "year", "month", "day": // i. Call the [[DefineOwnProperty]] internal method of options with the // property name, Property Descriptor {[[Value]]: "numeric", [[Writable]]: // true, [[Enumerable]]: true, [[Configurable]]: true}, and false. options.year = options.month = options.day = 'numeric'; // 8. If needDefaults is true and defaults is either "time" or "all", then if (needDefaults && (defaults === 'time' || defaults === 'all')) // a. For each of the property names "hour", "minute", "second": // i. Call the [[DefineOwnProperty]] internal method of options with the // property name, Property Descriptor {[[Value]]: "numeric", [[Writable]]: // true, [[Enumerable]]: true, [[Configurable]]: true}, and false. options.hour = options.minute = options.second = 'numeric'; // 9. Return options. return options; } /** * When the BasicFormatMatcher abstract operation is called with two arguments options and * formats, the following steps are taken: */ function BasicFormatMatcher(options, formats) { // 1. Let removalPenalty be 120. var removalPenalty = 120; // 2. Let additionPenalty be 20. var additionPenalty = 20; // 3. Let longLessPenalty be 8. var longLessPenalty = 8; // 4. Let longMorePenalty be 6. var longMorePenalty = 6; // 5. Let shortLessPenalty be 6. var shortLessPenalty = 6; // 6. Let shortMorePenalty be 3. var shortMorePenalty = 3; // 7. Let bestScore be -Infinity. var bestScore = -Infinity; // 8. Let bestFormat be undefined. var bestFormat = void 0; // 9. Let i be 0. var i = 0; // 10. Assert: formats is an Array object. // 11. Let len be the result of calling the [[Get]] internal method of formats with argument "length". var len = formats.length; // 12. Repeat while i < len: while (i < len) { // a. Let format be the result of calling the [[Get]] internal method of formats with argument ToString(i). var format = formats[i]; // b. Let score be 0. var score = 0; // c. For each property shown in Table 3: for (var property in dateTimeComponents) { if (!hop.call(dateTimeComponents, property)) continue; // i. Let optionsProp be options.[[<property>]]. var optionsProp = options['[[' + property + ']]']; // ii. Let formatPropDesc be the result of calling the [[GetOwnProperty]] internal method of format // with argument property. // iii. If formatPropDesc is not undefined, then // 1. Let formatProp be the result of calling the [[Get]] internal method of format with argument property. var formatProp = hop.call(format, property) ? format[property] : undefined; // iv. If optionsProp is undefined and formatProp is not undefined, then decrease score by // additionPenalty. if (optionsProp === undefined && formatProp !== undefined) score -= additionPenalty; // v. Else if optionsProp is not undefined and formatProp is undefined, then decrease score by // removalPenalty. else if (optionsProp !== undefined && formatProp === undefined) score -= removalPenalty; // vi. Else else { // 1. Let values be the array ["2-digit", "numeric", "narrow", "short", // "long"]. var values = ['2-digit', 'numeric', 'narrow', 'short', 'long']; // 2. Let optionsPropIndex be the index of optionsProp within values. var optionsPropIndex = arrIndexOf.call(values, optionsProp); // 3. Let formatPropIndex be the index of formatProp within values. var formatPropIndex = arrIndexOf.call(values, formatProp); // 4. Let delta be max(min(formatPropIndex - optionsPropIndex, 2), -2). var delta = Math.max(Math.min(formatPropIndex - optionsPropIndex, 2), -2); // 5. If delta = 2, decrease score by longMorePenalty. if (delta === 2) score -= longMorePenalty; // 6. Else if delta = 1, decrease score by shortMorePenalty. else if (delta === 1) score -= shortMorePenalty; // 7. Else if delta = -1, decrease score by shortLessPenalty. else if (delta === -1) score -= shortLessPenalty; // 8. Else if delta = -2, decrease score by longLessPenalty. else if (delta === -2) score -= longLessPenalty; } } // d. If score > bestScore, then if (score > bestScore) { // i. Let bestScore be score. bestScore = score; // ii. Let bestFormat be format. bestFormat = format; } // e. Increase i by 1. i++; } // 13. Return bestFormat. return bestFormat; } /** * When the BestFitFormatMatcher abstract operation is called with two arguments options * and formats, it performs implementation dependent steps, which should return a set of * component representations that a typical user of the selected locale would perceive as * at least as good as the one returned by BasicFormatMatcher. * * This polyfill defines the algorithm to be the same as BasicFormatMatcher, * with the addition of bonus points awarded where the requested format is of * the same data type as the potentially matching format. * * This algo relies on the concept of closest distance matching described here: * http://unicode.org/reports/tr35/tr35-dates.html#Matching_Skeletons * Typically a “best match” is found using a closest distance match, such as: * * Symbols requesting a best choice for the locale are replaced. * j → one of {H, k, h, K}; C → one of {a, b, B} * -> Covered by cldr.js matching process * * For fields with symbols representing the same type (year, month, day, etc): * Most symbols have a small distance from each other. * M ≅ L; E ≅ c; a ≅ b ≅ B; H ≅ k ≅ h ≅ K; ... * -> Covered by cldr.js matching process * * Width differences among fields, other than those marking text vs numeric, are given small distance from each other. * MMM ≅ MMMM * MM ≅ M * Numeric and text fields are given a larger distance from each other. * MMM ≈ MM * Symbols representing substantial differences (week of year vs week of month) are given much larger a distances from each other. * d ≋ D; ... * Missing or extra fields cause a match to fail. (But see Missing Skeleton Fields). * * * For example, * * { month: 'numeric', day: 'numeric' } * * should match * * { month: '2-digit', day: '2-digit' } * * rather than * * { month: 'short', day: 'numeric' } * * This makes sense because a user requesting a formatted date with numeric parts would * not expect to see the returned format containing narrow, short or long part names */ function BestFitFormatMatcher(options, formats) { /** Diverging: this block implements the hack for single property configuration, eg.: * * `new Intl.DateTimeFormat('en', {day: 'numeric'})` * * should produce a single digit with the day of the month. This is needed because * CLDR `availableFormats` data structure doesn't cover these cases. */ { var optionsPropNames = []; for (var property in dateTimeComponents) { if (!hop.call(dateTimeComponents, property)) continue; if (options['[[' + property + ']]'] !== undefined) { optionsPropNames.push(property); } } if (optionsPropNames.length === 1) { var _bestFormat = generateSyntheticFormat(optionsPropNames[0], options['[[' + optionsPropNames[0] + ']]']); if (_bestFormat) { return _bestFormat; } } } // 1. Let removalPenalty be 120. var removalPenalty = 120; // 2. Let additionPenalty be 20. var additionPenalty = 20; // 3. Let longLessPenalty be 8. var longLessPenalty = 8; // 4. Let longMorePenalty be 6. var longMorePenalty = 6; // 5. Let shortLessPenalty be 6. var shortLessPenalty = 6; // 6. Let shortMorePenalty be 3. var shortMorePenalty = 3; var patternPenalty = 2; var hour12Penalty = 1; // 7. Let bestScore be -Infinity. var bestScore = -Infinity; // 8. Let bestFormat be undefined. var bestFormat = void 0; // 9. Let i be 0. var i = 0; // 10. Assert: formats is an Array object. // 11. Let len be the result of calling the [[Get]] internal method of formats with argument "length". var len = formats.length; // 12. Repeat while i < len: while (i < len) { // a. Let format be the result of calling the [[Get]] internal method of formats with argument ToString(i). var format = formats[i]; // b. Let score be 0. var score = 0; // c. For each property shown in Table 3: for (var _property in dateTimeComponents) { if (!hop.call(dateTimeComponents, _property)) continue; // i. Let optionsProp be options.[[<property>]]. var optionsProp = options['[[' + _property + ']]']; // ii. Let formatPropDesc be the result of calling the [[GetOwnProperty]] internal method of format // with argument property. // iii. If formatPropDesc is not undefined, then // 1. Let formatProp be the result of calling the [[Get]] internal method of format with argument property. var formatProp = hop.call(format, _property) ? format[_property] : undefined; // Diverging: using the default properties produced by the pattern/skeleton // to match it with user options, and apply a penalty var patternProp = hop.call(format._, _property) ? format._[_property] : undefined; if (optionsProp !== patternProp) { score -= patternPenalty; } // iv. If optionsProp is undefined and formatProp is not undefined, then decrease score by // additionPenalty. if (optionsProp === undefined && formatProp !== undefined) score -= additionPenalty; // v. Else if optionsProp is not undefined and formatProp is undefined, then decrease score by // removalPenalty. else if (optionsProp !== undefined && formatProp === undefined) score -= removalPenalty; // vi. Else else { // 1. Let values be the array ["2-digit", "numeric", "narrow", "short", // "long"]. var values = ['2-digit', 'numeric', 'narrow', 'short', 'long']; // 2. Let optionsPropIndex be the index of optionsProp within values. var optionsPropIndex = arrIndexOf.call(values, optionsProp); // 3. Let formatPropIndex be the index of formatProp within values. var formatPropIndex = arrIndexOf.call(values, formatProp); // 4. Let delta be max(min(formatPropIndex - optionsPropIndex, 2), -2). var delta = Math.max(Math.min(formatPropIndex - optionsPropIndex, 2), -2); { // diverging from spec // When the bestFit argument is true, subtract additional penalty where data types are not the same if (formatPropIndex <= 1 && optionsPropIndex >= 2 || formatPropIndex >= 2 && optionsPropIndex <= 1) { // 5. If delta = 2, decrease score by longMorePenalty. if (delta > 0) score -= longMorePenalty;else if (delta < 0) score -= longLessPenalty; } else { // 5. If delta = 2, decrease score by longMorePenalty. if (delta > 1) score -= shortMorePenalty;else if (delta < -1) score -= shortLessPenalty; } } } } { // diverging to also take into consideration differences between 12 or 24 hours // which is special for the best fit only. if (format._.hour12 !== options.hour12) { score -= hour12Penalty; } } // d. If score > bestScore, then if (score > bestScore) { // i. Let bestScore be score. bestScore = score; // ii. Let bestFormat be format. bestFormat = format; } // e. Increase i by 1. i++; } // 13. Return bestFormat. return bestFormat; } /* 12.2.3 */internals.DateTimeFormat = { '[[availableLocales]]': [], '[[relevantExtensionKeys]]': ['ca', 'nu'], '[[localeData]]': {} }; /** * When the supportedLocalesOf method of Intl.DateTimeFormat is called, the * following steps are taken: */ /* 12.2.2 */ defineProperty(Intl.DateTimeFormat, 'supportedLocalesOf', { configurable: true, writable: true, value: fnBind.call(function (locales) { // Bound functions only have the `this` value altered if being used as a constructor, // this lets us imitate a native function that has no constructor if (!hop.call(this, '[[availableLocales]]')) throw new TypeError('supportedLocalesOf() is not a constructor'); // Create an object whose props can be used to restore the values of RegExp props var regexpRestore = createRegExpRestore(), // 1. If options is not provided, then let options be undefined. options = arguments[1], // 2. Let availableLocales be the value of the [[availableLocales]] internal // property of the standard built-in object that is the initial value of // Intl.NumberFormat. availableLocales = this['[[availableLocales]]'], // 3. Let requestedLocales be the result of calling the CanonicalizeLocaleList // abstract operation (defined in 9.2.1) with argument locales. requestedLocales = CanonicalizeLocaleList(locales); // Restore the RegExp properties regexpRestore(); // 4. Return the result of calling the SupportedLocales abstract operation // (defined in 9.2.8) with arguments availableLocales, requestedLocales, // and options. return SupportedLocales(availableLocales, requestedLocales, options); }, internals.NumberFormat) }); /** * This named accessor property returns a function that formats a number * according to the effective locale and the formatting options of this * DateTimeFormat object. */ /* 12.3.2 */defineProperty(Intl.DateTimeFormat.prototype, 'format', { configurable: true, get: GetFormatDateTime }); function GetFormatDateTime() { var internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); // Satisfy test 12.3_b if (!internal || !internal['[[initializedDateTimeFormat]]']) throw new TypeError('`this` value for format() is not an initialized Intl.DateTimeFormat object.'); // The value of the [[Get]] attribute is a function that takes the following // steps: // 1. If the [[boundFormat]] internal property of this DateTimeFormat object // is undefined, then: if (internal['[[boundFormat]]'] === undefined) { // a. Let F be a Function object, with internal properties set as // specified for built-in functions in ES5, 15, or successor, and the // length property set to 0, that takes the argument date and // performs the following steps: var F = function F() { var date = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0]; // i. If date is not provided or is undefined, then let x be the // result as if by the expression Date.now() where Date.now is // the standard built-in function defined in ES5, 15.9.4.4. // ii. Else let x be ToNumber(date). // iii. Return the result of calling the FormatDateTime abstract // operation (defined below) with arguments this and x. var x = date === undefined ? Date.now() : toNumber(date); return FormatDateTime(this, x); }; // b. Let bind be the standard built-in function object defined in ES5, // 15.3.4.5. // c. Let bf be the result of calling the [[Call]] internal method of // bind with F as the this value and an argument list containing // the single item this. var bf = fnBind.call(F, this); // d. Set the [[boundFormat]] internal property of this NumberFormat // object to bf. internal['[[boundFormat]]'] = bf; } // Return the value of the [[boundFormat]] internal property of this // NumberFormat object. return internal['[[boundFormat]]']; } function formatToParts$1() { var date = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0]; var internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); if (!internal || !internal['[[initializedDateTimeFormat]]']) throw new TypeError('`this` value for formatToParts() is not an initialized Intl.DateTimeFormat object.'); var x = date === undefined ? Date.now() : toNumber(date); return FormatToPartsDateTime(this, x); } Object.defineProperty(Intl.DateTimeFormat.prototype, 'formatToParts', { enumerable: false, writable: true, configurable: true, value: formatToParts$1 }); function CreateDateTimeParts(dateTimeFormat, x) { // 1. If x is not a finite Number, then throw a RangeError exception. if (!isFinite(x)) throw new RangeError('Invalid valid date passed to format'); var internal = dateTimeFormat.__getInternalProperties(secret); // Creating restore point for properties on the RegExp object... please wait /* let regexpRestore = */createRegExpRestore(); // ###TODO: review this // 2. Let locale be the value of the [[locale]] internal property of dateTimeFormat. var locale = internal['[[locale]]']; // 3. Let nf be the result of creating a new NumberFormat object as if by the // expression new Intl.NumberFormat([locale], {useGrouping: false}) where // Intl.NumberFormat is the standard built-in constructor defined in 11.1.3. var nf = new Intl.NumberFormat([locale], { useGrouping: false }); // 4. Let nf2 be the result of creating a new NumberFormat object as if by the // expression new Intl.NumberFormat([locale], {minimumIntegerDigits: 2, useGrouping: // false}) where Intl.NumberFormat is the standard built-in constructor defined in // 11.1.3. var nf2 = new Intl.NumberFormat([locale], { minimumIntegerDigits: 2, useGrouping: false }); // 5. Let tm be the result of calling the ToLocalTime abstract operation (defined // below) with x, the value of the [[calendar]] internal property of dateTimeFormat, // and the value of the [[timeZone]] internal property of dateTimeFormat. var tm = ToLocalTime(x, internal['[[calendar]]'], internal['[[timeZone]]']); // 6. Let result be the value of the [[pattern]] internal property of dateTimeFormat. var pattern = internal['[[pattern]]']; // 7. var result = new List(); // 8. var index = 0; // 9. var beginIndex = pattern.indexOf('{'); // 10. var endIndex = 0; // Need the locale minus any extensions var dataLocale = internal['[[dataLocale]]']; // Need the calendar data from CLDR var localeData = internals.DateTimeFormat['[[localeData]]'][dataLocale].calendars; var ca = internal['[[calendar]]']; // 11. while (beginIndex !== -1) { var fv = void 0; // a. endIndex = pattern.indexOf('}', beginIndex); // b. if (endIndex === -1) { throw new Error('Unclosed pattern'); } // c. if (beginIndex > index) { arrPush.call(result, { type: 'literal', value: pattern.substring(index, beginIndex) }); } // d. var p = pattern.substring(beginIndex + 1, endIndex); // e. if (dateTimeComponents.hasOwnProperty(p)) { // i. Let f be the value of the [[<p>]] internal property of dateTimeFormat. var f = internal['[[' + p + ']]']; // ii. Let v be the value of tm.[[<p>]]. var v = tm['[[' + p + ']]']; // iii. If p is "year" and v ≤ 0, then let v be 1 - v. if (p === 'year' && v <= 0) { v = 1 - v; } // iv. If p is "month", then increase v by 1. else if (p === 'month') { v++; } // v. If p is "hour" and the value of the [[hour12]] internal property of // dateTimeFormat is true, then else if (p === 'hour' && internal['[[hour12]]'] === true) { // 1. Let v be v modulo 12. v = v % 12; // 2. If v is 0 and the value of the [[hourNo0]] internal property of // dateTimeFormat is true, then let v be 12. if (v === 0 && internal['[[hourNo0]]'] === true) { v = 12; } } // vi. If f is "numeric", then if (f === 'numeric') { // 1. Let fv be the result of calling the FormatNumber abstract operation // (defined in 11.3.2) with arguments nf and v. fv = FormatNumber(nf, v); } // vii. Else if f is "2-digit", then else if (f === '2-digit') { // 1. Let fv be the result of calling the FormatNumber abstract operation // with arguments nf2 and v. fv = FormatNumber(nf2, v); // 2. If the length of fv is greater than 2, let fv be the substring of fv // containing the last two characters. if (fv.length > 2) { fv = fv.slice(-2); } } // viii. Else if f is "narrow", "short", or "long", then let fv be a String // value representing f in the desired form; the String value depends upon // the implementation and the effective locale and calendar of // dateTimeFormat. If p is "month", then the String value may also depend // on whether dateTimeFormat has a [[day]] internal property. If p is // "timeZoneName", then the String value may also depend on the value of // the [[inDST]] field of tm. else if (f in dateWidths) { switch (p) { case 'month': fv = resolveDateString(localeData, ca, 'months', f, tm['[[' + p + ']]']); break; case 'weekday': try { fv = resolveDateString(localeData, ca, 'days', f, tm['[[' + p + ']]']); // fv = resolveDateString(ca.days, f)[tm['[['+ p +']]']]; } catch (e) { throw new Error('Could not find weekday data for locale ' + locale); } break; case 'timeZoneName': fv = ''; // ###TODO break; case 'era': try { fv = resolveDateString(localeData, ca, 'eras', f, tm['[[' + p + ']]']); } catch (e) { throw new Error('Could not find era data for locale ' + locale); } break; default: fv = tm['[[' + p + ']]']; } } // ix arrPush.call(result, { type: p, value: fv }); // f. } else if (p === 'ampm') { // i. var _v = tm['[[hour]]']; // ii./iii. fv = resolveDateString(localeData, ca, 'dayPeriods', _v > 11 ? 'pm' : 'am', null); // iv. arrPush.call(result, { type: 'dayPeriod', value: fv }); // g. } else { arrPush.call(result, { type: 'literal', value: pattern.substring(beginIndex, endIndex + 1) }); } // h. index = endIndex + 1; // i. beginIndex = pattern.indexOf('{', index); } // 12. if (endIndex < pattern.length - 1) { arrPush.call(result, { type: 'literal', value: pattern.substr(endIndex + 1) }); } // 13. return result; } /** * When the FormatDateTime abstract operation is called with arguments dateTimeFormat * (which must be an object initialized as a DateTimeFormat) and x (which must be a Number * value), it returns a String value representing x (interpreted as a time value as * specified in ES5, 15.9.1.1) according to the effective locale and the formatting * options of dateTimeFormat. */ function FormatDateTime(dateTimeFormat, x) { var parts = CreateDateTimeParts(dateTimeFormat, x); var result = ''; for (var i = 0; parts.length > i; i++) { var part = parts[i]; result += part.value; } return result; } function FormatToPartsDateTime(dateTimeFormat, x) { var parts = CreateDateTimeParts(dateTimeFormat, x); var result = []; for (var i = 0; parts.length > i; i++) { var part = parts[i]; result.push({ type: part.type, value: part.value }); } return result; } /** * When the ToLocalTime abstract operation is called with arguments date, calendar, and * timeZone, the following steps are taken: */ function ToLocalTime(date, calendar, timeZone) { // 1. Apply calendrical calculations on date for the given calendar and time zone to // produce weekday, era, year, month, day, hour, minute, second, and inDST values. // The calculations should use best available information about the specified // calendar and time zone. If the calendar is "gregory", then the calculations must // match the algorithms specified in ES5, 15.9.1, except that calculations are not // bound by the restrictions on the use of best available information on time zones // for local time zone adjustment and daylight saving time adjustment imposed by // ES5, 15.9.1.7 and 15.9.1.8. // ###TODO### var d = new Date(date), m = 'get' + (timeZone || ''); // 2. Return a Record with fields [[weekday]], [[era]], [[year]], [[month]], [[day]], // [[hour]], [[minute]], [[second]], and [[inDST]], each with the corresponding // calculated value. return new Record({ '[[weekday]]': d[m + 'Day'](), '[[era]]': +(d[m + 'FullYear']() >= 0), '[[year]]': d[m + 'FullYear'](), '[[month]]': d[m + 'Month'](), '[[day]]': d[m + 'Date'](), '[[hour]]': d[m + 'Hours'](), '[[minute]]': d[m + 'Minutes'](), '[[second]]': d[m + 'Seconds'](), '[[inDST]]': false // ###TODO### }); } /** * The function returns a new object whose properties and attributes are set as if * constructed by an object literal assigning to each of the following properties the * value of the corresponding internal property of this DateTimeFormat object (see 12.4): * locale, calendar, numberingSystem, timeZone, hour12, weekday, era, year, month, day, * hour, minute, second, and timeZoneName. Properties whose corresponding internal * properties are not present are not assigned. */ /* 12.3.3 */defineProperty(Intl.DateTimeFormat.prototype, 'resolvedOptions', { writable: true, configurable: true, value: function value() { var prop = void 0, descs = new Record(), props = ['locale', 'calendar', 'numberingSystem', 'timeZone', 'hour12', 'weekday', 'era', 'year', 'month', 'day', 'hour', 'minute', 'second', 'timeZoneName'], internal = this !== null && babelHelpers$1["typeof"](this) === 'object' && getInternalProperties(this); // Satisfy test 12.3_b if (!internal || !internal['[[initializedDateTimeFormat]]']) throw new TypeError('`this` value for resolvedOptions() is not an initialized Intl.DateTimeFormat object.'); for (var i = 0, max = props.length; i < max; i++) { if (hop.call(internal, prop = '[[' + props[i] + ']]')) descs[props[i]] = { value: internal[prop], writable: true, configurable: true, enumerable: true }; } return objCreate({}, descs); } }); var ls = Intl.__localeSensitiveProtos = { Number: {}, Date: {} }; /** * When the toLocaleString method is called with optional arguments locales and options, * the following steps are taken: */ /* 13.2.1 */ls.Number.toLocaleString = function () { // Satisfy test 13.2.1_1 if (Object.prototype.toString.call(this) !== '[object Number]') throw new TypeError('`this` value must be a number for Number.prototype.toLocaleString()'); // 1. Let x be this Number value (as defined in ES5, 15.7.4). // 2. If locales is not provided, then let locales be undefined. // 3. If options is not provided, then let options be undefined. // 4. Let numberFormat be the result of creating a new object as if by the // expression new Intl.NumberFormat(locales, options) where // Intl.NumberFormat is the standard built-in constructor defined in 11.1.3. // 5. Return the result of calling the FormatNumber abstract operation // (defined in 11.3.2) with arguments numberFormat and x. return FormatNumber(new NumberFormatConstructor(arguments[0], arguments[1]), this); }; /** * When the toLocaleString method is called with optional arguments locales and options, * the following steps are taken: */ /* 13.3.1 */ls.Date.toLocaleString = function () { // Satisfy test 13.3.0_1 if (Object.prototype.toString.call(this) !== '[object Date]') throw new TypeError('`this` value must be a Date instance for Date.prototype.toLocaleString()'); // 1. Let x be this time value (as defined in ES5, 15.9.5). var x = +this; // 2. If x is NaN, then return "Invalid Date". if (isNaN(x)) return 'Invalid Date'; // 3. If locales is not provided, then let locales be undefined. var locales = arguments[0]; // 4. If options is not provided, then let options be undefined. var options = arguments[1]; // 5. Let options be the result of calling the ToDateTimeOptions abstract // operation (defined in 12.1.1) with arguments options, "any", and "all". options = ToDateTimeOptions(options, 'any', 'all'); // 6. Let dateTimeFormat be the result of creating a new object as if by the // expression new Intl.DateTimeFormat(locales, options) where // Intl.DateTimeFormat is the standard built-in constructor defined in 12.1.3. var dateTimeFormat = new DateTimeFormatConstructor(locales, options); // 7. Return the result of calling the FormatDateTime abstract operation (defined // in 12.3.2) with arguments dateTimeFormat and x. return FormatDateTime(dateTimeFormat, x); }; /** * When the toLocaleDateString method is called with optional arguments locales and * options, the following steps are taken: */ /* 13.3.2 */ls.Date.toLocaleDateString = function () { // Satisfy test 13.3.0_1 if (Object.prototype.toString.call(this) !== '[object Date]') throw new TypeError('`this` value must be a Date instance for Date.prototype.toLocaleDateString()'); // 1. Let x be this time value (as defined in ES5, 15.9.5). var x = +this; // 2. If x is NaN, then return "Invalid Date". if (isNaN(x)) return 'Invalid Date'; // 3. If locales is not provided, then let locales be undefined. var locales = arguments[0], // 4. If options is not provided, then let options be undefined. options = arguments[1]; // 5. Let options be the result of calling the ToDateTimeOptions abstract // operation (defined in 12.1.1) with arguments options, "date", and "date". options = ToDateTimeOptions(options, 'date', 'date'); // 6. Let dateTimeFormat be the result of creating a new object as if by the // expression new Intl.DateTimeFormat(locales, options) where // Intl.DateTimeFormat is the standard built-in constructor defined in 12.1.3. var dateTimeFormat = new DateTimeFormatConstructor(locales, options); // 7. Return the result of calling the FormatDateTime abstract operation (defined // in 12.3.2) with arguments dateTimeFormat and x. return FormatDateTime(dateTimeFormat, x); }; /** * When the toLocaleTimeString method is called with optional arguments locales and * options, the following steps are taken: */ /* 13.3.3 */ls.Date.toLocaleTimeString = function () { // Satisfy test 13.3.0_1 if (Object.prototype.toString.call(this) !== '[object Date]') throw new TypeError('`this` value must be a Date instance for Date.prototype.toLocaleTimeString()'); // 1. Let x be this time value (as defined in ES5, 15.9.5). var x = +this; // 2. If x is NaN, then return "Invalid Date". if (isNaN(x)) return 'Invalid Date'; // 3. If locales is not provided, then let locales be undefined. var locales = arguments[0]; // 4. If options is not provided, then let options be undefined. var options = arguments[1]; // 5. Let options be the result of calling the ToDateTimeOptions abstract // operation (defined in 12.1.1) with arguments options, "time", and "time". options = ToDateTimeOptions(options, 'time', 'time'); // 6. Let dateTimeFormat be the result of creating a new object as if by the // expression new Intl.DateTimeFormat(locales, options) where // Intl.DateTimeFormat is the standard built-in constructor defined in 12.1.3. var dateTimeFormat = new DateTimeFormatConstructor(locales, options); // 7. Return the result of calling the FormatDateTime abstract operation (defined // in 12.3.2) with arguments dateTimeFormat and x. return FormatDateTime(dateTimeFormat, x); }; defineProperty(Intl, '__applyLocaleSensitivePrototypes', { writable: true, configurable: true, value: function value() { defineProperty(Number.prototype, 'toLocaleString', { writable: true, configurable: true, value: ls.Number.toLocaleString }); // Need this here for IE 8, to avoid the _DontEnum_ bug defineProperty(Date.prototype, 'toLocaleString', { writable: true, configurable: true, value: ls.Date.toLocaleString }); for (var k in ls.Date) { if (hop.call(ls.Date, k)) defineProperty(Date.prototype, k, { writable: true, configurable: true, value: ls.Date[k] }); } } }); /** * Can't really ship a single script with data for hundreds of locales, so we provide * this __addLocaleData method as a means for the developer to add the data on an * as-needed basis */ defineProperty(Intl, '__addLocaleData', { value: function value(data) { if (!IsStructurallyValidLanguageTag(data.locale)) throw new Error("Object passed doesn't identify itself with a valid language tag"); addLocaleData(data, data.locale); } }); function addLocaleData(data, tag) { // Both NumberFormat and DateTimeFormat require number data, so throw if it isn't present if (!data.number) throw new Error("Object passed doesn't contain locale data for Intl.NumberFormat"); var locale = void 0, locales = [tag], parts = tag.split('-'); // Create fallbacks for locale data with scripts, e.g. Latn, Hans, Vaii, etc if (parts.length > 2 && parts[1].length === 4) arrPush.call(locales, parts[0] + '-' + parts[2]); while (locale = arrShift.call(locales)) { // Add to NumberFormat internal properties as per 11.2.3 arrPush.call(internals.NumberFormat['[[availableLocales]]'], locale); internals.NumberFormat['[[localeData]]'][locale] = data.number; // ...and DateTimeFormat internal properties as per 12.2.3 if (data.date) { data.date.nu = data.number.nu; arrPush.call(internals.DateTimeFormat['[[availableLocales]]'], locale); internals.DateTimeFormat['[[localeData]]'][locale] = data.date; } } // If this is the first set of locale data added, make it the default if (defaultLocale === undefined) setDefaultLocale(tag); } defineProperty(Intl, '__disableRegExpRestore', { value: function value() { internals.disableRegExpRestore = true; } }); module.exports = Intl; /***/ }), /***/ 2317: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2634); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9936: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6773); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3283: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8020); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 439: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3220); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9872: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5224); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3623: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9278); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1239: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9362); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2435: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(141); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3144: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5288); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6801: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2896); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1100: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8949); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 254: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4014); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 785: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7586); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9708: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8363); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9216: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7767); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6171: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5663); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9022: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(458); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2285: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8453); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9144: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(790); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3478: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2043); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9693: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1294); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8826: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2974); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2407: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2652); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7994: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8832); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5197: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3637); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9803: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1535); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8858: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(875); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8094: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9008); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8563: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7256); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8000: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3892); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7388: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1097); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4630: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3486); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5166: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4001); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8618: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6083); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8133: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9366); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6950: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4517); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 560: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7008); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9273: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(522); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2265: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7078); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5984: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6049); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4854: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4284); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8364: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1527); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6683: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1139); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1158: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6208); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9864: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1501); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3386: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9446); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3234: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1741); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5252: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4813); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7288: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4745); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5277: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9121); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 279: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4521); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9365: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9677); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1415: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2893); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8965: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4110); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1427: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2774); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7027: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6952); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8859: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2467); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3964: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8061); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1138: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7292); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6734: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3979); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1561: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7871); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2553: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2189); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4672: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2336); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5021: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(657); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3262: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(228); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3526); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4899: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7188); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3475: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5490); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4286: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6329); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3163: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6114); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1813: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4484); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9907: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1433); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8789: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3742); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6881: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1148); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3010: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8759); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5810: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7675); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5699: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1099); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4112: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8900); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7832: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2743); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8848: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2356); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8895: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4610); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8526: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5622); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 924: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8815); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3316: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7508); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8677: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9963); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4981: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4050); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4715: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2819); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9862: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2015); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5674: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4734); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7786: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3346); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 330: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9450); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2578: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3813); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1646: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5517); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7585: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9955); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8896: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2946); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6949: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8192); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1854: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1690); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6618: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5770); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1696: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(846); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7694: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7145); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5121: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7607); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6250: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9219); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7001: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5741); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 32: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7464); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4946: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2645); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9953: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9235); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7665: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1542); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6813: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1914); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3007: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6362); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4558: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5906); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5351: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7765); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7702: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4200); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4322: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3848); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4132: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1636); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8252: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2631); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 978: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6725); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5436: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6038); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2908: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7526); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3759: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8601); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2764: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3970); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2568: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6690); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9392: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(466); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9099: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(449); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4697: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9838); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7931: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1874); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5822: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1531); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5322: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3573); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5347: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7380); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1323: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5623); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5071: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1880); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5220: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5418); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 502: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7242); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 255: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(389); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7009: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6332); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7961: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2889); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6483: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(5995); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5386: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3396); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7817: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7829); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4607: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2872); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9786: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9163); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9360: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7366); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 286: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8362); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5768: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7025); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9957: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(671); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8184: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8392); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4601: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8239); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2687: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8658); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8901: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(154); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1595: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4964); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 5233: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1708); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4516: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6344); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2312: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4561); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8856: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1132); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 1799: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9799); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 2859: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4596); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 3468: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(6660); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 4695: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9364); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9033: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(8642); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6053: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(7970); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7139: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9930); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6227: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1767); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 9563: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(1552); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 301: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(3001); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7399: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(9396); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 622: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(2990); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 7381: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4614); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 8734: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { var content = __webpack_require__(4832); if(typeof content === 'string') content = [[module.id, content, '']]; var transform; var insertInto; var options = {"hmr":true} options.transform = transform options.insertInto = undefined; var update = __webpack_require__(6723)(content, options); if(content.locals) module.exports = content.locals; if(false) {} /***/ }), /***/ 6723: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { /* MIT License http://www.opensource.org/licenses/mit-license.php Author Tobias Koppers @sokra */ var stylesInDom = {}; var memoize = function (fn) { var memo; return function () { if (typeof memo === "undefined") memo = fn.apply(this, arguments); return memo; }; }; var isOldIE = memoize(function () { // Test for IE <= 9 as proposed by Browserhacks // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805 // Tests for existence of standard globals is to allow style-loader // to operate correctly into non-standard environments // @see https://github.com/webpack-contrib/style-loader/issues/177 return window && document && document.all && !window.atob; }); var getTarget = function (target, parent) { if (parent){ return parent.querySelector(target); } return document.querySelector(target); }; var getElement = (function (fn) { var memo = {}; return function(target, parent) { // If passing function in options, then use it for resolve "head" element. // Useful for Shadow Root style i.e // { // insertInto: function () { return document.querySelector("#foo").shadowRoot } // } if (typeof target === 'function') { return target(); } if (typeof memo[target] === "undefined") { var styleTarget = getTarget.call(this, target, parent); // Special case to return head of iframe instead of iframe itself if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) { try { // This will throw an exception if access to iframe is blocked // due to cross-origin restrictions styleTarget = styleTarget.contentDocument.head; } catch(e) { styleTarget = null; } } memo[target] = styleTarget; } return memo[target] }; })(); var singleton = null; var singletonCounter = 0; var stylesInsertedAtTop = []; var fixUrls = __webpack_require__(1947); module.exports = function(list, options) { if (typeof DEBUG !== "undefined" && DEBUG) { if (typeof document !== "object") throw new Error("The style-loader cannot be used in a non-browser environment"); } options = options || {}; options.attrs = typeof options.attrs === "object" ? options.attrs : {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style> // tags it will allow on a page if (!options.singleton && typeof options.singleton !== "boolean") options.singleton = isOldIE(); // By default, add <style> tags to the <head> element if (!options.insertInto) options.insertInto = "head"; // By default, add <style> tags to the bottom of the target if (!options.insertAt) options.insertAt = "bottom"; var styles = listToStyles(list, options); addStylesToDom(styles, options); return function update (newList) { var mayRemove = []; for (var i = 0; i < styles.length; i++) { var item = styles[i]; var domStyle = stylesInDom[item.id]; domStyle.refs--; mayRemove.push(domStyle); } if(newList) { var newStyles = listToStyles(newList, options); addStylesToDom(newStyles, options); } for (var i = 0; i < mayRemove.length; i++) { var domStyle = mayRemove[i]; if(domStyle.refs === 0) { for (var j = 0; j < domStyle.parts.length; j++) domStyle.parts[j](); delete stylesInDom[domStyle.id]; } } }; }; function addStylesToDom (styles, options) { for (var i = 0; i < styles.length; i++) { var item = styles[i]; var domStyle = stylesInDom[item.id]; if(domStyle) { domStyle.refs++; for(var j = 0; j < domStyle.parts.length; j++) { domStyle.parts[j](item.parts[j]); } for(; j < item.parts.length; j++) { domStyle.parts.push(addStyle(item.parts[j], options)); } } else { var parts = []; for(var j = 0; j < item.parts.length; j++) { parts.push(addStyle(item.parts[j], options)); } stylesInDom[item.id] = {id: item.id, refs: 1, parts: parts}; } } } function listToStyles (list, options) { var styles = []; var newStyles = {}; for (var i = 0; i < list.length; i++) { var item = list[i]; var id = options.base ? item[0] + options.base : item[0]; var css = item[1]; var media = item[2]; var sourceMap = item[3]; var part = {css: css, media: media, sourceMap: sourceMap}; if(!newStyles[id]) styles.push(newStyles[id] = {id: id, parts: [part]}); else newStyles[id].parts.push(part); } return styles; } function insertStyleElement (options, style) { var target = getElement(options.insertInto) if (!target) { throw new Error("Couldn't find a style target. This probably means that the value for the 'insertInto' parameter is invalid."); } var lastStyleElementInsertedAtTop = stylesInsertedAtTop[stylesInsertedAtTop.length - 1]; if (options.insertAt === "top") { if (!lastStyleElementInsertedAtTop) { target.insertBefore(style, target.firstChild); } else if (lastStyleElementInsertedAtTop.nextSibling) { target.insertBefore(style, lastStyleElementInsertedAtTop.nextSibling); } else { target.appendChild(style); } stylesInsertedAtTop.push(style); } else if (options.insertAt === "bottom") { target.appendChild(style); } else if (typeof options.insertAt === "object" && options.insertAt.before) { var nextSibling = getElement(options.insertAt.before, target); target.insertBefore(style, nextSibling); } else { throw new Error("[Style Loader]\n\n Invalid value for parameter 'insertAt' ('options.insertAt') found.\n Must be 'top', 'bottom', or Object.\n (https://github.com/webpack-contrib/style-loader#insertat)\n"); } } function removeStyleElement (style) { if (style.parentNode === null) return false; style.parentNode.removeChild(style); var idx = stylesInsertedAtTop.indexOf(style); if(idx >= 0) { stylesInsertedAtTop.splice(idx, 1); } } function createStyleElement (options) { var style = document.createElement("style"); if(options.attrs.type === undefined) { options.attrs.type = "text/css"; } if(options.attrs.nonce === undefined) { var nonce = getNonce(); if (nonce) { options.attrs.nonce = nonce; } } addAttrs(style, options.attrs); insertStyleElement(options, style); return style; } function createLinkElement (options) { var link = document.createElement("link"); if(options.attrs.type === undefined) { options.attrs.type = "text/css"; } options.attrs.rel = "stylesheet"; addAttrs(link, options.attrs); insertStyleElement(options, link); return link; } function addAttrs (el, attrs) { Object.keys(attrs).forEach(function (key) { el.setAttribute(key, attrs[key]); }); } function getNonce() { if (false) {} return __webpack_require__.nc; } function addStyle (obj, options) { var style, update, remove, result; // If a transform function was defined, run it on the css if (options.transform && obj.css) { result = typeof options.transform === 'function' ? options.transform(obj.css) : options.transform.default(obj.css); if (result) { // If transform returns a value, use that instead of the original css. // This allows running runtime transformations on the css. obj.css = result; } else { // If the transform function returns a falsy value, don't add this css. // This allows conditional loading of css return function() { // noop }; } } if (options.singleton) { var styleIndex = singletonCounter++; style = singleton || (singleton = createStyleElement(options)); update = applyToSingletonTag.bind(null, style, styleIndex, false); remove = applyToSingletonTag.bind(null, style, styleIndex, true); } else if ( obj.sourceMap && typeof URL === "function" && typeof URL.createObjectURL === "function" && typeof URL.revokeObjectURL === "function" && typeof Blob === "function" && typeof btoa === "function" ) { style = createLinkElement(options); update = updateLink.bind(null, style, options); remove = function () { removeStyleElement(style); if(style.href) URL.revokeObjectURL(style.href); }; } else { style = createStyleElement(options); update = applyToTag.bind(null, style); remove = function () { removeStyleElement(style); }; } update(obj); return function updateStyle (newObj) { if (newObj) { if ( newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap ) { return; } update(obj = newObj); } else { remove(); } }; } var replaceText = (function () { var textStore = []; return function (index, replacement) { textStore[index] = replacement; return textStore.filter(Boolean).join('\n'); }; })(); function applyToSingletonTag (style, index, remove, obj) { var css = remove ? "" : obj.css; if (style.styleSheet) { style.styleSheet.cssText = replaceText(index, css); } else { var cssNode = document.createTextNode(css); var childNodes = style.childNodes; if (childNodes[index]) style.removeChild(childNodes[index]); if (childNodes.length) { style.insertBefore(cssNode, childNodes[index]); } else { style.appendChild(cssNode); } } } function applyToTag (style, obj) { var css = obj.css; var media = obj.media; if(media) { style.setAttribute("media", media) } if(style.styleSheet) { style.styleSheet.cssText = css; } else { while(style.firstChild) { style.removeChild(style.firstChild); } style.appendChild(document.createTextNode(css)); } } function updateLink (link, options, obj) { var css = obj.css; var sourceMap = obj.sourceMap; /* If convertToAbsoluteUrls isn't defined, but sourcemaps are enabled and there is no publicPath defined then lets turn convertToAbsoluteUrls on by default. Otherwise default to the convertToAbsoluteUrls option directly */ var autoFixUrls = options.convertToAbsoluteUrls === undefined && sourceMap; if (options.convertToAbsoluteUrls || autoFixUrls) { css = fixUrls(css); } if (sourceMap) { // http://stackoverflow.com/a/26603875 css += "\n/*# sourceMappingURL=data:application/json;base64," + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + " */"; } var blob = new Blob([css], { type: "text/css" }); var oldSrc = link.href; link.href = URL.createObjectURL(blob); if(oldSrc) URL.revokeObjectURL(oldSrc); } /***/ }), /***/ 1947: /***/ ((module) => { /** * When source maps are enabled, `style-loader` uses a link element with a data-uri to * embed the css on the page. This breaks all relative urls because now they are relative to a * bundle instead of the current page. * * One solution is to only use full urls, but that may be impossible. * * Instead, this function "fixes" the relative urls to be absolute according to the current page location. * * A rudimentary test suite is located at `test/fixUrls.js` and can be run via the `npm test` command. * */ module.exports = function (css) { // get current location var location = typeof window !== "undefined" && window.location; if (!location) { throw new Error("fixUrls requires window.location"); } // blank or null? if (!css || typeof css !== "string") { return css; } var baseUrl = location.protocol + "//" + location.host; var currentDir = baseUrl + location.pathname.replace(/\/[^\/]*$/, "/"); // convert each url(...) /* This regular expression is just a way to recursively match brackets within a string. /url\s*\( = Match on the word "url" with any whitespace after it and then a parens ( = Start a capturing group (?: = Start a non-capturing group [^)(] = Match anything that isn't a parentheses | = OR \( = Match a start parentheses (?: = Start another non-capturing groups [^)(]+ = Match anything that isn't a parentheses | = OR \( = Match a start parentheses [^)(]* = Match anything that isn't a parentheses \) = Match a end parentheses ) = End Group *\) = Match anything and then a close parens ) = Close non-capturing group * = Match anything ) = Close capturing group \) = Match a close parens /gi = Get all matches, not the first. Be case insensitive. */ var fixedCss = css.replace(/url\s*\(((?:[^)(]|\((?:[^)(]+|\([^)(]*\))*\))*)\)/gi, function(fullMatch, origUrl) { // strip quotes (if they exist) var unquotedOrigUrl = origUrl .trim() .replace(/^"(.*)"$/, function(o, $1){ return $1; }) .replace(/^'(.*)'$/, function(o, $1){ return $1; }); // already a full url? no change if (/^(#|data:|http:\/\/|https:\/\/|file:\/\/\/|\s*$)/i.test(unquotedOrigUrl)) { return fullMatch; } // convert the url to a full url var newUrl; if (unquotedOrigUrl.indexOf("//") === 0) { //TODO: should we add protocol? newUrl = unquotedOrigUrl; } else if (unquotedOrigUrl.indexOf("/") === 0) { // path should be relative to the base url newUrl = baseUrl + unquotedOrigUrl; // already starts with '/' } else { // path should be relative to current directory newUrl = currentDir + unquotedOrigUrl.replace(/^\.\//, ""); // Strip leading './' } // send back the fixed url(...) return "url(" + JSON.stringify(newUrl) + ")"; }); // send back the fixed css return fixedCss; }; /***/ }), /***/ 2482: /***/ (() => { /* (ignored) */ /***/ }), /***/ 2398: /***/ ((module) => { "use strict"; module.exports = JSON.parse('["3g2","3ga","3gp","7z","aa","aac","ac","accdb","accdt","ace","adn","ai","aif","aifc","aiff","ait","amr","ani","apk","app","applescript","asax","asc","ascx","asf","ash","ashx","asm","asmx","asp","aspx","asx","au","aup","avi","axd","aze","bak","bash","bat","bin","blank","bmp","bowerrc","bpg","browser","bz2","bzempty","c","cab","cad","caf","cal","cd","cdda","cer","cfg","cfm","cfml","cgi","chm","class","cmd","code-workspace","codekit","coffee","coffeelintignore","com","compile","conf","config","cpp","cptx","cr2","crdownload","crt","crypt","cs","csh","cson","csproj","css","csv","cue","cur","dart","dat","data","db","dbf","deb","default","dgn","dist","diz","dll","dmg","dng","doc","docb","docm","docx","dot","dotm","dotx","download","dpj","ds_store","dsn","dtd","dwg","dxf","editorconfig","el","elf","eml","enc","eot","eps","epub","eslintignore","exe","f4v","fax","fb2","fla","flac","flv","fnt","folder","fon","gadget","gdp","gem","gif","gitattributes","gitignore","go","gpg","gpl","gradle","gz","h","handlebars","hbs","heic","hlp","hs","hsl","htm","html","ibooks","icns","ico","ics","idx","iff","ifo","image","img","iml","in","inc","indd","inf","info","ini","inv","iso","j2","jar","java","jpe","jpeg","jpg","js","json","jsp","jsx","key","kf8","kmk","ksh","kt","kts","kup","less","lex","licx","lisp","lit","lnk","lock","log","lua","m","m2v","m3u","m3u8","m4","m4a","m4r","m4v","map","master","mc","md","mdb","mdf","me","mi","mid","midi","mk","mkv","mm","mng","mo","mobi","mod","mov","mp2","mp3","mp4","mpa","mpd","mpe","mpeg","mpg","mpga","mpp","mpt","msg","msi","msu","nef","nes","nfo","nix","npmignore","ocx","odb","ods","odt","ogg","ogv","ost","otf","ott","ova","ovf","p12","p7b","pages","part","pcd","pdb","pdf","pem","pfx","pgp","ph","phar","php","pid","pkg","pl","plist","pm","png","po","pom","pot","potx","pps","ppsx","ppt","pptm","pptx","prop","ps","ps1","psd","psp","pst","pub","py","pyc","qt","ra","ram","rar","raw","rb","rdf","rdl","reg","resx","retry","rm","rom","rpm","rpt","rsa","rss","rst","rtf","ru","rub","sass","scss","sdf","sed","sh","sit","sitemap","skin","sldm","sldx","sln","sol","sphinx","sql","sqlite","step","stl","svg","swd","swf","swift","swp","sys","tar","tax","tcsh","tex","tfignore","tga","tgz","tif","tiff","tmp","tmx","torrent","tpl","ts","tsv","ttf","twig","txt","udf","vb","vbproj","vbs","vcd","vcf","vcs","vdi","vdx","vmdk","vob","vox","vscodeignore","vsd","vss","vst","vsx","vtx","war","wav","wbk","webinfo","webm","webp","wma","wmf","wmv","woff","woff2","wps","wsf","xaml","xcf","xfl","xlm","xls","xlsm","xlsx","xlt","xltm","xltx","xml","xpi","xps","xrb","xsd","xsl","xspf","xz","yaml","yml","z","zip","zsh"]'); /***/ }) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ id: moduleId, /******/ loaded: false, /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); /******/ /******/ // Flag the module as loaded /******/ module.loaded = true; /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /************************************************************************/ /******/ /* webpack/runtime/amd options */ /******/ (() => { /******/ __webpack_require__.amdO = {}; /******/ })(); /******/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/global */ /******/ (() => { /******/ __webpack_require__.g = (function() { /******/ if (typeof globalThis === 'object') return globalThis; /******/ try { /******/ return this || new Function('return this')(); /******/ } catch (e) { /******/ if (typeof window === 'object') return window; /******/ } /******/ })(); /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ (() => { /******/ // define __esModule on exports /******/ __webpack_require__.r = (exports) => { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/node module decorator */ /******/ (() => { /******/ __webpack_require__.nmd = (module) => { /******/ module.paths = []; /******/ if (!module.children) module.children = []; /******/ return module; /******/ }; /******/ })(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // This entry need to be wrapped in an IIFE because it need to be in strict mode. (() => { "use strict"; // NAMESPACE OBJECT: ./node_modules/absol/src/JSX/dom.js var dom_namespaceObject = {}; __webpack_require__.r(dom_namespaceObject); __webpack_require__.d(dom_namespaceObject, { "domVisitor": () => (domVisitor), "parseDom": () => (parseDom) }); // NAMESPACE OBJECT: ./node_modules/absol/src/Math/measurements.js var measurements_namespaceObject = {}; __webpack_require__.r(measurements_namespaceObject); __webpack_require__.d(measurements_namespaceObject, { "PAGE_SIZE_IN_DOT": () => (PAGE_SIZE_IN_DOT), "PAGE_SIZE_IN_POINT": () => (PAGE_SIZE_IN_POINT), "centimeterToPx": () => (centimeterToPx), "dotToPoint": () => (dotToPoint), "feetToMeter": () => (feetToMeter), "latLngDistance": () => (latLngDistance), "latLngRectFromCenter": () => (latLngRectFromCenter), "meterToFeet": () => (meterToFeet), "meterToInch": () => (meterToInch), "meterToMile": () => (meterToMile), "meterToYard": () => (meterToYard), "mileToMeter": () => (mileToMeter), "pointToDot": () => (pointToDot), "pxToCentimeter": () => (pxToCentimeter), "yardToMeter": () => (yardToMeter) }); // EXTERNAL MODULE: ./node_modules/atob/browser-atob.js var browser_atob = __webpack_require__(9892); var browser_atob_default = /*#__PURE__*/__webpack_require__.n(browser_atob); // EXTERNAL MODULE: ./node_modules/btoa/index.js var btoa = __webpack_require__(706); var btoa_default = /*#__PURE__*/__webpack_require__.n(btoa); // EXTERNAL MODULE: ./node_modules/intl/index.js var intl = __webpack_require__(8267); var intl_default = /*#__PURE__*/__webpack_require__.n(intl); ;// CONCATENATED MODULE: ./node_modules/absol/src/Polyfill/polyfill.js if (!('Intl' in window)){ window.Intl = (intl_default()); } if (!('atob' in window)) { window.atob = (browser_atob_default()); } if (!('btoa' in window)) { window.btoa = (btoa_default()); } !function (e, n) { "object" == typeof exports && "undefined" != "object" ? n() : "function" == typeof define && __webpack_require__.amdO ? define(n) : n() }(0, function () { "use strict"; function e(e) { var n = this.constructor; return this.then(function (t) { return n.resolve(e()).then(function () { return t }) }, function (t) { return n.resolve(e()).then(function () { return n.reject(t) }) }) } function n() { } function t(e) { if (!(this instanceof t)) throw new TypeError("Promises must be constructed via new"); if ("function" != typeof e) throw new TypeError("not a function"); this._state = 0, this._handled = !1, this._value = undefined, this._deferreds = [], u(e, this) } function o(e, n) { for (; 3 === e._state;) e = e._value; 0 !== e._state ? (e._handled = !0, t._immediateFn(function () { var t = 1 === e._state ? n.onFulfilled : n.onRejected; if (null !== t) { var o; try { o = t(e._value) } catch (f) { return void i(n.promise, f) } r(n.promise, o) } else (1 === e._state ? r : i)(n.promise, e._value) })) : e._deferreds.push(n) } function r(e, n) { try { if (n === e) throw new TypeError("A promise cannot be resolved with itself."); if (n && ("object" == typeof n || "function" == typeof n)) { var o = n.then; if (n instanceof t) return e._state = 3, e._value = n, void f(e); if ("function" == typeof o) return void u(function (e, n) { return function () { e.apply(n, arguments) } }(o, n), e) } e._state = 1, e._value = n, f(e) } catch (r) { i(e, r) } } function i(e, n) { e._state = 2, e._value = n, f(e) } function f(e) { 2 === e._state && 0 === e._deferreds.length && t._immediateFn(function () { e._handled || t._unhandledRejectionFn(e._value) }); for (var n = 0, r = e._deferreds.length; r > n; n++) o(e, e._deferreds[n]); e._deferreds = null } function u(e, n) { var t = !1; try { e(function (e) { t || (t = !0, r(n, e)) }, function (e) { t || (t = !0, i(n, e)) }) } catch (o) { if (t) return; t = !0, i(n, o) } } var c = setTimeout; t.prototype["catch"] = function (e) { return this.then(null, e) }, t.prototype.then = function (e, t) { var r = new this.constructor(n); return o(this, new function (e, n, t) { this.onFulfilled = "function" == typeof e ? e : null, this.onRejected = "function" == typeof n ? n : null, this.promise = t }(e, t, r)), r }, t.prototype["finally"] = e, t.all = function (e) { return new t(function (n, t) { function o(e, f) { try { if (f && ("object" == typeof f || "function" == typeof f)) { var u = f.then; if ("function" == typeof u) return void u.call(f, function (n) { o(e, n) }, t) } r[e] = f, 0 == --i && n(r) } catch (c) { t(c) } } if (!e || "undefined" == typeof e.length) throw new TypeError("Promise.all accepts an array"); var r = Array.prototype.slice.call(e); if (0 === r.length) return n([]); for (var i = r.length, f = 0; r.length > f; f++) o(f, r[f]) }) }, t.resolve = function (e) { return e && "object" == typeof e && e.constructor === t ? e : new t(function (n) { n(e) }) }, t.reject = function (e) { return new t(function (n, t) { t(e) }) }, t.race = function (e) { return new t(function (n, t) { for (var o = 0, r = e.length; r > o; o++) e[o].then(n, t) }) }, t._immediateFn = "function" == typeof setImmediate && function (e) { setImmediate(e) } || function (e) { c(e, 0) }, t._unhandledRejectionFn = function (e) { void 0 !== console && console && console.warn("Possible Unhandled Promise Rejection:", e) }; var l = function () { if ("undefined" != typeof self) return self; if ("undefined" != typeof window) return window; if ("undefined" != typeof __webpack_require__.g) return __webpack_require__.g; throw Error("unable to locate global object") }(); "Promise" in l ? l.Promise.prototype["finally"] || (l.Promise.prototype["finally"] = e) : l.Promise = t }); !(function () { var vendors = ['ms', 'moz', 'webkit', 'o']; for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame']; window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame']; } if (!window.requestAnimationFrame) window.requestAnimationFrame = function (callback, element) { var id = window.setTimeout(function () { callback(element); }, 1000 / 60); return id; }; if (!window.cancelAnimationFrame) window.cancelAnimationFrame = function (id) { clearTimeout(id); }; }()); //Object (function () { 'use strict'; var ObjectProto = Object.prototype, defineGetter = ObjectProto.__defineGetter__, defineSetter = ObjectProto.__defineSetter__, lookupGetter = ObjectProto.__lookupGetter__, lookupSetter = ObjectProto.__lookupSetter__, hasOwnProp = ObjectProto.hasOwnProperty; var supportDom = true; try { if (Object.defineProperty) { Object.defineProperty(document.createElement('div'), 'theRandomName', { set: function () { }, get: function () { } }); } } catch (error) { supportDom = false; } if ((!supportDom || !Object.defineProperty) && defineGetter && defineSetter && lookupGetter && lookupSetter) { var originObjetDefineProperty = Object.defineProperty; Object.defineProperty = function (obj, prop, descriptor) { if (!originObjetDefineProperty || (typeof obj.nodeType === "number" && typeof obj.nodeName === "string")) { if (arguments.length < 3) { // all arguments required throw new TypeError("Arguments not optional"); } prop += ""; // convert prop to string if (hasOwnProp.call(descriptor, "value")) { if (!lookupGetter.call(obj, prop) && !lookupSetter.call(obj, prop)) { // data property defined and no pre-existing accessors obj[prop] = descriptor.value; } if ((hasOwnProp.call(descriptor, "get") || hasOwnProp.call(descriptor, "set"))) { // descriptor has a value prop but accessor already exists throw new TypeError("Cannot specify an accessor and a value"); } } if (descriptor.get) { defineGetter.call(obj, prop, descriptor.get); } if (descriptor.set) { defineSetter.call(obj, prop, descriptor.set); } return obj; } else { return originObjetDefineProperty.call(this, obj, prop, descriptor); } }; var originObjectGetOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; Object.getOwnPropertyDescriptor = function (obj, prop) { if (!originObjectGetOwnPropertyDescriptor || typeof obj.nodeType === "number" && typeof obj.nodeName === "string") { if (arguments.length < 2) { // all arguments required throw new TypeError("Arguments not optional."); } prop += ""; // convert prop to string var descriptor = { configurable: true, enumerable: true, writable: true }, getter = lookupGetter.call(obj, prop), setter = lookupSetter.call(obj, prop); if (!hasOwnProp.call(obj, prop)) { // property doesn't exist or is inherited return descriptor; } if (!getter && !setter) { // not an accessor so return prop descriptor.value = obj[prop]; return descriptor; } // there is an accessor, remove descriptor.writable; // populate descriptor.get and descriptor.set (IE's behavior) delete descriptor.writable; descriptor.get = descriptor.set = undefined; if (getter) { descriptor.get = getter; } if (setter) { descriptor.set = setter; } return descriptor; } else { return originObjectGetOwnPropertyDescriptor(obj, prop); } }; } if (!supportDom || !Object.getOwnPropertyDescriptors) { Object.getOwnPropertyDescriptors = function (o) { var res = {}; for (var key in o) { res[key] = Object.getOwnPropertyDescriptor(o, key); } return res; }; } if (!supportDom || !Object.defineProperties) { Object.defineProperties = function (obj, props) { var prop; for (prop in props) { if (hasOwnProp.call(props, prop)) { Object.defineProperty(obj, prop, props[prop]); } } }; } if (typeof Object.assign != 'function') { Object.assign = function (target, varArgs) { 'use strict'; if (target == null) { throw new TypeError('Cannot convert undefined or null to object'); } var to = Object(target); for (var index = 1; index < arguments.length; index++) { var nextSource = arguments[index]; if (nextSource != null) { for (var nextKey in nextSource) { if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) { to[nextKey] = nextSource[nextKey]; } } } } return to; }; } }()); //string !(function () { if (!String.prototype.startsWith) { String.prototype.startsWith = function (searchString, position) { position = position || 0; return this.indexOf(searchString, position) === position; }; } if (!String.prototype.replaceAll) { String.prototype.replaceAll = function () { var find = arguments[0]; if (!find) return this; if (typeof find == "string") { return this.split(find).join(arguments[1]); } else if (find instanceof RegExp) { return this.replace(new RegExp(find.source, 'g'), arguments[1]); } } } })(); //array !(function () { if (!Array.prototype.fill) { Object.defineProperty(Array.prototype, 'fill', { value: function (value) { // Steps 1-2. if (this == null) { throw new TypeError('this is null or not defined'); } var O = Object(this); // Steps 3-5. var len = O.length >>> 0; // Steps 6-7. var start = arguments[1]; var relativeStart = start >> 0; // Step 8. var k = relativeStart < 0 ? Math.max(len + relativeStart, 0) : Math.min(relativeStart, len); // Steps 9-10. var end = arguments[2]; var relativeEnd = end === undefined ? len : end >> 0; // Step 11. var final = relativeEnd < 0 ? Math.max(len + relativeEnd, 0) : Math.min(relativeEnd, len); // Step 12. while (k < final) { O[k] = value; k++; } // Step 13. return O; } }); } if (!Array.prototype.some) { Array.prototype.some = function (fun /*, thisp */) { "use strict"; if (this == null) throw new TypeError(); var t = Object(this), len = t.length >>> 0; if (typeof fun != "function") throw new TypeError(); var thisp = arguments[1]; for (var i = 0; i < len; i++) { if (i in t && fun.call(thisp, t[i], i, t)) return true; } return false; }; } })(); //function !(function () { if (!Function.prototype.bind) { var ArrayPrototypeSlice = Array.prototype.slice; Function.prototype.bind = function (otherThis) { if (typeof this !== 'function') { // closest thing possible to the ECMAScript 5 // internal IsCallable function throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable'); } var baseArgs = ArrayPrototypeSlice.call(arguments, 1), baseArgsLength = baseArgs.length, fToBind = this, fNOP = function () { }, fBound = function () { baseArgs.length = baseArgsLength; // reset to default base arguments baseArgs.push.apply(baseArgs, arguments); return fToBind.apply( fNOP.prototype.isPrototypeOf(this) ? this : otherThis, baseArgs ); }; if (this.prototype) { // Function.prototype doesn't have a prototype property fNOP.prototype = this.prototype; } fBound.prototype = new fNOP(); return fBound; }; } })(); // EXTERNAL MODULE: ./node_modules/absol/src/Polyfill/gps.js var gps = __webpack_require__(1942); ;// CONCATENATED MODULE: ./node_modules/absol/src/polyfill.js // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/EventEmitter.js var EventEmitter = __webpack_require__(863); // EXTERNAL MODULE: ./node_modules/absol/src/Detector/BrowserDetector.js var BrowserDetector = __webpack_require__(9399); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/JSPath.js var JSPath = __webpack_require__(8706); // EXTERNAL MODULE: ./node_modules/absol/src/JSMaker/TemplateString.js var TemplateString = __webpack_require__(369); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLConstant.js var XMLConstant = { TYPE_ELEMENT:1, TYPE_TEXT:3, TYPE_COMMENT:8, TYPE_DECLARATION:16 }; /* harmony default export */ const XML_XMLConstant = (XMLConstant); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLDeclarationNode.js function XMLDeclaretionNode() { this.nodeType = XML_XMLConstant.TYPE_DECLARATION; this.parentNode; /** * @type {String} */ this.tagName = ''; /** * @type {XMLElement} */ this.parentNode; this.attributes = {}; } /** * @param {String} name attribute name */ XMLDeclaretionNode.prototype.getAttribute = function (name) { return this.attributes[name]; }; /** * @param {String} name attribute name * @param {String} value */ XMLDeclaretionNode.prototype.setAttribute = function (name, value) { this.attributes[name] = value; }; /** * @param {String} name attribute name */ XMLDeclaretionNode.prototype.removeAttribute = function (name) { delete this.attributes[name]; }; XMLDeclaretionNode.prototype.remove = function () { if (this.parentNode) { this.parentNode.removeChild(this); } }; XMLDeclaretionNode.prototype.toObject = function () { return { nodeType: this.nodeType, tagName: this.tagName, attributes: Object.assign({}, this.attributes) }; }; /* harmony default export */ const XMLDeclarationNode = (XMLDeclaretionNode); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLClassList.js /** * * @param {XMLElement} xmlNode */ function XMLClassList(xmlNode) { this.xmlNode = xmlNode; } /** * @param {String} name * @returns {Boolean} */ XMLClassList.prototype.contains = function (name) { var className = this.xmlNode.getAttribute('class'); if (className) { var classes = className.trim().split(/\s+/); for (var i = 0; i < classes.length; ++i) { if (classes[i] == name) return true; } return false; } else return false; }; /** * @param {Number} index * @returns {String} */ XMLClassList.prototype.item = function (index) { var className = this.xmlNode.getAttribute('class'); if (className) { var classes = className.trim().split(/\s+/); return classes[index]; } else return undefined; }; /** * @param {Array<String>} arguments */ XMLClassList.prototype.remove = function () { var dict = Array.prototype.reduce.call(arguments, function (ac, name) { ac[name] = true; return ac; }, {}); var className = this.xmlNode.getAttribute('class'); if (className) { var classes = className.trim().split(/\s+/); var newClasses = classes.filter(function (name) { dict[name]; }); this.xmlNode.setAttribute(newClasses.join(' ')); } }; /** * @param {Array<String>} arguments */ XMLClassList.prototype.add = function () { var className = this.xmlNode.getAttribute('class') || ''; var classes = className.trim().split(/\s+/); var dict = classes.reduce(function (ac, name) { ac[name] = true; return ac; }, {}); for (var i = 0; i < arguments.length; ++i) { var newClass = arguments[i].trim(); if (newClass.length == 0) return; if (!dict[newClass]) { classes.push(newClass); dict[newClass] = true; } } this.xmlNode.setAttribute('class', classes.join(' ')); }; /* harmony default export */ const XML_XMLClassList = (XMLClassList); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLElement.js function XMLElement() { this.nodeType = XML_XMLConstant.TYPE_ELEMENT; /** * @type {String} */ this.tagName = ''; /** * @type {XMLElement} */ this.parentNode; this.attributes = {}; /** * @type {Array} Array of XMLElement or XMLText */ this.childNodes = []; Object.defineProperty(this, 'classList', { value: new XML_XMLClassList(this), writable: false }); } /** * @param {String} name attribute name */ XMLElement.prototype.getAttribute = function (name) { return this.attributes[name]; }; /** * @param {String} name attribute name * @param {String} value */ XMLElement.prototype.setAttribute = function (name, value) { this.attributes[name] = value; }; /** * @param {String} name attribute name */ XMLElement.prototype.removeAttribute = function (name) { delete this.attributes[name]; }; XMLElement.prototype.appendChild = function (node) { node.remove(); this.childNodes.push(node); node.parentNode = this; return node; }; /** * @param {XMLElement} child * @returns {XMLElement} removed node */ XMLElement.prototype.removeChild = function (child) { var result; if (this == child.parentNode) { var j = 0; for (var i = 0; i < this.childNodes.length; ++i) { if (child != this.childNodes[i]) { this.childNodes[j] = this.childNodes[i]; ++j; } else { child.parentNode = undefined; result = child; } } while (j > this.childNodes.length) { this.childNodes.pop(); } } return result; }; /** * @param {XMLElement|XMLText|XMLDeclaretionNode} node */ XMLElement.prototype.inserBefore = function (node, child) { if (node == child) return; var childIndex = -1; for (var i = 0; i < this.childNodes.length; ++i) { if (this.childNodes[i] == child) { childIndex = i; break; } } if (childIndex < 0) return; node.remove(); node.parentNode = this; this.childNodes.push(null); var cIndex = this.childNodes.length - 2; while (cIndex >= 0) { if (this.childNodes[cIndex] == child) { this.childNodes[cIndex + 1] = node; } else this.childNodes[cIndex + 1] = this.childNodes[cIndex]; } }; XMLElement.prototype.remove = function () { if (this.parentNode) { this.parentNode.removeChild(this); } }; XMLElement.prototype.toObject = function () { return { nodeType: this.nodeType, tagName: this.tagName, attributes: Object.assign({}, this.attributes), childNodes: this.childNodes.map(function (child) { return child.toObject(); }) }; }; /* harmony default export */ const XML_XMLElement = (XMLElement); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLTextNode.js function XMLTextNode(data) { this.nodeType = XML_XMLConstant.TYPE_TEXT; /** * @type {XMLNode} */ this.parentNode; /** * @type {String} */ this.data = data || ''; } XMLTextNode.prototype.remove = function () { if (this.parentNode) { this.parentNode.removeChild(this); } }; XMLTextNode.prototype.toObject = function () { return { nodeType: this.nodeType, data: this.data }; }; /* harmony default export */ const XML_XMLTextNode = (XMLTextNode); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XMLCommentNode.js function XMLCommentNode(data) { this.nodeType = XML_XMLConstant.TYPE_COMMENT; /** * @type {XMLNode} */ this.parentNode; /** * @type {String} */ this.data = data || ''; } XMLCommentNode.prototype.remove = function () { if (this.parentNode) { this.parentNode.removeChild(this); } }; XMLCommentNode.prototype.toObject = function () { return { nodeType: this.nodeType, data: this.data }; }; /* harmony default export */ const XML_XMLCommentNode = (XMLCommentNode); ;// CONCATENATED MODULE: ./node_modules/absol/src/XML/XML.js /** * * @param {RegExp} regex */ function getRegexBody(regex) { return regex.toString().match(/^\/(.+)\/([gimuy]*)$/)[1]; } var BEGIN_TAG = 1; var END_TAG = 2; var CDATA = 3; var DECLARATION = 4; var COMMENT = 5; var TEXT = 6; var identRgx = /[^\s\"\r\n\'\!\/=\>\<\]\[\?\+\.]+/; var spaceRgx = /[\s\r\n]+/; var stringRgx = /\"(([^\"\\]*|(\\.))*)\"/; var textRgx = /[^\<\-]+/; var doctypeOpenRgx = /\<\!DOCTYPE/; var commentOpenRgx = /\<!\-\-/; var commentCloseRgx = /\-\-\>/; var cdataOpenRgx = /\<\!\[CDATA\[/; var cdataCloseRgx = /\]\]\>/; var openRgx = /\</; var openEndTagRgx = /\<\//; var closeRgx = /\>/; var shortCloseRgx = /\/\>/; var declarationOpenRgx = /\<\?/; var declarationCloseRgx = /\?\>/; var assignOpRgx = /=/; var tokenRgxBody = '(' + [ spaceRgx, doctypeOpenRgx, declarationOpenRgx, cdataOpenRgx, commentOpenRgx, openEndTagRgx, openRgx, assignOpRgx, stringRgx, commentCloseRgx, identRgx, declarationCloseRgx, shortCloseRgx, closeRgx, cdataCloseRgx, textRgx ].map(function (e) { return getRegexBody(e); }).join(')|(') + ')'; var tokenType = { space: spaceRgx, doctypeOpen: doctypeOpenRgx, declarationOpen: declarationOpenRgx, cdataOpen: cdataOpenRgx, commentOpen: commentOpenRgx, openEndTag: openEndTagRgx, open: openRgx, ident: identRgx, assignOp: assignOpRgx, string: stringRgx, commentClose: commentCloseRgx, declarationClose: declarationCloseRgx, shortClose: shortCloseRgx, close: closeRgx, cdataClose: cdataCloseRgx, text: textRgx } var tokenRgx = new RegExp(tokenRgxBody); /** * * @typedef {Object} Token * @property {String} text * @property {*} matched */ /** * * @param {String} text * @returns {Array<Token>} */ function xmlTokenize(text) { var texts = text.match(new RegExp(tokenRgxBody, 'g')); return text.match(new RegExp(tokenRgxBody, 'g')) .map(function (tokenText, i) { var result = { text: tokenText, matched: {} }; for (var tType in tokenType) { var matched = tokenText.match(tokenType[tType]); if (matched) { if (matched[0] == tokenText) result.matched[tType] = matched; } } return result; }); } /** * @typedef {Object} XMLPaseInfo * @property {Array<Token>} tokens * @property {Number} type * @property {Number} start * @property {Number} end * @property {Error} error * @property {Boolean} closed * * * * @typedef {Object} XMLParseNode * @property {XMLPaseInfo} __xml__ * @property {String} tagName * @property {*} attributes * @property {String} text */ /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchAssign(tokens, i) { var result = { __xml__: { start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['ident']) { result.key = cToken.text; ++i; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['space']) { ++i; } if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['assignOp']) { ++i; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['space']) { ++i; } if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['string']) { result.value = cToken.matched.string[1]; ++i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected string'); } } else { result.__xml__.error = new Error('End of data found, expected ident'); } } else { result.__xml__.error = new Error('End of data found, expected ident'); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected ='); } } else { result.__xml__.error = new Error('End of data found, expected ='); } } else { result.__xml__.error = new Error('End of data found, expected ='); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected ident'); } } else { result.__xml__.error = new Error('End of data found, expected ident'); } result.__xml__.end = i; return result; } /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchBeginTag(tokens, i) { var result = { __xml__: { type: BEGIN_TAG, start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['open']) { ++i; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['ident']) { result.tagName = cToken.text; ++i; if (i < tokens.length) { var finished = false;//when find the close symbol while (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['space']) { ++i; }//skip space between attributes if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['shortClose']) { result.__xml__.closed = true; ++i; finished = true; break; } else if (cToken.matched['close']) { result.__xml__.closed = false; ++i; finished = true; break; } else if (tokens[i - 1].matched['space']) { var assign = matchAssign(tokens, i); if (!assign.__xml__.error) { result.attributes = result.attributes || {}; result.attributes[assign.key] = assign.value; i = assign.__xml__.end; } else if (cToken.matched['ident']) { result.attributes = result.attributes || {}; result.attributes[cToken.text] = true;// a flag ++i; } else { //TODO: we can ignore some error here, the same with order Match* function result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); break; } } else { //TODO: we can ignore some error here result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); break; } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); break; } } if (!finished && !result.__xml__.error) { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('Expected indent'); } } else { result.__xml__.error = new Error('End of data found, expected indent'); } result.__xml__.end = i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected <'); } } else { result.__xml__.error = new Error('End of data found, expected <'); } result.__xml__.end = i; return result; } /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchEndTag(tokens, i) { var result = { __xml__: { type: END_TAG, closed: true, start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['openEndTag']) { ++i; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['ident']) { result.tagName = cToken.text; ++i; if (i < tokens.length) { var finished = false;//when find the close symbol while (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['space']) { ++i; }//skip space between attributes if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['close']) { ++i; finished = true; break; } else if (tokens[i - 1].matched['space']) { var assign = matchAssign(tokens, i); if (!assign.__xml__.error) { result.attributes = result.attributes || {}; result.attributes[assign.key] = assign.value; i = assign.__xml__.end; } else if (cToken.matched['ident']) { result.attributes = result.attributes || {}; result.attributes[cToken.text] = true;// a flag ++i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); } } if (!finished && !result.__xml__.error) { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('Expected indent'); } } else { result.__xml__.error = new Error('End of data found, expected indent'); } result.__xml__.end = i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected <'); } } else { result.__xml__.error = new Error('End of data found, expected <'); } result.__xml__.end = i; return result; } /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchDeclaration(tokens, i) { var result = { __xml__: { type: DECLARATION, start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['declarationOpen']) { ++i; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['ident']) { result.tagName = cToken.text; ++i; if (i < tokens.length) { var finished = false;//when find the close symbol while (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['space']) { ++i; }//skip space between attributes if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['declarationClose']) { result.__xml__.closed = false; ++i; finished = true; break; } else if (tokens[i - 1].matched['space']) { var assign = matchAssign(tokens, i); if (!assign.__xml__.error) { result.attributes = result.attributes || {}; result.attributes[assign.key] = assign.value; i = assign.__xml__.end; } else if (cToken.matched['ident']) { result.attributes = result.attributes || {}; result.attributes[cToken.text] = true;// a flag ++i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected > or indent'); } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); } } if (!finished && !result.__xml__.error) { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('End of data found, expected /> or >'); } } else { result.__xml__.error = new Error('Expected indent'); } } else { result.__xml__.error = new Error('End of data found, expected indent'); } result.__xml__.end = i; } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected <'); } } else { result.__xml__.error = new Error('End of data found, expected <'); } result.__xml__.end = i; return result; } /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchCData(tokens, i) { var result = { __xml__: { type: CDATA, start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['cdataOpen']) { ++i; result.text = ''; var finished = false; while (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['cdataClose']) { finished = true; ++i; break; } else { result.text += cToken.text; ++i; } } if (!finished) { result.__xml__.error = new Error('End of data found, expected ]]>'); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected <![CDATA['); } } else { result.__xml__.error = new Error('End of data found, expected <![CDATA['); } result.__xml__.end = i return result; } /** * * @param {Array<Token>} tokens * @param {Number} i * @returns {XMLParseNode} */ function matchComment(tokens, i) { var result = { __xml__: { type: COMMENT, start: i } }; var cToken; if (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['commentOpen']) { ++i; result.text = ''; var finished = false; while (i < tokens.length) { cToken = tokens[i]; if (cToken.matched['commentClose']) { finished = true; ++i; break; } else { result.text += cToken.text; ++i; } } if (!finished) { result.__xml__.error = new Error('End of data found, expected -->'); } } else { result.__xml__.error = new Error('"' + cToken.text + '"' + 'found, expected <!--'); } } else { result.__xml__.error = new Error('End of data found, expected <!--'); } result.__xml__.end = i; return result; } /** * * @param {Token} tokens */ function parseXMLTab(tokens) { var tabs = []; var i = 0; while (i < tokens.length) { var comment = matchComment(tokens, i); if (!comment.__xml__.error) { tabs.push(comment); i = comment.__xml__.end; } else { var declaration = matchDeclaration(tokens, i); if (!declaration.__xml__.error) { tabs.push(declaration); i = declaration.__xml__.end; } else { var begin = matchBeginTag(tokens, i); if (!begin.__xml__.error) { tabs.push(begin); i = begin.__xml__.end; } else { var end = matchEndTag(tokens, i); if (!end.__xml__.error) { tabs.push(end); i = end.__xml__.end; } else { var cdata = matchCData(tokens, i); if (!cdata.__xml__.error) { tabs.push(cdata); i = cdata.__xml__.end; } else { ++i;//skip } } } } } } return tabs; } /** * * @param {Array<Token>} tokens * @param {Array<XMLParseNode>} tabs * @returns {Array<XMLParseNode>} */ function parseXMLText(tokens, tabs) { var texts = []; var ofs = 0; var text; var tab; for (var i = 0; i < tabs.length; ++i) { tab = tabs[i]; if (tab.__xml__.start > ofs) { text = tokens.slice(ofs, tab.__xml__.start) .map(function (token) { return token.text; }).join('').trim(); if (text.length > 0) texts.push({ __xml__: { type: TEXT, tokens: tokens, start: ofs, end: tab.__xml__.start }, text: text }); } ofs = tab.__xml__.end; } if (ofs < tokens.length) { text = tokens.slice(ofs) .map(function (token) { return token.text; }).join('').trim(); if (text.length > 0) texts.push({ __xml__: { type: TEXT, tokens: tokens, start: ofs, end: tab.__xml__.start }, text: text }); } return texts; } /** * * @param {Array<XMLParseNode>} tabs * @param {Array<XMLParseNode>} texts * @return {Array<XMLParseNode>} */ function mergeNodes(tabs, texts) { var nodes = []; var choose; var iTabs = 0, iTexts = 0; var diTabs, diTexts; var minStart; do { choose = undefined; diTabs = 0, diTexts = 0; minStart = 100000000; if (iTabs < tabs.length) { choose = tabs[iTabs]; minStart = choose.__xml__.start; diTabs = 1; } if (iTexts < texts.length && texts[iTexts].__xml__.start < minStart) { choose = texts[iTexts]; minStart = choose.__xml__.start; diTabs = 0; diTexts = 1; } if (choose) { iTexts += diTexts; iTabs += diTabs; nodes.push(choose); } } while (choose); return nodes; } /** * * @param {String} text * @return {Array<XMLParseNode>} */ function parseXMLTextToXMLParseNode(text) { text = text.trim(); var tokens = xmlTokenize(text.trim()); var tabs = parseXMLTab(tokens); var texts = parseXMLText(tokens, tabs); return mergeNodes(tabs, texts); } /** * * @param {Array<XMLParseNode>} nodes * @returns {Array} */ function paresNodesToXMLs(nodes) { var node; var parentXMLElement = new XML_XMLElement(); parentXMLElement.tagName = "FAKE_DOCUMENT"; var assignAttributes = function (node, attributes) { Object.keys(attributes).forEach(function (key) { node.setAttribute(key, attributes[key]); }) } var newXMLNode; for (var i = 0; i < nodes.length; ++i) { node = nodes[i]; newXMLNode = undefined; switch (node.__xml__.type) { case DECLARATION: newXMLNode = new XMLDeclarationNode(); newXMLNode.tagName = node.tagName; if (node.attributes) assignAttributes(newXMLNode, node.attributes); parentXMLElement.appendChild(newXMLNode); break; case BEGIN_TAG: newXMLNode = new XML_XMLElement(); newXMLNode.tagName = node.tagName; if (node.attributes) assignAttributes(newXMLNode, node.attributes); parentXMLElement.appendChild(newXMLNode); if (!node.__xml__.closed) parentXMLElement = newXMLNode; break; case END_TAG: if (parentXMLElement && node.tagName == parentXMLElement.tagName) { parentXMLElement = parentXMLElement.parentNode; } else if (parentXMLElement && (parentXMLElement.tagName == 'img' || parentXMLElement.tagName == 'input')) { // image can be not close while (parentXMLElement.tagName == 'img' || parentXMLElement.tagName == 'input') { parentXMLElement = parentXMLElement.parentNode; } parentXMLElement = parentXMLElement.parentNode; } else { throw new Error("Unknown close of tagName " + node.tagName + ', but ' + (parentXMLElement ? parentXMLElement.tagName : "EOF") + ' expected'); } break; case TEXT: newXMLNode = new XML_XMLTextNode(node.text); parentXMLElement.appendChild(newXMLNode); break; case COMMENT: newXMLNode = new XML_XMLCommentNode(node.text); parentXMLElement.appendChild(newXMLNode); break; } } return parentXMLElement.childNodes.slice().map(function (e) { e.remove(); return e; }); } /** * * @param {XMLElement} node */ function makeOpenXMLElementTab(node) { var res = '<' + node.tagName; var attributesText = Object.keys(node.attributes) .map(function (key) { var value = node.attributes[key]; if (value === null) { return key; } else { return key + '=' + '"' + value + '"'; } }).join(' '); if (attributesText.length > 0) { res += ' ' + attributesText; } res += '>'; return res; } /** * * @param {XMLDeclaretionNode} node */ function makeXMLDeclaretionTab(node) { var res = '<?' + node.tagName; var attributesText = Object.keys(node.attributes) .map(function (key) { var value = node.attributes[key]; if (value === null) { return key; } else { return key + '=' + '"' + value + '"'; } }).join(' '); if (attributesText.length > 0) { res += ' ' + attributesText; } res += '?>'; return res; } /** * * @param {XMLDeclaretionNode} node */ function makeXMLCommentTab(node) { var res = '<!--' + node.data + '-->'; return res; } var XML = {}; /** * @param {String} code * @returns {Array<XMLElement>} */ XML.parseLikeHTML = function (code) { var nodes = parseXMLTextToXMLParseNode(code); // console.log('nodes', nodes); var xmls = paresNodesToXMLs(nodes); return xmls; }; /** * @param {String} code * @returns {XMLElement} */ XML.parse = function (code) { var xmls = this.parseLikeHTML(code); if (xmls.length == 0) return undefined; var obj = xmls[xmls.length - 1].toObject(); return obj; }; XML.DFNodeVisit = function (node, handlers, accumulator) { if (!node.childNodes || node.childNodes.length == 0) { if (handlers.leaf) handlers.leaf(accumulator, node); } else { if (handlers.open) handlers.open(accumulator, node); for (var i = 0; i < node.childNodes.length; ++i) { this.DFNodeVisit(node.childNodes[i], handlers, accumulator); } if (handlers.close) handlers.close(accumulator, node); return accumulator; } }; /** * @typedef {Object} XMLBeautifyOption * @property {String} indent * @property {Number} initDepth */ /** * @param {Array<XMLElement>} o * @param {XMLBeautifyOption} beautifyOption * * */ XML.stringify = function (o, beautifyOption) { var texts = []; var indent = ''; var lineBreak = ''; var depth = 0; if (beautifyOption) { lineBreak = '\n'; indent = typeof (beautifyOption.indent) == 'string' ? beautifyOption.indent : ' '; depth = beautifyOption.initDepth || 0; } if (!(o instanceof Array)) { o = [o]; } var visitor = { open: function (ac, node) { var currentLineIndent = ac.lineIndentStack[ac.lineIndentStack.length - 1]; var openTabText = makeOpenXMLElementTab(node); ac.texts.push(currentLineIndent + openTabText); ac.lineIndentStack.push(currentLineIndent + ac.indent); }, close: function (ac, node) { ac.lineIndentStack.pop(); var currentLineIndent = ac.lineIndentStack[ac.lineIndentStack.length - 1]; var endTab = '</' + node.tagName + '>'; if (node.childNodes.length == 1 && node.childNodes[0].nodeType == XML_XMLConstant.TYPE_TEXT) { ac.texts[ac.texts.length - 1] += endTab; } else { ac.texts.push(currentLineIndent + endTab); } }, leaf: function (ac, node) { var currentLineIndent = ac.lineIndentStack[ac.lineIndentStack.length - 1]; var tab; if (node.nodeType == XML_XMLConstant.TYPE_TEXT) { if (node.parentNode && node.parentNode.childNodes.length == 1) { ac.texts[ac.texts.length - 1] += node.data; } else { ac.texts.push(currentLineIndent + node.data); } } else if (node.nodeType == XML_XMLConstant.TYPE_ELEMENT) { var openTabText = makeOpenXMLElementTab(node); var endTab = '</' + node.tagName + '>'; ac.texts.push(currentLineIndent + openTabText + endTab); } else if (node.nodeType == XML_XMLConstant.TYPE_DECLARATION) { tab = makeXMLDeclaretionTab(node); ac.texts.push(currentLineIndent + tab); } else if (node.nodeType == XML_XMLConstant.TYPE_COMMENT) { tab = makeXMLCommentTab(node); ac.texts.push(currentLineIndent + tab); } } }; for (var i = 0; i < o.length; ++i) { this.DFNodeVisit(o[i], visitor, { depth: 0, texts: texts, lineIndentStack: [''], indent: indent }); } return texts.join(lineBreak); }; /* harmony default export */ const XML_XML = (XML); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSMaker/TemplateXML.js function TemplateXML(props) { this.xml = props.xml; } TemplateXML.prototype._xmlNodeToJSCode = function (node) { var body = []; if (node.nodeType == XML_XMLConstant.TYPE_ELEMENT) { body.push('tag:' + JSON.stringify(node.tagName)); var attributeKeys = Object.keys(node.attributes).filter(function (x) { return x != 'class' && x != 'style' && !x.startsWith('az-') }); if (attributeKeys && attributeKeys.length > 0) { body.push('attr: {' + attributeKeys.map(function (key) { return JSON.stringify(key) + ': ' + TemplateString/* default.parse */.Z.parse(node.attributes[key]).toJSCode(); }).join(', ') + '}'); } if (node.attributes['az-props']) { body.push('props: ' + TemplateString/* default.parse */.Z.parse(node.attributes['az-props']).toJSCode() ); } if (node.attributes['az-data']) { body.push('data: ' + TemplateString/* default.parse */.Z.parse(node.attributes['az-data']).toJSCode() ); } if (node.attributes.style) { var styleSheet = node.attributes.style.split(';').map(function (s) { var t = s.split(':').map(function (text) { return text.trim() }); if (t.length == 2) { return JSON.stringify(t[0]) + ': ' + JSON.stringify(t[1]); } else return false; }).filter(function (e) { return !!e; }); if (styleSheet.length > 0) { body.push('style:{' + styleSheet.join(',') + '}'); } } if (node.attributes.class) { var classList = node.attributes.class.trim().split(/\s+/); if (classList.length > 0) body.push('class:' + JSON.stringify(classList)); } if (node.childNodes && node.childNodes.length > 0) { var childList = '[' + node.childNodes.filter(function (e) { return e.nodeType == XML_XMLConstant.TYPE_ELEMENT || e.nodeType == XML_XMLConstant.TYPE_TEXT; }).map(function (e) { return this._xmlNodeToJSCode(e); }.bind(this)).filter(function (e) { return !!e; }).join(', ') + ']'; if (childList && childList.length > 0) body.push('child: ' + childList); } } else if (node.nodeType == XML_XMLConstant.TYPE_TEXT) { body.push('text: ' + TemplateString/* default.parse */.Z.parse(node.data).toJSCode()); } else return undefined; var res = '{' + body.join(', ') + '}'; return res; }; TemplateXML.prototype.toJSCode = function () { var res = this._xmlNodeToJSCode(this.xml); return res; }; /** * * @param {...any} args * @returns {Function} */ TemplateXML.compileToFunction = function () { var innerCode = 'return ' + this.parse(arguments[arguments.length - 1]).toJSCode() + ';'; var fParam = Array.prototype.slice.call(arguments, 0, arguments.length - 1); fParam.push(innerCode); return Function.apply(null, fParam); }; TemplateXML.parse = function (text) { var xml = XML_XML.parse(text); if (xml) { return new TemplateXML({ xml: xml }); } else return undefined; }; /* harmony default export */ const JSMaker_TemplateXML = (TemplateXML); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var HTML5_Dom = __webpack_require__(6628); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Svg.js var Svg = __webpack_require__(6821); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol/src/Color/Color.js var Color = __webpack_require__(257); // EXTERNAL MODULE: ./node_modules/absol/src/Network/IFrameBridge.js var IFrameBridge = __webpack_require__(3154); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/templates/document.tpl /* harmony default export */ const templates_document = ("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\r\n<w:document\r\n xmlns:w=\"http://schemas.openxmlformats.org/wordprocessingml/2006/main\"\r\n xmlns:m=\"http://schemas.openxmlformats.org/officeDocument/2006/math\"\r\n xmlns:r=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships\"\r\n xmlns:wp=\"http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing\"\r\n xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\"\r\n xmlns:ns6=\"http://schemas.openxmlformats.org/schemaLibrary/2006/main\"\r\n xmlns:c=\"http://schemas.openxmlformats.org/drawingml/2006/chart\"\r\n xmlns:ns8=\"http://schemas.openxmlformats.org/drawingml/2006/chartDrawing\"\r\n xmlns:dgm=\"http://schemas.openxmlformats.org/drawingml/2006/diagram\"\r\n xmlns:pic=\"http://schemas.openxmlformats.org/drawingml/2006/picture\"\r\n xmlns:ns11=\"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing\"\r\n xmlns:dsp=\"http://schemas.microsoft.com/office/drawing/2008/diagram\"\r\n xmlns:ns13=\"urn:schemas-microsoft-com:office:excel\"\r\n xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\n xmlns:v=\"urn:schemas-microsoft-com:vml\"\r\n xmlns:w10=\"urn:schemas-microsoft-com:office:word\"\r\n xmlns:ns17=\"urn:schemas-microsoft-com:office:powerpoint\"\r\n xmlns:odx=\"http://opendope.org/xpaths\"\r\n xmlns:odc=\"http://opendope.org/conditions\"\r\n xmlns:odq=\"http://opendope.org/questions\"\r\n xmlns:odi=\"http://opendope.org/components\"\r\n xmlns:odgm=\"http://opendope.org/SmartArt/DataHierarchy\"\r\n xmlns:ns24=\"http://schemas.openxmlformats.org/officeDocument/2006/bibliography\"\r\n xmlns:ns25=\"http://schemas.openxmlformats.org/drawingml/2006/compatibility\"\r\n xmlns:ns26=\"http://schemas.openxmlformats.org/drawingml/2006/lockedCanvas\">\r\n <w:body>\r\n <w:altChunk r:id=\"htmlChunk\" />\r\n <w:sectPr>\r\n <w:pgSz w:w=\"{{ pageSetting.width }}\" w:h=\"{{ pageSetting.height }}\" w:orient=\"{{ pageSetting.orient }}\" />\r\n <w:pgMar w:top=\"{{ pageSetting.margins.top }}\"\r\n w:right=\"{{ pageSetting.margins.right }}\"\r\n w:bottom=\"{{ pageSetting.margins.bottom }}\"\r\n w:left=\"{{ pageSetting.margins.left }}\"\r\n w:header=\"{{ pageSetting.margins.header }}\"\r\n w:footer=\"{{ pageSetting.margins.footer }}\"\r\n w:gutter=\"{{ pageSetting.margins.gutter }}\"/>\r\n </w:sectPr>\r\n </w:body>\r\n</w:document>\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/templates/mht_document.tpl /* harmony default export */ const mht_document = ("MIME-Version: 1.0\r\nContent-Type: multipart/related;\r\n type=\"text/html\";\r\n boundary=\"----=mhtDocumentPart\"\r\n\r\n\r\n------=mhtDocumentPart\r\nContent-Type: text/html;\r\n charset=\"utf-8\"\r\nContent-Transfer-Encoding: quoted-printable\r\nContent-Location: file:///C:/fake/document.html\r\n\r\n{{ htmlSource }}\r\n\r\n{{ contentParts }}\r\n\r\n------=mhtDocumentPart--\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/templates/mht_part.tpl /* harmony default export */ const mht_part = ("------=mhtDocumentPart\r\nContent-Type: {{ contentType }}\r\nContent-Transfer-Encoding: {{ contentEncoding }}\r\nContent-Location: {{ contentLocation }}\r\n\r\n{{ encodedContent }}\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/DocxTpl.js /* harmony default export */ const DocxTpl = ({ document: new Function('pageSetting', 'return ' + TemplateString/* default.parse */.Z.parse(templates_document).toJSCode()), mht_document: new Function('htmlSource', 'contentParts', 'return ' + TemplateString/* default.parse */.Z.parse(mht_document).toJSCode()), mht_part: new Function('contentType', 'contentEncoding', 'contentLocation', 'encodedContent', 'return ' + TemplateString/* default.parse */.Z.parse(mht_part).toJSCode()) }); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/assets/content_types.xml /* harmony default export */ const content_types = ("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\r\n<Types xmlns=\"http://schemas.openxmlformats.org/package/2006/content-types\">\r\n <Default Extension=\"rels\" ContentType=\r\n \"application/vnd.openxmlformats-package.relationships+xml\" />\r\n <Override PartName=\"/word/document.xml\" ContentType=\r\n \"application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml\"/>\r\n <Override PartName=\"/word/afchunk.mht\" ContentType=\"message/rfc822\"/>\r\n</Types>\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/assets/rels.xml /* harmony default export */ const rels = ("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\r\n<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">\r\n <Relationship\r\n Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\"\r\n Target=\"/word/document.xml\" Id=\"R09c83fafc067488e\" />\r\n</Relationships>\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/assets/document.xml.rels /* harmony default export */ const document_xml = ("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\r\n<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">\r\n <Relationship Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/aFChunk\"\r\n Target=\"/word/afchunk.mht\" Id=\"htmlChunk\" />\r\n</Relationships>\r\n"); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSDocx/JSDocx.js var JSZip = window.JSZip; function JSDocx(props) { if (props.blob) this.blob = props.blob; if (props.blob) this.buffer = props.buffer; } JSDocx.prototype.saveAs = function (fileName) { var src; if (this.blob) { src = (URL || webkitURL).createObjectURL(this.blob); } else if (this.buffer) { src = "data:application/octet-stream," + encodeURIComponent(this.buffer); } var element = document.createElement('a'); element.setAttribute('href', src); element.setAttribute('download', fileName); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); }; JSDocx._prepareImageParts = function (htmlSource) { var imageContentParts = []; var inlinedSrcPattern = /\"data:(\w+\/\w+);(\w+),(\S+)\"/g; var inlinedReplacer = function (match, contentType, contentEncoding, encodedContent) { var index = imageContentParts.length; var extension = contentType.split('/')[1]; var contentLocation = "file:///C:/fake/image" + index + "." + extension; // mht_part: new Function('contentType', 'contentEncoding', 'contentLocation', 'encodedContent', 'return ' + TemplateString.parse(mht_pathTpl).toJSCode()) imageContentParts.push(DocxTpl.mht_part(contentType, contentEncoding, contentLocation, encodedContent)); return "\"" + contentLocation + "\""; }; if (typeof htmlSource === 'string') { if (!/<img/g.test(htmlSource)) { return { htmlSource: htmlSource, imageContentParts: imageContentParts }; } htmlSource = htmlSource.replace(inlinedSrcPattern, inlinedReplacer); return { htmlSource: htmlSource, imageContentParts: imageContentParts }; } else { throw new Error("Not a valid source provided!"); } }; JSDocx._getMHTdocument = function (htmlSource) { var imageContentParts, _ref; _ref = this._prepareImageParts(htmlSource), htmlSource = _ref.htmlSource, imageContentParts = _ref.imageContentParts; htmlSource = htmlSource.replace(/\=/g, '=3D'); return DocxTpl.mht_document(htmlSource, imageContentParts.join('\n') ); }; /** * @param {JSZip} zip */ JSDocx._generateDocument = function (zip) { return zip.generateAsync({ type: 'arraybuffer' }).then(function (buffer) { var props = {}; if (__webpack_require__.g.Blob) props.blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' }); else if (__webpack_require__.g.Buffer) props.buffer = new Buffer(new Uint8Array(buffer)); else throw new Error("Neither Blob nor Buffer are accessible in this environment. " + "Consider adding Blob.js shim"); return new JSDocx(props); }); }; JSDocx._renderDocumentFile = function (pageSetting) { return DocxTpl.document(pageSetting); }; JSDocx._createPageSetting = function (documentOptions) { documentOptions = documentOptions || {}; var pageSetting = { margins: { top: 1440, right: 1440, bottom: 1440, left: 1440, header: 720, footer: 720, gutter: 0 } }; if (documentOptions.orientation == 'landscape') { Object.assign(pageSetting, { height: 12240, width: 15840, orient: 'landscape' }); } else { Object.assign(pageSetting, { width: 12240, height: 15840, orient: 'portrait' }); } if (documentOptions.margins) { Object.assign(pageSetting, documentOptions.margins); } return pageSetting; }; JSDocx._addFiles = function (zip, htmlSource, pageSetting) { zip.file('[Content_Types].xml', content_types); zip.folder('_rels') .file('.rels', rels); zip.folder('word') .file('document.xml', DocxTpl.document(pageSetting)); zip.folder('word') .file('document.xml', JSDocx._renderDocumentFile(pageSetting)) .file('afchunk.mht', JSDocx._getMHTdocument(htmlSource)) .folder('_rels') .file('document.xml.rels', document_xml); return zip; }; JSDocx.fromHTMLCode = function (html, options) { var zip = new JSZip(); JSDocx._addFiles(zip, html, JSDocx._createPageSetting(options)); return JSDocx._generateDocument(zip); }; JSDocx.fromHTMLElement = function (element, options, getOuter, isWorkingElement) { if (typeof element == 'string') { element = HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$(element); } if (!element) throw new Error('@param element must be HTMLElement'); var preRender; if (!isWorkingElement) { preRender = HTML5_Dom/* default.ShareInstance._ */.ZP.ShareInstance._('div'); preRender.addStyle({ position: 'fixed', top: '0', left: '0', zIndex: '-10000', opacity: '0' }).addTo(document.body); Array.prototype.forEach.call(element.childNodes, function (e) { if (e.tagName != 'script') preRender.addChild(e.cloneNode(true)); }); } else { preRender = element; } HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$('script', preRender, function (e) { e.parentElement.removeChild(e); return false; }); var imageTask = []; HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$('img', preRender, function (e) { if (e.src && !e.src.match(/data:/)) { var task = HTML5_Dom/* default.imageToCanvas */.ZP.imageToCanvas(e).then(function (canvas) { var newSrc = canvas.toDataURL(); e.src = newSrc; }); imageTask.push(task); } return false; }); HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$('svg', preRender, function (e) { var task = Svg/* default.svgToCanvas */.ZP.svgToCanvas(e).then(function (canvas) { var newSrc = canvas.toDataURL(); var image = HTML5_Dom/* default.ShareInstance._ */.ZP.ShareInstance._('img'); image.src = newSrc; HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$(e).selfReplace(image); }); imageTask.push(task); return false; }); return Promise.all(imageTask).then(function () { var code; if (getOuter) { code = preRender.outerHTML; if (!code) { var temp = document.createElement('div'); temp.addChild(preRender); code = temp.innerHTML; } } else { code = preRender.innerHTML; } return JSDocx.fromHTMLCode(code, options); }); }; /* harmony default export */ const JSDocx_JSDocx = (JSDocx); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringGenerate.js var stringGenerate = __webpack_require__(1334); ;// CONCATENATED MODULE: ./node_modules/absol/src/Network/Broadcast.js // it can be replace BroadcastChanel function Broadcast(channel, id) { EventEmitter/* default.call */.ZP.call(this); this.channel = channel; this.id = id || (0,stringGenerate.randomIdent)(32); this._ev_message = this._ev_message.bind(this); this._ev_storage = this._ev_storage.bind(this); this._init(); } OOP/* default.mixClass */.ZP.mixClass(Broadcast, EventEmitter/* default */.ZP); Broadcast.prototype._init = function () { if ('BroadcastChannel' in window) { this.nativeBroadcastChannel = new BroadcastChannel(this.channel); this.nativeBroadcastChannel.onmessage = this._ev_message; } else if ('localStorage' in window) { if (!('onstorage' in window)) console.warn("Your browser may not support onstorage event."); if (window.addEventListener) { window.addEventListener('storage', this._ev_storage); } else { window.attachEvent('onstorage', this._ev_storage); } this.storageKey = '_broadcast_' + this.channel; } else { throw new Error("Your browser can not support broadcast!"); } }; Broadcast.prototype._ev_storage = function (event) { if (event.key == this.storageKey) { var data = JSON.parse(event.newValue); if (data.sourceId != this.id) this.handleMessData(data.message); } }; Broadcast.prototype._ev_message = function (event) { var data = event.data; this.handleMessData(data); }; Broadcast.prototype.handleMessData = function (data) { if (data.type == "EMIT") this.fire.apply(this, data.params); if (typeof this.onmessage == 'function') this.onmessage(event); }; /** * @param {...Array<*>} */ Broadcast.prototype.emit = function () { var params = Array.prototype.slice.call(arguments); this.postMessage({ type: "EMIT", params, sourceId: this.id }); }; /** * @param {*} message */ Broadcast.prototype.postMessage = function (message) { if (this.nativeBroadcastChannel) { this.nativeBroadcastChannel.postMessage(message); } else { localStorage.setItem(this.storageKey, JSON.stringify({ message: message, sourceId: this.id })); } }; Broadcast.prototype.onmessage = null; Broadcast.prototype.close = function () { if (this.nativeBroadcastChannel) this.nativeBroadcastChannel.close(); }; /* harmony default export */ const Network_Broadcast = (Broadcast); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Text.js var Text = __webpack_require__(5827); // EXTERNAL MODULE: ./node_modules/absol/src/Converter/file.js var file = __webpack_require__(4574); // EXTERNAL MODULE: ./node_modules/absol/src/Converter/base64.js var base64 = __webpack_require__(9959); ;// CONCATENATED MODULE: ./node_modules/absol/src/Time/Alarm.js /** * * @param {Date| Number} time * @param {Function} callback */ function Alarm(time, callback) { this.LIMIT_TIMEOUT = 2147483647; this.callback = callback; this.state = "STAND_BY"; this.timeout = -1; if (typeof time == 'number') this.time = time; else this.time = time.getTime(); this.args = Array.prototype.slice.call(arguments, 2); this.tick = this.tick.bind(this); if (this.time >= new Date().getTime()) this.start(); else this.kill(); } Alarm.prototype.start = function () { if (this.state == 'STAND_BY' || this.state == "PAUSE") { this.state = "RUNNING"; this.tick(); return true; } return false; }; Alarm.prototype.pause = function () { if (this.state == "RUNNING") { clearTimeout(this.timeout); this.timeout = -1; this.state = 'PAUSE'; } }; Alarm.prototype.tick = function () { var now = new Date().getTime(); if (now >= this.time) { this.callback && this.callback.apply(null, this.args); this.start = 'FINISH'; } else { var deltaTime = Math.min(this.LIMIT_TIMEOUT, this.time - now); this.timeout = setTimeout(this.tick, deltaTime); this.state = "RUNNING"; } } Alarm.prototype.kill = function () { if (this.state != "FINISH" && this.state != "DEAD") { if (this.timeout >= 0) clearTimeout(this.timeout); this.state = 'DEAD'; return true; } return false; }; /* harmony default export */ const Time_Alarm = (Alarm); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Ref.js var Ref = __webpack_require__(4446); // EXTERNAL MODULE: ./node_modules/absol/src/Network/XHR.js var XHR = __webpack_require__(6069); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringFormat.js var stringFormat = __webpack_require__(6382); // EXTERNAL MODULE: ./node_modules/absol/src/JSX/attribute.js + 1 modules var JSX_attribute = __webpack_require__(2953); ;// CONCATENATED MODULE: ./node_modules/absol/src/JSX/dom.js function domVisitor(jsxCode) { var visitor = { File: function (node, ac) { return acept(node.program, ac); }, Program: function (node, ac) { ac.child = node.body.map(function (cNode) { return acept(cNode, {}); }); return ac; }, ExpressionStatement: function (node, ac) { return acept(node.expression, ac); }, JSXElement: function (node, ac) { acept(node.openingElement, ac); if (node.children && node.children.length > 0) { ac.child = node.children.map(function (cNode) { return acept(cNode, {}); }); } return ac; }, JSXOpeningElement: function (node, ac) { var name = {}; acept(node.name, name); ac.tag = name.value; if (node.attributes && node.attributes.length > 0) { node.attributes.forEach(function (aNode) { var attribute = {}; acept(aNode, attribute); if (attribute.key) { if (attribute.key.startsWith('data-')) { ac.data = ac.data || {}; ac.data[attribute.key.replace('data-', '')] = attribute.value; } else if (attribute.key.startsWith('prop-')) { ac.props = ac.props || {}; ac.props[attribute.key.replace('prop-', '')] = attribute.value; } else if (attribute.key.startsWith('on-')) { ac.on = ac.props || {}; ac.on[attribute.key.replace('on-', '')] = attribute.value; } else if (attribute.key == 'style') { ac.style = (0,JSX_attribute.parseStyleAttr)(attribute.value); } else if (attribute.key == 'class') { var classList = (0,JSX_attribute.parseClassAttr)(attribute.value); if (classList.length > 0) ac.class = classList; } else{ ac.attr = ac.attr || {}; ac.attr[attribute.key] = attribute.value; } } }, {}); } return ac; }, JSXIdentifier: function (node, ac) { ac.value = node.name; }, JSXAttribute: function (node, ac) { var key = {}; acept(node.name, key); ac.key = key.value; var value = {}; acept(node.value, value); ac.value = value.value; return ac; }, StringLiteral: function (node, ac) { ac.value = node.value; }, JSXExpressionContainer: function (node, ac) { ac.value = { expression: jsxCode.substring(node.expression.start, node.expression.end) }; return ac; }, JSXText: function (node, ac) { ac.text = node.value return ac; } }; function accept(node, ac) { return node && visitor[node.type] && visitor[node.type](node, ac); } return { acept: accept, accept: accept, visitor: visitor } } /*** * @param {String} jsxCode */ function parseDom(jsxCode) { jsxCode = jsxCode.trim().replace(/>\s+</gm, '><').replace(/<(\/?)(img|input|link|br|meta)([^>]*)>/g, function (sub, end, tag, content) { if (end == '/') return ''; return '<' + tag + content + '/>'; }); var ast = babel.parse( jsxCode, { plugins: [ babel.pluginSyntaxJsx ] }); var xmlData = {}; domVisitor(jsxCode).acept(ast, xmlData); if (xmlData.child.length > 1) return xmlData.child; return xmlData.child[0]; } // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Context.js var Context = __webpack_require__(5721); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/Activity.js //NOTE: !impotant : don't make setter, getter for activity, just code like JAVA /** * @class */ function Activity() { Context/* default.call */.Z.call(this); } Object.defineProperties(Activity.prototype, Object.getOwnPropertyDescriptors(Context/* default.prototype */.Z.prototype)); Activity.prototype.constructor = Activity; Activity.prototype.startActivity = function (activity) { if (this.parent) { this.parent.startActivity(activity); } else { } }; Activity.prototype.finish = function () { if (this.parent) { this.parent.stopActivity(this); } else { } }; /* harmony default export */ const AppPattern_Activity = (Activity); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/ContextManager.js var ContextManager = __webpack_require__(6372); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/Application.js /** * @class */ function Application() { Context/* default.call */.Z.call(this); this.activityStack = []; /** @type {Activity} */ this.currentActivity = null; } Object.defineProperties(Application.prototype, Object.getOwnPropertyDescriptors(Context/* default.prototype */.Z.prototype)); Application.prototype.constructor = Application; /** * @param {Activity} activity */ Application.prototype.startActivity = function (activity) { if (this.currentActivity != null) { this.currentActivity.pause(); this.activityStack.push(this.currentActivity); } this.currentActivity = activity; this.appendChild(activity); activity.attach(this); this.setContentView(activity.getView(), true); activity.start(); }; /** * @param {Activity} activity */ Application.prototype.stopActivity = function (activity) { if (this.currentActivity == activity) { if (this.activityStack.length == 0) { //todo } else { activity.detach(); this.removeChild(this.currentActivity); this.currentActivity = this.activityStack.pop(); this.setContentView(this.currentActivity.getView()); this.currentActivity.resume(); } } else { console.error("NOT ON TOP ACTIVITY"); } }; /** * @param {HTMLElement} view */ Application.prototype.setContentView = function (view, overlay) { throw new Error("Not Implement!"); }; Application.prototype.backToTopActivity = function () { while (this.activityStack.length > 0) { this.currentActivity.stop(); this.currentActivity = this.activityStack.pop(); } this.setContentView(this.currentActivity.getView()); this.currentActivity.resume(); }; /* harmony default export */ const AppPattern_Application = (Application); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/VarScope.js var VarScope = __webpack_require__(1312); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/Fragment.js + 1 modules var Fragment = __webpack_require__(4861); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Rectangle.js var Rectangle = __webpack_require__(2759); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Vec2.js var Vec2 = __webpack_require__(557); // EXTERNAL MODULE: ./node_modules/absol/src/Math/int.js var Math_int = __webpack_require__(7988); ;// CONCATENATED MODULE: ./node_modules/absol/src/Math/Arc.js function Arc(x, y, r, start, end) { this.x = x; this.y = y; this.r = r; this.start = start; this.end = end; } Arc.prototype.isPointInBound = function (p) { if ((0,Math_int.distance)(this.x, this.y, p.x, p.y) > r) return false; return (0,Math_int.radianInRange)(Math.atan2(p.y - this.y, p.x - this.x), start, end); }; Arc.prototype.isRectInBound = function (rect) { return this.isPointInBound(rect.A()) && this.isPointInBound(rect.B()) && this.isPointInBound(rect.C()) && this.isPointInBound(rect.D()); }; Arc.prototype.isRectOutBound = function (rect) { return !this.isPointInBound(rect.A()) && !this.isPointInBound(rect.B()) && !this.isPointInBound(rect.C()) && !this.isPointInBound(rect.D()); }; Arc.prototype.isRectCollapse = function (rect) { return this.isPointInBound(rect.A()) || this.isPointInBound(rect.B()) || this.isPointInBound(rect.C()) || this.isPointInBound(rect.D()); }; Arc.prototype.centerPoint = function () { var mid = (this.start + this.end) / 2; var x = this.x + Math.cos(mid) * this.r * 2 / 3; var y = this.y + Math.sin(mid) * this.r * 2 / 3; return new Vec2/* default */.Z(x, y); }; Arc.prototype.centerRoundPoint = function () { var mid = (this.start + this.end) / 2; var x = this.x + Math.cos(mid) * this.r; var y = this.y + Math.sin(mid) * this.r; return new Vec2/* default */.Z(x, y); }; Arc.make = function (x, y, r, start, end) { return new Arc(x, y, r, start, end); }; /* harmony default export */ const Math_Arc = (Arc); ;// CONCATENATED MODULE: ./node_modules/absol/src/Math/NumRange.js /** * * @param {Number} start * @param {Number} length */ function NumRange(start, length) { if (arguments.length === 1) length = 0; else if (arguments.length === 0) { length = 0; start = 0; } this.start = start; this.length = length; } /** * @param {Number} num */ NumRange.prototype.contains = function (num) { return (num >= this.start) && (num <= this.start + this.length); }; /** * @param {NumRange} other * @returns {NumRange} */ NumRange.prototype.merge = function (other) { var start = Math.min(this.start, other.start); var end = Math.max(this.start + this.length, other.start + other.length); return new NumRange(start, end - start); }; NumRange.prototype.centerValue = function () { return this.start + this.length / 2; }; /** * @param {NumRange} other * @returns {Boolean} */ NumRange.prototype.isCollapse = function (other) { var start = Math.max(this.start, other.start); var end = Math.min(this.start + this.length, other.start + other.length); return start <= end; }; /** * @param {NumRange} other * @returns {NumRange} */ NumRange.prototype.collapsedNumRange = function (other) { var start = Math.max(this.start, other.start); var end = Math.min(this.start + this.length, other.start + other.length); if (start <= end) return new NumRange(start, end - start); return null; }; NumRange.prototype.clone = function () { return new NumRange(this.start, this.length); }; /* harmony default export */ const Math_NumRange = (NumRange); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Clipboard.js var Clipboard = __webpack_require__(5164); // EXTERNAL MODULE: ./node_modules/absol/src/DataStructure/Heap.js var Heap = __webpack_require__(5491); // EXTERNAL MODULE: ./node_modules/absol/src/Time/datetime.js var datetime = __webpack_require__(7807); // EXTERNAL MODULE: ./node_modules/absol/src/AppPattern/CMDRunner.js var CMDRunner = __webpack_require__(2243); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Element.js var Element = __webpack_require__(1487); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElementNS.js var AElementNS = __webpack_require__(2510); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DomSignal.js var DomSignal = __webpack_require__(5150); ;// CONCATENATED MODULE: ./node_modules/absol/src/Cookie/CookieStore.js function CookieStore(converter) { this.converter = converter || base64.UnicodeBase64Converter; } CookieStore.prototype.isEnabled = function () { var cookieEnabled = !!navigator.cookieEnabled; //if not IE4+ nor NS6+ if (typeof navigator.cookieEnabled == "undefined" && !cookieEnabled) { document.cookie = "testcookie_enabled"; cookieEnabled = document.cookie.indexOf("testcookie_enabled") != -1; } return cookieEnabled; }; CookieStore.prototype.secure = function () { document.cookie = "secure"; }; CookieStore.prototype.get = function (key) { var bkey = this.converter.encode(key).replace(/=/g, '_'); var pairs = document.cookie.split(';') .map(function (text) { return text.split('=') }) .filter(function (pair) { return pair[0].trim() == bkey; }); if (pairs.length > 0) { if (pairs[0].length > 1) { var bvalue = pairs[0][1]; return this.converter.decode(bvalue.replace(/_/g, '=').trim()); } else { return true; } } else return undefined; }; CookieStore.prototype.set = function (key, value) { var bkey = this.converter.encode(key); var bvalue = this.converter.encode(value); document.cookie = bkey.replace(/=/g, '_') + "=" + bvalue.replace(/=/g, '_'); }; /* harmony default export */ const Cookie_CookieStore = (new CookieStore()); ;// CONCATENATED MODULE: ./node_modules/absol/src/Cookie/parseCookieString.js /*** * * @param {string} text * @return {{}} */ function parseCookieString(text) { return text.split(/\s*;\s*/).reduce(function (ac, item) { var tokens = item.split('='); var name = (tokens.shift() || '').trim(); if (!name) return ac; var value = (tokens.shift() || '').trim(); if (!value) value = true; ac[name] = value; return ac; }, {}); } // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ResizeSystem.js var HTML5_ResizeSystem = __webpack_require__(6700); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Mat3.js var Mat3 = __webpack_require__(9846); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/LanguageSystem.js var LanguageSystem = __webpack_require__(6013); ;// CONCATENATED MODULE: ./node_modules/absol/src/Code/FlagManager.js /*** * @extends EventEmitter * @constructor */ function FlagManager() { EventEmitter/* default.call */.ZP.call(this); this.flag = {}; this.readSetting(); } OOP/* default.mixClass */.ZP.mixClass(FlagManager, EventEmitter/* default */.ZP); FlagManager.prototype.STORE_KEY = "ABSOL_FLAG" FlagManager.prototype.readSetting = function () { var flagText = localStorage.getItem(this.STORE_KEY) || '{}'; var newFlag = {}; try { newFlag = JSON.parse(flagText); } catch (err) { } this.applyFlag(newFlag); }; FlagManager.prototype.applyFlag = function (newFlag, save) { var changed = []; Object.keys(Object.assign({}, this.flag, newFlag)).forEach(function (key) { if (key in window) { if (key in newFlag) { if (window[key] !== newFlag[key]) { window[key] = newFlag[key]; changed.push(key); } } else { changed.push(key); delete window[key]; } } else { if (key in newFlag) { if (window[key] !== newFlag[key]) { window[key] = newFlag[key]; changed.push(key); } } } }); this.flag = newFlag; if (save) this.saveSetting(); if (changed.length > 0) { this.emit('change', { type: 'change', target: this, keys: changed }) } }; FlagManager.prototype.saveSetting = function () { localStorage.setItem(this.STORE_KEY, JSON.stringify(this.flag)); }; /*** * * @param {string} key * @param {boolean=} value */ FlagManager.prototype.add = function (key, value) { if (!key || (typeof (key) != 'string')) return; if (key in this.flag) return; if (typeof (value) != "boolean") { value = !!window[key]; } this.flag[key] = value; window[key] = value; this.saveSetting(); this.emit('change', { type: 'change', target: this, keys: [key] }); }; FlagManager.prototype.set = function (key, value) { if (!key || (typeof (key) != 'string')) return; if (typeof (value) != "boolean") { value = !!window[key]; } var changed = false; this.flag[key] = value; if (window[key] !== value) { changed = true; } this.saveSetting(); if (changed) { this.emit('change', { type: 'change', target: this, keys: [key] }); } }; FlagManager.prototype.remove = function (key) { if (key in this.flag) { delete window[key]; delete this.flag[key]; this.emit('change', { type: 'change', target: this, keys: [key] }); } }; /* harmony default export */ const Code_FlagManager = (new FlagManager()); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); ;// CONCATENATED MODULE: ./node_modules/absol/src/Code/ALogger.js Code_FlagManager.add('ABSOL_DEBUG', false); function ALogger() { Code_FlagManager.on('change', this._updateProto.bind(this)); this._updateProto(); } ALogger.prototype._updateProto = function () { ['log', 'table', 'table', 'error', 'warn'].forEach(function (name) { var cFunction = window['ABSOL_DEBUG'] ? (console[name] && console[name].bind(console)) : noop/* default */.Z; this[name] = cFunction || noop/* default */.Z; }.bind(this)); }; ALogger.prototype.log = noop/* default */.Z; ALogger.prototype.table = noop/* default */.Z; ALogger.prototype.error = noop/* default */.Z; ALogger.prototype.warn = noop/* default */.Z; (window || __webpack_require__.g).ALogger = new ALogger(); /* harmony default export */ const Code_ALogger = (ALogger); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/ObservableArray.js /*** * @augments EventEmitter * @extends Array * @constructor */ function ObservableArray(array) { EventEmitter/* default.call */.ZP.call(this); Object.defineProperty(this, '_array', { configurable: false, enumerable: false, value: array }); this._makeArrIndex(0, array.length); } Object.defineProperty(ObservableArray.prototype, 'unshift', { enumerable: false, value: function () { var newItems = Array.prototype.slice.call(arguments); var cN = this._array.length; this._makeArrIndex(cN, this._array.length + newItems.length); this._array.unshift.apply(this._array, newItems); this.emit("additem", { target: this, items: newItems, type: 'additem', offset: 0, action: 'unshift' }, this); } }); Object.defineProperty(ObservableArray.prototype, 'shift', { enumerable: false, value: function () { var res = undefined; if (this._array.length > 0) { res = this._array.shift(); this._removeIndex(this._array.length); this.emit("removeitem", { target: this, type: 'additem', offset: 0, action: 'shift', items: [res], item: res }, this); } return res; } }); Object.defineProperty(ObservableArray.prototype, 'push', { enumerable: false, value: function () { var newItems = Array.prototype.slice.call(arguments); var cN = this._array.length; this._makeArrIndex(this._array.length, this._array.length + newItems.length); this._array.push.apply(this._array, newItems); this.emit("additem", { target: this, items: newItems, type: 'additem', offset: cN, action: 'push' }, this); } }); Object.defineProperty(ObservableArray.prototype, 'pop', { enumerable: false, value: function () { var res = undefined; if (this._array.length > 0) { res = this._array.pop(); this._removeIndex(this._array.length); this.emit("removeitem", { target: this, type: 'additem', offset: this._array.length, action: 'shift', items: [res], item: res }, this); } return res; } }); Object.defineProperty(ObservableArray.prototype, 'replace', { enumerable: false, value: function (offset, items) { for (var i = 0; i < items.length && offset < this._array.length; ++i, ++offset) { this._array[offset] = items[i]; } } }); Object.defineProperty(ObservableArray.prototype, 'toJSON', { enumerable: false, value: function () { return this._array; } }); Object.defineProperty(ObservableArray.prototype, 'valueOf', { enumerable: false, value: function () { return this._array; } }); Object.defineProperty(ObservableArray.prototype, '_makeArrIndex', { enumerable: false, value: function (cN, nN) { var i; if (nN > cN) { for (i = cN; i < nN; ++i) this._defineIndex(i); } else { for (i = cN - 1; i >= nN; --i) this._removeIndex(i); } } }); /*** * * @param {number} idx * @private */ Object.defineProperty(ObservableArray.prototype, '_defineIndex', { enumerable: false, value: function (idx) { if (!(idx in this)) { Object.defineProperty(this, idx, { set: function (value) { var oldValue = this._array[idx] this._array[idx] = value; this.emit('setitem', { type: 'setitem', target: this, oldValue: oldValue, vale: value, offset: idx }, this); }, get: function () { return this._array[idx]; }, configurable: true, enumerable: true }); } } }); Object.defineProperty(ObservableArray.prototype, '_removeIndex', { enumerable: false, value: function (idx) { delete this[idx]; } }); Object.defineProperty(ObservableArray.prototype, 'splice', { enumerable: false, value: function (index, howMany) { var res = []; var newItems = Array.prototype.slice.call(arguments, 2); index = index == null ? 0 : index < 0 ? this._array.length + index : index; howMany = howMany == null ? this._array.length - index : howMany > 0 ? howMany : 0; if (howMany > 0) { this._makeArrIndex(this._array.length, this._array.length - howMany); res = this._array.splice(index, howMany); if (newItems.length > 0) { if (res.length > 0) { this.emit('replaceitem', { type: 'replaceitem', offset: index, oldItems: res, newItems: newItems, target: this, action: 'splice' }, this); } else { this.emit('additem', { type: 'additem', offset: index, items: newItems, target: this }, this); } } else { if (res.length > 0) { this.emit('removeitem', { target: this, type: 'additem', offset: 0, action: 'splice', items: res, }, this); } } } return res; } }); Object.defineProperty(ObservableArray.prototype, 'length', { set: function (value) { var n = Number(value); var length = this._array.length; if (n % 1 === 0 && n >= 0) { if (n < length) { this.splice(n); } else if (n > length) { this.push.apply(this, new Array(n - length)); } } else { throw new RangeError("Invalid array length"); } this._array.length = n; }, get: function () { return this._array.length; } }); Object.getOwnPropertyNames(Array.prototype).forEach(function (name) { if (!(name in ObservableArray.prototype)) { Object.defineProperty(ObservableArray.prototype, name, { configurable: false, enumerable: false, writable: false, value: Array.prototype[name] }); } }); Object.getOwnPropertyNames(EventEmitter/* default.prototype */.ZP.prototype).forEach(function (name) { if (!(name in ObservableArray.prototype)) { Object.defineProperty(ObservableArray.prototype, name, { configurable: false, enumerable: false, writable: false, value: EventEmitter/* default.prototype */.ZP.prototype[name] }); } }); /* harmony default export */ const AppPattern_ObservableArray = (ObservableArray); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/ObservableStruct.js /*** * @extends EventEmitter * @param {Object} o * @constructor */ function ObservableStruct(o) { EventEmitter/* default.call */.ZP.call(this); Object.defineProperty(this, '__o__', { configurable: false, enumerable: false, value: o }); for (var key in o) this.defineProperty(key); } Object.defineProperty(ObservableStruct.prototype, 'defineProperty', { configurable: false, enumerable: false, writable: false, /*** * * @param {string} name * @param {*=} value */ value: function (name, value) { if (!(name in this)) { Object.defineProperty(this, name, { set: function (value) { var oldValue = this.__o__[name] this.__o__[name] = value; this.emit('setproperty', { type: 'setproperty', target: this, oldValue: oldValue, vale: value, name: name }, this); }, get: function () { return this.__o__[name]; }, configurable: true, enumerable: true }); } } }); Object.getOwnPropertyNames(EventEmitter/* default.prototype */.ZP.prototype).forEach(function (name) { if (!(name in ObservableStruct.prototype)) { Object.defineProperty(ObservableStruct.prototype, name, { configurable: false, enumerable: false, writable: false, value: EventEmitter/* default.prototype */.ZP.prototype[name] }); } }); /* harmony default export */ const AppPattern_ObservableStruct = (ObservableStruct); // EXTERNAL MODULE: ./node_modules/absol/src/Code/safeThrow.js var safeThrow = __webpack_require__(5650); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/circuit/CCBlock.js /*** * * @param {{id?:string}=} opt * @constructor */ function CCBlock(opt) { opt = opt || {}; this.id = opt.id || (0,stringGenerate.randomIdent)(16); Object.defineProperty(this, '__cc_listener__', { enumerable: false, configurable: true, writable: false, value: {} }); Object.defineProperty(this, '__cc_line_list_by_id__', { enumerable: false, configurable: true, writable: false, value: {} }); } /*** * * @param {string} pinName * @param {function} listener * @return {CCBlock} */ CCBlock.prototype.pinOn = function (pinName, listener) { var cbList; if (this.__cc_listener__[pinName]) { cbList = this.__cc_listener__[pinName]; } else { cbList = []; this.__cc_listener__[pinName] = cbList; } if (cbList.indexOf(listener) < 0) { cbList.push(listener); } else { console.warn("Duplicate pin listener!"); } return this; }; CCBlock.prototype.pinOff = function (pinName, listener) { if (!this.__cc_listener__[pinName]) return this; var cbList = this.__cc_listener__[pinName]; var cbIdx = cbList.indexOf(listener); if (cbIdx >= 0) { cbList.splice(cbIdx); } return this; }; CCBlock.prototype.pinFire = function (pinName) { if (!this.__cc_listener__[pinName]) return this; var cbList = this.__cc_listener__[pinName].slice(); if (cbList.length === 0) return; //avoid call pinGetValue var args = Array.prototype.slice.call(arguments, 1); if (args.length === 0 && this.pinHandlers[pinName] && this.pinHandlers[pinName].get && cbList.length > 0) args.push(this.pinGetValue(pinName)); for (var i = 0; i < cbList.length; ++i) { try { cbList[i].apply(this, args); } catch (e) { (0,safeThrow/* default */.Z)(e); } } }; CCBlock.prototype.pinFireAll = function () { var pinNames = Object.keys(this.pinHandlers); var pinName; for (var i = 0; i < pinNames.length; ++i) { pinName = pinNames[i]; if (this.pinHandlers[pinName] && this.pinHandlers[pinName].get) this.pinFire(pinName); } }; CCBlock.prototype.pinReceives = function (pinName) { var args = Array.prototype.slice.call(arguments, 1); if (this.pinHandlers[pinName] && this.pinHandlers[pinName].receives) { this.pinHandlers[pinName].receives.apply(this, args); } }; CCBlock.prototype.pinGetValue = function (pinName) { var args = Array.prototype.slice.call(arguments, 1); if (this.pinHandlers[pinName] && this.pinHandlers[pinName].get) { return this.pinHandlers[pinName].get.apply(this, args); } return undefined; }; CCBlock.prototype.pinGetDescriptor = function (pinName) { var args = Array.prototype.slice.call(arguments, 1); var descriptor = this.pinHandlers[pinName] && this.pinHandlers[pinName].descriptor; if (descriptor) { if (typeof descriptor === "function") return this.pinHandlers[pinName].get.apply(this, args); return descriptor; } return undefined; }; Object.defineProperty(CCBlock.prototype, 'pinLines', { get: function () { var lineList = this.__cc_line_list_by_id__; return Object.keys(lineList).map(function (id) { return lineList[id]; }); } }); CCBlock.prototype.pinHandlers = {}; /* harmony default export */ const circuit_CCBlock = (CCBlock); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/circuit/CCLine.js /*** * * @param {CCBlock} u * @param {string} uPinName * @param {CCBlock} v * @param {string} vPinName * @param {boolean=} twoWay * @param {{id?:string}=} opt * @constructor */ function CCLine(u, uPinName, v, vPinName, twoWay, opt) { opt = opt || {}; twoWay = !!twoWay; Object.defineProperty(this, 'id', { enumerable: true, writable: false, value: opt.id || (0,stringGenerate.randomIdent)(32) }); Object.defineProperty(this, 'u', { enumerable: true, writable: false, value: u }); Object.defineProperty(this, 'v', { enumerable: true, writable: false, value: v }); Object.defineProperty(this, 'uPinName', { enumerable: true, writable: false, value: uPinName }); Object.defineProperty(this, 'vPinName', { enumerable: true, writable: false, value: vPinName }); Object.defineProperty(this, 'twoWay', { enumerable: true, writable: false, value: twoWay }); this.vToU = this.vToU.bind(this); this.uToV = this.uToV.bind(this); this.u.pinOn(this.uPinName, this.uToV); if (this.twoWay) this.v.pinOn(this.vPinName, this.vToU); this.u.__cc_line_list_by_id__[this.id] = this; this.v.__cc_line_list_by_id__[this.id] = this; } CCLine.prototype.remove = function () { this.u.pinOff(this.uPinName, this.uToV); if (this.twoWay) this.v.pinOff(this.vPinName, this.vToU); delete this.u.__cc_line_list_by_id__[this.id]; delete this.v.__cc_line_list_by_id__[this.id]; }; CCLine.prototype.uToV = function () { var args = [this.vPinName].concat(Array.prototype.slice.call(arguments)); this.v.pinReceives.apply(this.v, args); }; CCLine.prototype.vToU = function () { var args = [this.uPinName].concat(Array.prototype.slice.call(arguments)); this.u.pinReceives.apply(this.u, args); }; /* harmony default export */ const circuit_CCLine = (CCLine); // EXTERNAL MODULE: ./node_modules/absol/src/Network/FileSaver.js var FileSaver = __webpack_require__(5447); // EXTERNAL MODULE: ./node_modules/absol/src/Network/Thread.js + 1 modules var Thread = __webpack_require__(6672); // EXTERNAL MODULE: ./node_modules/absol/src/JSMaker/generator.js var generator = __webpack_require__(2914); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/ShareConfiguration.js /** * * @param {{storageKey: string}} opt * @constructor */ function ShareConfiguration(opt) { this.opt = Object.assign({ storageKey: "AS_SHARE_CONFIGURATION", }, opt); Object.defineProperty(this, 'data', { value: {}, enumerable: true, writable: false }); Object.defineProperty(this, '__listener__', { value: {}, enumerable: false, writable: false }); this.to = -1; this._load(); } ShareConfiguration.prototype.version = 1; ShareConfiguration.prototype._load = function () { var js = localStorage.getItem(this.opt.storageKey); if (!js) return; try { var obj = (new Function('return ' + js))(); if (obj && obj.version === this.version) { Object.assign(this.data, obj.data || {}); } } catch (e) { } }; /*** * * @param {string} key * @param {*|undefined} value * @returns this */ ShareConfiguration.prototype.set = function (key, value) { var prev = this.data[key]; if (value === undefined) { delete this.data[key]; } else { this.data[key] = value; } if (value !== prev) { this.emit(key, value, this); } return this; }; /*** *@returns this */ ShareConfiguration.prototype.save = function () { clearTimeout(this.to); var obj = { data: this.data, version: this.version }; var js = (0,generator/* generateJSVariable */.NQ)(obj); localStorage.setItem(this.opt.storageKey, js); }; /*** *@returns this */ ShareConfiguration.prototype.saveDelay = function () { clearTimeout(this.to); this.to = setTimeout(() => this.save(), 100); }; ShareConfiguration.prototype.emit = function (key) { var args = Array.prototype.slice.call(arguments, 1); var self = this; if (this.__listener__[key]) { this.__listener__[key].slice().forEach(function (f) { try { f.apply(self, args); } catch (err) { (0,safeThrow/* default */.Z)(err); } }); } return this; }; /*** * * @param {string|Object} key * @param {function=}listener * @return {ShareConfiguration} */ ShareConfiguration.prototype.on = function (key, listener) { if (typeof key === "string") { if (!this.__listener__[key]) this.__listener__[key] = []; if (this.__listener__[key].indexOf(listener) < 0) { this.__listener__[key].push(listener); } } else if (typeof key === "object") { for (var key1 in key) { this.on(key1, key[key1]); } } return this; }; /*** * * @param {string|Object} key * @param {function=}listener * @return {ShareConfiguration} */ ShareConfiguration.prototype.off = function (key, listener) { if (typeof key === "string" && this.__listener__[key]) { var idx = this.__listener__[key].indexOf(listener); if (idx >= 0) { this.__listener__[key].splice(idx, 1); } } else if (typeof key === "object") { for (var key1 in key) { this.off(key1, key[key1]); } } return this; }; /*** * * @param {string} key * @param {*=} defaultValue * @return {*} */ ShareConfiguration.prototype.get = function (key, defaultValue) { var value = this.data[key]; if (value === undefined) return defaultValue; return value; }; ShareConfiguration.prototype.contains = function (key) { return this.data[key] !== undefined; }; ShareConfiguration.instance = new ShareConfiguration(); /* harmony default export */ const AppPattern_ShareConfiguration = (ShareConfiguration); // EXTERNAL MODULE: ./node_modules/absol/src/DataStructure/Array.js var DataStructure_Array = __webpack_require__(7835); ;// CONCATENATED MODULE: ./node_modules/absol/src/Network/url.js /*** * * @param {string} current * @param {string} target * @return {string} */ function resolveUrl(current, target) { current = current.trim(); target = target.trim(); if (target.match(/[a-z]+:\/\//)) return target; var origin = current.match(/^[a-z]+:\/\/[a-zA-Z0-9._]+(:[0-9]+)?/); if (origin) origin = origin[0]; var cPath = current.replace(/^[a-z]+:\/\/[a-zA-Z0-9._]+(:[0-9]+)?/, ''); if (target.startsWith('/')) return origin ? origin + target : target; var cParts = cPath.split('/'); cParts.pop(); var tParts = target.split('/'); var t; //todo: normal current while (tParts.length > 0) { t = tParts.shift().trim(); if (t === '..') { cParts.pop(); } else if (t !== '.' && t.length > 0) { cParts.push(t); } } if (origin) { if (cParts[0].length === 0) cParts.shift(); cParts.unshift(origin) } return cParts.join('/'); } ;// CONCATENATED MODULE: ./node_modules/absol/src/Network/remoteRequireNodeAsync.js function remoteRequireNodeAsync(filename, entry) { var moduleCache = {}; var factors = {}; var resources = {}; function getFileName(path) { return path.split('/').pop(); } function getExtension(fileName) { return fileName.split('.').slice(1).pop() || null; } function require(currentLoc, fn) { var fullPath = resolveUrl(currentLoc, fn); if (factors[fullPath + '.js']) fullPath = fullPath + '.js'; var filename = getFileName(fullPath);//__filename var module = moduleCache[fullPath]; if (!module) { if (factors[fullPath]) { module = { 'exports': {} }; moduleCache[fullPath] = module; factors[fullPath](require.bind(null, fullPath), module, module.exports, resolveUrl(fullPath, '.'), filename, window) } else { throw new Error("Could not find module :" + fullPath); } } return module.exports; } function findAllRequire(s) { var regex0 = /[^a-zA-Z_.0-9]require\s*\([^\)]+\)/gm; var regex1 = /require\s*\([^)]+\)/gm; var regex2 = /\([^)]+\)/gm; var es = s.match(regex0); if (!es) return []; return es.map(function (s) { s = s.match(regex1)[0]; s = s.match(regex2)[0]; s = s.replace(/['"()]/gm, ''); if (!getExtension(getFileName(s))) s += '.js'; return s; }); } function fetchResource(fullPath) { if (resources[fullPath]) return Promise.resolve(); var resource = {}; resources[fullPath] = resource; var ext = getExtension(getFileName(fullPath)); resource.sync = fetch(fullPath, { cache: "no-cache" }).then(res => res.text()).then(text => { resource.text = text; switch (ext) { case 'js': factors[fullPath] = new Function('require', 'module', 'exports', '__dir', '__filename', 'global', text) break; case 'json': factors[fullPath] = true; moduleCache[fullPath] = { exports: JSON.parse(text) }; break; default: factors[fullPath] = true; moduleCache[fullPath] = { exports: text }; } var requiredNodes; if (ext === 'js') { requiredNodes = findAllRequire(text); var syncs = requiredNodes.map(ident => fetchResource(resolveUrl(fullPath, ident))); return Promise.all(syncs); } }); return resource.sync; } var absoluteEntry = location.href; function requireCode(filename, entry, fileList) { if (!fileList) fileList = {}; if (!entry) entry = absoluteEntry; var fullPath = resolveUrl(entry, filename); if (fileList[fullPath] === 'pending') { return Promise.resolve(); } else if (fileList[fullPath] !== undefined && fileList[fullPath] !== 'pending') { return Promise.resolve(); } fileList[fullPath] = true; fileList[fullPath] = 'pending'; return fetch(fullPath, { cache: "no-cache" }).then(res => res.text()).then(text => { fileList[fullPath] = text; var requirePath = findAllRequire(text); var waitCode = requirePath.map(function (e) { return requireCode(e, fullPath, fileList); }); return Promise.all(waitCode).then(function () { return fileList; }); }); } if (!entry) entry = absoluteEntry; if (!getExtension(filename)) filename += '.js'; var fullPath = resolveUrl(entry, filename); return fetchResource(fullPath).then(() => { return require('', fullPath); }); } // EXTERNAL MODULE: ./node_modules/absol/src/Math/Polygon.js var Polygon = __webpack_require__(9894); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DynamicCSS.js var HTML5_DynamicCSS = __webpack_require__(488); // EXTERNAL MODULE: ./node_modules/absol/src/Pharse/DPParser.js + 1 modules var DPParser = __webpack_require__(3281); // EXTERNAL MODULE: ./node_modules/absol/src/SCLang/SCGrammar.js var SCGrammar = __webpack_require__(3224); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCParser.js /*** * @type {DPParser} */ var SCParser = new DPParser/* default */.Z(SCGrammar/* default */.Z); /* harmony default export */ const SCLang_SCParser = (SCParser); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCOperatorExecutor.js function OperatorExecutor() { this.oFXYs = {}; this.oFXs = {}; } /*** * * @param {string} operator * @param {function(x, y, next: function):void} fxy */ OperatorExecutor.prototype.addBinaryOperator = function (operator, fxy) { if (!this.oFXYs[operator]) this.oFXYs[operator] = []; this.oFXYs[operator].unshift(fxy); }; /*** * * @param {string} operator * @param {function(x, next: function):void} fx */ OperatorExecutor.prototype.addUnaryOperator = function (operator, fx) { if (!this.oFXs[operator]) this.oFXs[operator] = []; this.oFXs[operator].unshift(fx); }; OperatorExecutor.prototype.executeBinaryOperator = function (operator, x, y) { var fXYs = this.oFXYs[operator]; var i, next; if (fXYs) { i = -1; next = () => { ++i; if (i >= fXYs.length) throw { message: 'Could not match any function for operator' + operator, x: x, y: y }; return fXYs[i](x, y, next); }; return next(); } else { throw { message: 'Could not find operate: ' + operator }; } }; OperatorExecutor.prototype.executeUnaryOperator = function (operator, x) { var fXs = this.oFXs[operator]; var i, next; if (fXs) { i = -1; next = () => { ++i; if (i >= fXs.length) throw { message: 'Could not match any function for operator' + operator, x: x }; return fXs[i](x, next); }; return next(); } else { throw { message: 'Could not find operate: ' + operator }; } }; /*** * @type {OperatorExecutor} */ var SCOperatorExecutor = new OperatorExecutor(); /* harmony default export */ const SCLang_SCOperatorExecutor = (SCOperatorExecutor); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCOperators.js function ADD(a, b) { var type_a = typeof a; var type_b = typeof b; if (type_a === "number") { if (type_b === "number" || type_b === 'string') return a + b; } if (type_a === "undefined" && type_b === "undefined") return undefined; if (type_a === 'string') { if (type_b === "string") return a + b; if (b instanceof Date) return a + (0,datetime.formatDateTime)(b, 'dd/MM/yyyy'); if (type_b === "number") return a + b; } if (a instanceof Date) { if (type_b === 'number') { return new Date(a.getTime() + datetime.MILLIS_PER_DAY * b); } else if (type_b === 'string') { return (0,datetime.formatDateTime)(a, 'dd/MM/yyyy') + b; } } if (a.add && a.constructor === b.constructor) return a.add(b); console.error("Can not add: ", a, b); return NaN; } SCLang_SCOperatorExecutor.addBinaryOperator('+', ADD); function SUB(a, b) { var type_a = typeof a; var type_b = typeof b; if (type_a === "number" && type_b === "number") { return a - b; } if (type_a === "undefined" && type_b === "undefined") return undefined; if (a instanceof Date) { if (type_b === 'number') { return new Date(a.getTime() - datetime.MILLIS_PER_DAY * b); } } if (a.sub && a.constructor === b.constructor) return a.sub(b); console.error("Can not sub: ", a, b); return NaN; } SCLang_SCOperatorExecutor.addBinaryOperator('-', SUB); function MUL(a, b) { var type_a = typeof a; var type_b = typeof b; if (type_a === "number" && type_b === "number") { return a * b; } if (type_a === "undefined" && type_b === "undefined") return undefined; if (type_a === "string" && type_b === "number") { return a.repeat(b); } console.error("Can not mul: ", a, b); return NaN; } SCLang_SCOperatorExecutor.addBinaryOperator('*', MUL); function DIV(a, b) { var type_a = typeof a; var type_b = typeof b; if (type_a === "number" && type_b === "number") { return a / b; } if (type_a === "undefined" && type_b === "undefined") return undefined; console.error("Can not div: ", a, b); return NaN; } SCLang_SCOperatorExecutor.addBinaryOperator('/', DIV); function MOD(x, m) { return x % m; } SCLang_SCOperatorExecutor.addBinaryOperator('%', MOD); function NEGATIVE(x) { return -x; } SCLang_SCOperatorExecutor.addUnaryOperator('-', NEGATIVE); function POSITIVE(x) { return x; } SCLang_SCOperatorExecutor.addUnaryOperator('+', POSITIVE); function NOT(x) { return !x; } SCLang_SCOperatorExecutor.addUnaryOperator('!', NOT); function LESS_THAN(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a < b); } SCLang_SCOperatorExecutor.addBinaryOperator('<', LESS_THAN); function MORE_THAN(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a > b); } SCLang_SCOperatorExecutor.addBinaryOperator('>', MORE_THAN); function EQUAL(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a == b); } SCLang_SCOperatorExecutor.addBinaryOperator('==', EQUAL); function EXTRACT_EQUAL(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a === b); } SCLang_SCOperatorExecutor.addBinaryOperator('===', EXTRACT_EQUAL); function LESS_AND_EQUAL(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a <= b); } SCLang_SCOperatorExecutor.addBinaryOperator('<=', LESS_AND_EQUAL); function MORE_AND_EQUAL(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a >= b); } SCLang_SCOperatorExecutor.addBinaryOperator('>=', MORE_AND_EQUAL); function NOT_EQUAL(a, b) { if (a instanceof Date) a = a.getTime(); if (b instanceof Date) b = b.getTime(); return (a != b); } SCLang_SCOperatorExecutor.addBinaryOperator('!=', NOT_EQUAL); function AND(a, b) { return a && b; } SCLang_SCOperatorExecutor.addBinaryOperator('&&', AND); function OR(a, b) { return a || b; } SCLang_SCOperatorExecutor.addBinaryOperator('||', OR); ;// CONCATENATED MODULE: ./node_modules/absol/src/AppPattern/Const.js /*** * * @param {T} value * @param {*=} type * @constructor * @template T */ function Const(value, type) { this.value = value; this.type = type; } Const.prototype.toString = function () { return this.value + ''; }; /*** * * @return {T} */ Const.prototype.valueOf = function () { return this.value; }; /** * * @return {T} */ Const.prototype.get = function () { return this.value; } /* harmony default export */ const AppPattern_Const = (Const); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCScope.js /*** * * @param {SCScope=} parent * @constructor */ function SCScope(parent) { this.parent = parent; /*** * * @type {Object<string, Ref|Const>} */ this.data = {}; } SCScope.prototype.set = function (name, value) { var ref = this.findRef(name); if (!ref) throw new Error('"' + name + '" was not declared!'); if (ref.set) { ref.set(value); } else { throw new Error('"' + name + '" defined with const cannot be modified!'); } }; SCScope.prototype.get = function (name) { var ref = this.findRef(name); if (!ref) throw new Error('"' + name + '" was not declared!'); return ref.get(); }; SCScope.prototype.declareConst = function (name, value, force, type) { if ((name in this.data) && !force) throw new Error("Cannot redefine variable, " + name + " is already declared!"); this.data[name] = new AppPattern_Const(value, type); }; SCScope.prototype.declareVar = function (name, value, force, type) { if ((name in this.data) && !force) throw new Error("Cannot redefine variable, " + name + " is already declared!"); this.data[name] = new Ref/* default */.Z(value, type); }; SCScope.prototype.revoke = function (name) { delete this.data[name]; }; /*** * * @param {string} name * @return {Ref|Const|null} */ SCScope.prototype.findRef = function (name) { return this.data[name] || (this.parent && this.parent.findRef(name)) || null; }; /*** * * @param {string} name * @return {SCScope|null} */ SCScope.prototype.findScope = function (name) { if (this.data[name]) return this; if (this.parent) return this.parent.findScope(name); return null; }; /** * * @returns {SCScope} */ SCScope.prototype.makeFlattenedScope = function () { var res; if (this.parent) res = this.parent.makeFlattenedScope(); else res = new SCScope(); Object.assign(res.data, this.data); return res; }; /* harmony default export */ const SCLang_SCScope = (SCScope); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCCodeGenerator.js /*** * * @constructor */ function SCCodeGenerator() { } SCCodeGenerator.prototype.accept = function (node) { if (!node) return '/*TODO*/'; var visitor = this.visitors[node.type]; if (visitor) { try { return this.visitors[node.type].apply(this, arguments); } catch (e) { console.error(e, node) } } else { return '[' + node.type + ']'; // throw { message: 'Can not handle ', node: node }; } }; SCCodeGenerator.prototype.generate = function (ast) { return this.accept(ast); }; /*** * * @type {Object<string, function>} */ SCCodeGenerator.prototype.visitors = { Program: function (node) { return node.body.map(st => this.accept(st)).join('\n'); }, FunctionDeclaration: function (node) { var bodyCode = this.accept(node.body); var argsCode = node.params.map(arg => this.accept(arg)).join(', '); return `function ${node.id.name}(${argsCode}) ${bodyCode}`; }, ArgumentDeclaration: function (node) { var res = node.id.name; var typeText; if (node.typeAnnotation) typeText = this.accept(node.typeAnnotation); if (typeText && typeText !== 'any') res += ': ' + typeText; return res; }, TypeAnnotation: function (node) { return this.accept(node.typeAnnotation); }, GenericType: function (node) { var typeText = this.accept(node.id); if (node.typeParameters && node.typeParameters.length > 0) { typeText += '<'; typeText += node.typeParameters.map(it => this.accept(it)).join(', '); typeText += '>'; } return typeText; }, LinkedType: function (node) { return 'linktype ' + this.accept(node.address); }, Identifier: function (node) { return node.name; }, VariableDeclarator: function (node) { var res = node.id.name; var typeText; if (node.typeAnnotation) typeText = this.accept(node.typeAnnotation); if (typeText && typeText !== 'any') res += ': ' + typeText; if (node.init) res += ' = ' + this.accept(node.init); res += ';'; return res; }, VariableDeclaration: function (node) { var res = 'var '; if (node.declarations) { res += node.declarations.map(arg => this.accept(arg)).join(', '); } else { node = Object.assign({}, node); node.type = 'VariableDeclarator'; res += this.accept(node); //adapter for old version } return res; }, BlockStatement: function (node) { var bodyCode = node.body.map(it => this.accept(it)).join('\n'); if (bodyCode.length > 0) { bodyCode = bodyCode.split('\n').map(r => ' ' + r).join('\n'); } return ['{', bodyCode, '}'].join('\n'); }, AssignStatement: function (node) { //@deprecated return this.accept(node.left) + ' = ' + this.accept(node.right) + ';'; }, AssignmentExpression: function (node) { return this.accept(node.left) + ' = ' + this.accept(node.right); }, BooleanLiteral: function (node) { return node.value ? 'true' : 'false'; }, NullLiteral: function (node) { return "null"; }, NewExpression: function (node) { var res = 'new '; if (node.callee.type === 'Identifier' || node.callee.type === 'MemberExpression') { res += this.accept(node.callee); } else { res += '(' + this.accept(node.callee) + ')'; } res += '('; res += node.arguments.map(arg => this.accept(arg)).join(', '); res += ')'; return res; }, CallExpression: function (node) { var res = ''; if (node.callee && (node.callee.type === 'Identifier' || node.callee.type === 'MemberExpression')) { res += this.accept(node.callee); } else { res += '(' + this.accept(node.callee) + ')'; } res += '('; res += node.arguments.map(arg => this.accept(arg)).join(', '); res += ')'; return res; }, MemberExpression: function (node) { var res = ''; if (node.object.type === 'Identifier' || node.object.type === 'MemberExpression') { res += this.accept(node.object); } else { res += '(' + this.accept(node.object) + ')'; } if (node.computed) { res += '['; res += this.accept(node.property); res += ']'; } else { res += '.'; res += this.accept(node.property); } return res; }, IfStatement: function (node) { var res = 'if ('; res += this.accept(node.test); res += ') '; res += this.accept(node.consequent); if (node.alternate) { res += '\nelse '; res += this.accept(node.alternate); } return res; }, WhileStatement: function (node) { var res = 'while ('; res += this.accept(node.test); res += ') '; res += this.accept(node.body); return res; }, ForCountStatement: function (node) { var res = ['for', this.accept(node.for), 'from', this.accept(node.from), 'to', this.accept(node.to)].join(' ') + ' '; res += this.accept(node.body) return res; }, ForOfStatement: function (node) { var res = ['for', this.accept(node.for), 'of', this.accept(node.of)].join(' ') + ' '; res += this.accept(node.body) return res; }, ForInStatement: function (node) { var res = ['for', this.accept(node.for), 'in', this.accept(node.in)].join(' ') + ' '; res += this.accept(node.body); return res; }, BreakStatement: function () { return 'break;'; }, ReturnStatement: function (node) { if (node.argument) return 'return ' + this.accept(node.argument) + ';'; return 'return;'; }, BinaryExpression: function (node) { var callOrderOf = snode => { if (!snode) return 100; if (snode.type === 'BinaryExpression') { return Math.max(SCGrammar/* default.operatorOrder */.Z.operatorOrder[snode.operator.content], callOrderOf(snode.right), callOrderOf(snode.right)); } else if (snode.type === 'UnaryExpression') return -1; else return -2; }; var operatorContent = node.operator.content; var cOrder = SCGrammar/* default.operatorOrder */.Z.operatorOrder[operatorContent]; var left = this.accept(node.left); var right = this.accept(node.right); var leftOrder = callOrderOf(node.left); var rightOrder = callOrderOf(node.right); if (leftOrder > cOrder) left = '(' + left + ')'; if (rightOrder >= cOrder) right = '(' + right + ')'; return [left, operatorContent, right].join(' '); }, UnaryExpression: function (node) { var res = node.operator.content; if (node.argument && node.argument.type === 'BinaryExpression') { res += '(' + this.accept(node.argument) + ')'; } else { res += this.accept(node.argument); } return res; }, ExpressionStatement: function (node) { return this.accept(node.expression) + ';'; }, NumericLiteral: function (node) { if (typeof node.value === "number") return node.value.toString(); return '0'; }, StringLiteral: function (node) { return JSON.stringify(node.value); }, ArrayExpression: function (node) { var res = '['; var elementTexts = node.elements.map(arg => this.accept(arg)); var needWrap = elementTexts.some(et => { return et.length > 60; }); if (needWrap) { res += '\n'; res += elementTexts.join(',\n').split('\n').map(t => ' ' + t).join('\n'); res += '\n'; } else { res += elementTexts.join(', '); } res += ']'; return res; }, ObjectProperty: function (node) { return this.accept(node.key) + ': ' + this.accept(node.value); }, ObjectExpression: function (node) { var res = '{'; var propertyTexts = node.properties.map(arg => this.accept(arg)); var needWrap = propertyTexts.some(et => { return et.length > 60; }); if (needWrap) { res += '\n'; res += propertyTexts.join(',\n').split('\n').map(t => ' ' + t).join('\n'); res += '\n'; } else { res += propertyTexts.join(', '); } res += '}'; return res; }, ConditionalExpression: function (node) { return [this.accept(node.test), '?', this.accept(node.consequent), ':', this.accept(node.alternate)].join(' '); } }; /* harmony default export */ const SCLang_SCCodeGenerator = (SCCodeGenerator); /*** * @extends SCCodeGenerator * @constructor */ function SCCodeHighlightingGenerator() { SCCodeGenerator.apply(this, arguments); } OOP/* default.mixClass */.ZP.mixClass(SCCodeHighlightingGenerator, SCCodeGenerator); SCCodeHighlightingGenerator.prototype.accept = function (node) { if (!node) return '/*TODO*/'; var visitor = this.visitors[node.type]; if (visitor) { try { return `<div class="sclang-node sclang-${node.type}${node.error ? ' sclang-error' : ''}"${node.error ? ('title=' + JSON.stringify(node.error)) : ''}>${this.visitors[node.type].apply(this, arguments)}</div>`; } catch (e) { console.error(e, node) } } else { return '[' + node.type + ']'; // throw { message: 'Can not handle ', node: node }; } }; SCCodeHighlightingGenerator.prototype.visitors = Object.assign({}, SCCodeGenerator.prototype.visitors, { IfStatement: function (node) { var res = '<span class="sclang-keyword">if</span> ('; res += this.accept(node.test); res += ') '; res += this.accept(node.consequent); if (node.alternate) { res += '\n<span class="sclang-keyword">else</span> '; res += this.accept(node.alternate); } return res; }, FunctionDeclaration: function (node) { var bodyCode = this.accept(node.body); var argsCode = node.params.map(arg => this.accept(arg)).join(', '); return `<span class="sclang-keyword">function</span> ${node.id.name}(${argsCode}) ${bodyCode}`; }, ForStatement: function (node) { }, ForCountStatement: function (node) { var res = ['<span class="sclang-keyword">for</span>', this.accept(node.for), '<span class="sclang-keyword">from</span>', this.accept(node.from), '<span class="sclang-keyword">to</span>', this.accept(node.to)].join(' ') + ' '; res += this.accept(node.body) return res; }, ForOfStatement: function (node) { var res = ['<span class="sclang-keyword">for</span>', this.accept(node.for), '<span class="sclang-keyword">of</span>', this.accept(node.of)].join(' ') + ' '; res += this.accept(node.body) return res; }, ForInStatement: function (node) { var res = ['<span class="sclang-keyword">for</span>', this.accept(node.for), '<span class="sclang-keyword">in</span>', this.accept(node.in)].join(' ') + ' '; res += this.accept(node.body) return res; }, VariableDeclarator: function (node) { var res = node.id.name; var typeText; if (node.typeAnnotation) typeText = this.accept(node.typeAnnotation); if (typeText && typeText !== 'any') res += ': ' + typeText; if (node.init) res += ' = ' + this.accept(node.init); return res; }, VariableDeclaration: function (node) { var res = '<span class="sclang-keyword">var</span> '; if (node.declarations) { res += node.declarations.map(arg => this.accept(arg)).join(', '); } else { node = Object.assign({}, node); node.type = 'VariableDeclarator'; res += this.accept(node); //adapter for old version } res += ';'; return res; }, LinkedType: function (node) { return '<span class="sclang-keyword">linktype</span> ' + this.accept(node.address); }, }); SCCodeHighlightingGenerator.prototype.generate = function (ast) { var text = this.accept(ast); return text.split('\n').map(text => { return text.replace(/^\s+/, (full) => { return `<span>${' '.repeat(full.length)}</span>` }); }).join('<br>'); }; function generateSCCode(ast) { var generator = new SCCodeGenerator(); return generator.generate(ast); } function generateSCHighlightPreviewCode(ast) { var generator = new SCCodeHighlightingGenerator(); return generator.generate(ast); } // EXTERNAL MODULE: ./node_modules/absol/src/Converter/ext2MineType.js var ext2MineType = __webpack_require__(9691); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCProgramInstance.js var SCStaticLibScope = new SCLang_SCScope(); var SCDynamicLibScope = new SCLang_SCScope(SCStaticLibScope); function SCProgramInstance(ast, env) { env = env || {}; if (env instanceof SCLang_SCScope) { this.global = env; } else { this.global = new SCLang_SCScope(SCDynamicLibScope); Object.keys(env).forEach(key => { this.global.declareConst(key, env[key]); }); } this.topScope = this.global; this.stack = [{ scope: this.global }]; this.ast = ast; } SCProgramInstance.prototype.exec = function () { return this.accept(this.ast); }; SCProgramInstance.prototype.accept = function (node) { var visitor = this.visitors[node.type]; if (visitor) { return this.visitors[node.type].apply(this, arguments); // try { // // } catch (e) { // console.error(e, node) // } } else { throw this.makeError("NotHandle", 'Can not handle node type ' + node && node.type, node); } }; SCProgramInstance.prototype.makeError = function (type, message, node) { var err = {}; var copy = o => { if (!o) return o; if (o instanceof Array) { return o.map(e => copy(e)); } if (o instanceof Date) return new Date(o.getTime()); if (o.constructor === Object) return Object.keys(o).reduce((ac, key) => { ac[key] = copy(o[key]); return ac; }, o === node ? { error: message || type || true } : {}); return o; } err.ast = copy(this.ast); err.message = message; err.errorNode = node; err._shown = false; Object.defineProperty(err, 'SHOW_ERROR', { enumerable: false, get: function () { if (this._shown) return; this._shown = true; var text = generateSCHighlightPreviewCode(this.ast); var html = `<html><head><title>Error</title> <style> .sclang-Program { font-family: Consolas, serif; white-space: pre-wrap; line-height: 1.5; } .sclang-keyword { color: #2C82FF; } .sclang-node { display: inline; } .sclang-error { animation: 1s linear infinite condemned_blink_effect; } @keyframes condemned_blink_effect { 0% { background-color: transparent; } 50% { background-color: transparent; } 51% { background-color: #f76868; } 100% { background-color: #f76868; } } .sclang-CallExpression > .sclang-MemberExpression:first-child > .sclang-Identifier:last-child, .sclang-CallExpression > .sclang-Identifier:first-child{ color: #41a01b; }</style></head><body>${text}</body></html>` var blob = new Blob([html], { type: ext2MineType/* default.html */.Z.html }); var url = URL.createObjectURL(blob); window.open(url, '_blank'); setTimeout(() => { URL.revokeObjectURL(url); }, 4000); return true; } }) return err; }; SCProgramInstance.prototype.getRefOf = function (name) { return this.topScope.findRef(name); }; SCProgramInstance.prototype.isFunctionReturned = function () { var topStack = this.stack[this.stack.length - 1]; if (topStack.isFunctionReturned) { return topStack.isFunctionReturned(); } return false; }; SCProgramInstance.prototype.functionReturn = function (res) { var topStack = this.stack[this.stack.length - 1]; if (topStack.functionReturn) { return topStack.functionReturn(res); } }; SCProgramInstance.prototype.isLoopBroken = function () { var topStack = this.stack[this.stack.length - 1]; if (topStack.loop && topStack.loop.length > 0) { // console.log(topStack.loop[topStack.loop.length - 1].isBroken()); return topStack.loop[topStack.loop.length - 1].isBroken() } return false; }; SCProgramInstance.prototype.loopPush = function (holder) { var topStack = this.stack[this.stack.length - 1]; topStack.loop = topStack.loop || []; topStack.loop.push(holder); }; SCProgramInstance.prototype.loopPop = function () { var topStack = this.stack[this.stack.length - 1]; topStack.loop.pop(); }; SCProgramInstance.prototype.loopBreak = function () { var topStack = this.stack[this.stack.length - 1]; topStack.loop[topStack.loop.length - 1].break(); } SCProgramInstance.prototype.visitors = { Program: function (node) { var i = 0; var statements = node.body; var returnWith; var res = new Promise(rs => returnWith = rs); var runStep = () => { var statement; var sResult; while (i < statements.length) { statement = statements[i++]; sResult = this.accept(statement); if (sResult && sResult.then) { sResult.then(runStep); return; } } returnWith(0); } runStep(); return res; }, BooleanLiteral: function (node) { return node.value; }, BlockStatement: function (node) { var i = 0; var statements = node.body; var returnWith; var resolved = false; var result = undefined; var sync = new Promise(rs => { returnWith = (res) => { resolved = true; result = res; rs(res); } }); var runStep = () => { var statement; var sResult; while (i < statements.length && !this.isFunctionReturned() && !this.isLoopBroken()) { statement = statements[i++]; sResult = this.accept(statement); if (sResult && sResult.then) { sResult.then(runStep); return; } } returnWith(0); } runStep(); if (resolved) { return this.result; } else return sync; }, ExpressionStatement: function (node) { return this.accept(node.expression); }, VariableDeclarator: function (node, kind) { var initValue = null; if (node.init) { initValue = this.accept(node.init, 'const'); } if (initValue && initValue.then) { return initValue.then((result) => { if (kind === 'const') { this.topScope.declareConst(node.id.name, result); } else { this.topScope.declareVar(node.id.name, result); } }); } else { if (kind === 'const') { this.topScope.declareConst(node.id.name, initValue); } else { this.topScope.declareVar(node.id.name, initValue); } } }, VariableDeclaration: function (node) { var resolved = false; var sync; var resolve; var doStep; var i; var declarations = node.declarations; if (declarations) { i = 0; doStep = () => { var dResult; while (i < declarations.length) { dResult = this.accept(declarations[i++], node.kind); if (dResult && dResult.then) { if (!sync) { sync = new Promise(rs => { resolve = rs; }); } dResult.then(doStep); return; } } if (resolve) resolve(); else resolved = true; } doStep(); if (!resolved) return sync; } else { node = Object.assign({}, node); node.type = 'VariableDeclarator'; return this.accept(node); //adapter for old version } }, ArrayExpression: function (node) { var res = []; var resolved = false; var resolve; var sync = new Promise(rs => { resolve = () => { resolved = true; rs(res); }; }); var elements = node.elements; var i = 0; var doStep = () => { var eResult; while (i < elements.length) { eResult = this.accept(elements[i++], 'const'); if (eResult && eResult.then) { eResult.then((item) => { res.push(item); doStep(); }); return; } else { res.push(eResult); } } resolve(); } doStep(); if (resolved) { return res; } else { return sync; } }, ForCountStatement: function (node) { var idRef = this.accept(node.for, 'ref'); var from = this.accept(node.from, 'const'); var to = this.accept(node.to, 'const'); var result; var resolved = false; var resolveWith; var sync = new Promise(function (rs) { resolveWith = (res) => { result = res; resolved = true; rs(res); } }); var i = from; var runStep = () => { while (i <= to) { idRef.set(i); ++i; var stResult = this.accept(node.body); if (stResult && stResult.then) { stResult.then(runStep); return; } } resolveWith(0); } runStep(); if (resolved) { return result; } else { return sync; } }, WhileStatement: function (node) { var resolved = false; var resolve; var sync = new Promise(rs => { resolve = () => { resolved = true; rs(undefined); }; }); this.loopPush({ break: () => { resolved = true; }, isBroken: () => { return resolved; } }); var state = 0; var doStep = () => { var sResult; while (!resolved) { if (this.isFunctionReturned()) { resolve(); return; } if (state === 0) { sResult = this.accept(node.test, 'const'); state = 1; } else { sResult = this.accept(node.body); state = 0; } if (sResult && (typeof sResult.then === "function")) { sResult.then((sResult) => { if (state === 0 || sResult) { doStep(); } else { resolve(); } }); return; } else { if (state === 1 && !sResult) { resolve(); } } } } doStep(); if (resolved) { this.loopPop(); return undefined; } else { return sync.then(() => this.loopPop()); } }, DoWhileStatement: function (node) { var resolved = false; var resolve; var sync = new Promise(rs => { resolve = () => { resolved = true; rs(undefined); }; }); var state = 1; var doStep = () => { var sResult; while (!resolved) { if (state === 0) { sResult = this.accept(node.test, 'const'); state = 1; } else { sResult = this.accept(node.body); state = 0; } if (sResult && (typeof sResult.then === "function")) { sResult.then((sResult) => { if (state === 0 || sResult) { doStep(); } else { resolve(); } }); return; } else { if (state === 1 && !sResult) { resolve(); } } } } doStep(); if (resolved) { return undefined; } else { return sync; } }, ForOfStatement: function (node) { var valRef = this.accept(node.for, 'ref'); var of = this.accept(node.of, 'const'); var values; var result; var resolved = false; var resolveWith; var sync = new Promise(function (rs) { resolveWith = (res) => { result = res; resolved = true; rs(res); } }); var i = 0; var runStep = () => { while (i < values.length) { valRef.set(values[i]); ++i; var stResult = this.accept(node.body); if (stResult && stResult.then) { stResult.then(runStep); return; } } resolveWith(0); } if (of.then) of.then((value) => { of = value; values = (of instanceof Array) ? of : Object.values(value); runStep(); }); else { values = (of instanceof Array) ? of : Object.values(value); runStep(); } if (resolved) { return result; } else { return sync; } }, ForInStatement: function (node) { var valRef = this.accept(node.for, 'ref'); var inObj = this.accept(node.in, 'const'); var keys; var result; var resolved = false; var resolveWith; var sync = new Promise(function (rs) { resolveWith = (res) => { result = res; resolved = true; rs(res); } }); var i = 0; var runStep = () => { while (i < keys.length) { valRef.set(keys[i]); ++i; var stResult = this.accept(node.body); if (stResult && stResult.then) { stResult.then(runStep); return; } } resolveWith(0); } if (inObj.then) inObj.then((value) => { inObj = value; keys = Object.keys(inObj); runStep(); }); else { keys = Object.keys(inObj) runStep(); } if (resolved) { return result; } else { return sync; } }, AssignStatement: function (node) { //@deprecated var leftRef = this.accept(node.left, 'ref'); var right = this.accept(node.right, 'const'); if (right && right.then) { return right.then(function (value) { leftRef.set(value); return value; }); } else { leftRef.set(right); return right; } }, AssignmentExpression: function (node) { var leftRef = this.accept(node.left, 'ref'); var right = this.accept(node.right, 'const'); if (right && right.then) { return right.then(function (value) { leftRef.set(value); return value; }); } else { leftRef.set(right); return right; } }, IfStatement: function (node) { var test = this.accept(node.test, 'const'); if (test && (typeof test.then === 'function')) { return test.then((test) => { if (test) { return this.accept(node.consequent); } else if (node.alternate) { return this.accept(node.alternate); } }); } else { if (test) { return this.accept(node.consequent); } else if (node.alternate) { return this.accept(node.alternate); } } }, ConditionalExpression: function (node) { var test = this.accept(node.test, 'const'); if (test && (typeof test.then === 'function')) { return test.then((test) => { if (test) { return this.accept(node.consequent); } else { return this.accept(node.alternate); } }); } else { if (test) { return this.accept(node.consequent); } else { return this.accept(node.alternate); } } }, NullLiteral: function (node) { return null; }, NumericLiteral: function (node) { return (node.value); }, StringLiteral: function (node) { return node.value; }, BinaryExpression: function (node) { var op = node.operator.content; var leftValue = this.accept(node.left, 'const'); if (op === '&&' && !leftValue) { return leftValue; } else if (op === '||' && (leftValue && !leftValue.then)) { return leftValue; } var rightValue = this.accept(node.right, 'const'); var sync = []; if (leftValue && leftValue.then) { sync.push(leftValue); leftValue.then(result => leftValue = result); } if (rightValue && rightValue.then) { sync.push(rightValue); rightValue.then(result => rightValue = result); } if (sync.length === 0) { return SCLang_SCOperatorExecutor.executeBinaryOperator(node.operator.content, leftValue, rightValue); } else { return Promise.all(sync).then(u => { return SCLang_SCOperatorExecutor.executeBinaryOperator(node.operator.content, leftValue, rightValue); }); } }, UnaryExpression: function (node) { var arg = this.accept(node.argument, 'const'); if (arg && arg.then) { return arg.then(value => SCLang_SCOperatorExecutor.executeUnaryOperator(node.operator.content, value)); } else { return SCLang_SCOperatorExecutor.executeUnaryOperator(node.operator.content, arg); } }, Identifier: function (node, type) { var ref; if (type === 'const') { ref = this.getRefOf(node.name); if (ref) { return ref.get(); } else { throw this.makeError("NotDeclare", "", node); } } else if (type === 'ref') { ref = this.getRefOf(node.name); if (ref) { return ref; } else { this.makeError("NotDeclare", "", node); } } return node.name; }, CallExpression: function (node) { var calleeFunction; var object = null; var ref; if (node.callee.type === "Identifier") { ref = this.getRefOf(node.callee.name); calleeFunction = ref.get(); } else if (node.callee.type === 'MemberExpression') { ref = this.accept(node.callee); calleeFunction = ref.get(); object = ref.object; } var argumentValues = node.arguments.map((exp) => { return this.accept(exp, 'const'); }); var sync = []; argumentValues.forEach((arg, i) => { if (arg && arg.then) { sync.push(arg.then(result => { argumentValues[i] = result; })); } }); if (sync.length > 0) { return Promise.all(sync).then(() => { if (!calleeFunction) { throw { message: 'Undefined function ' + generateSCCode(node.callee), ast: node } } return calleeFunction.apply(object, argumentValues); }); } else { if (!calleeFunction) { throw { message: 'Undefined function ' + generateSCCode(node.callee), ast: node } } return calleeFunction.apply(object, argumentValues); } }, NewExpression: function (node) { var calleeFunction; var ref; if (node.callee.type === "Identifier") { ref = this.getRefOf(node.callee.name); calleeFunction = ref.get(); } else if (node.callee.type === 'MemberExpression') { ref = this.accept(node.callee); calleeFunction = ref.get(); } var argumentValues = node.arguments.map((exp) => { return this.accept(exp, 'const'); }); var code = `return new clazz(${argumentValues.map((u, i) => `args[${i}]`).join(', ')});`; var f = new Function('clazz', 'args', code); return f(calleeFunction, argumentValues); }, MemberExpression: function (node, type) { var object = this.accept(node.object, 'const'); var key; if (node.property.type === 'Identifier' && !node.computed) { key = node.property.name; } else { key = this.accept(node.property, 'const'); } if (key && key.then) { return key.then(key => { if (!object) { throw { message: 'Can not access ' + JSON.stringify(key) + ' from ' + generateSCCode(node.object) }; } if (type === 'const') return object[key]; return { set: function (value) { return object[key] = value; }, get: function () { return object[key]; }, object: object } }); } else { if (type === 'const') return object[key]; return { set: function (value) { return object[key] = value; }, get: function () { return object[key]; }, object: object } } }, ObjectProperty: function (node) { var res = {}; var key = this.accept(node.key); var value = this.accept(node.value, 'const'); if (value && (typeof value.then === 'function')) { return value.then(value => { res[key] = value; return res; }); } else { res[key] = value; } return res; }, ObjectExpression: function (node) { var res = {}; var resolved = false; var resolve; var sync = new Promise(rs => { resolve = () => { resolved = true; rs(res); } }); var i = 0; var properties = node.properties; var doStep = () => { var pResult; while (i < properties.length) { pResult = this.accept(properties[i++]); if (pResult && (typeof pResult.then === "function")) { pResult.then((pO) => { Object.assign(res, pO); }); return; } else { Object.assign(res, pResult); } } resolve(); }; doStep(); if (resolved) { return res; } else { return sync; } }, FunctionDeclaration: function (node) { var self = this; //todo: overloading var functionName = node.id.name; function f() { var scope = new SCLang_SCScope(self.topScope); var result = undefined; var resolved = false; var functionReturn = (res) => { resolved = true; result = res; } var isFunctionReturned = () => { return resolved; } self.stack.push({ scope: scope, functionReturn: functionReturn, isFunctionReturned: isFunctionReturned }); self.topScope = scope; for (var i = 0; i < node.params.length; ++i) { scope.declareVar(node.params[i].id.name, arguments[i]); } scope.declareVar('arguments', arguments); var res = self.accept(node.body); if (res && (typeof res.then === "function")) { return res.then(res => { if (self.stack[self.stack.length - 1].scope === scope) { self.stack.pop(); self.topScope = self.stack[self.stack.length - 1].scope; return result; } else { throw new Error('EngineError: Bug in stack!'); } }); } else { if (self.stack[self.stack.length - 1].scope === scope) { self.stack.pop(); self.topScope = self.stack[self.stack.length - 1].scope; return result; } else { throw new Error('EngineError: Bug in stack!'); } } } var code = `return function ${functionName}(${node.params.map(pr => pr.id.name || (0,stringGenerate.randomIdent)(5)).join(',')}) { return f.apply(this, arguments); }`; var func = (new Function('f', code))(f); this.topScope.declareVar(functionName, func); return func; }, BreakStatement: function (node) { this.loopBreak(); }, ReturnStatement: function (node) { var res = undefined; if (node.argument) { res = this.accept(node.argument, 'const'); } if (res && res.then) { res.then(res => { this.functionReturn(res); }); } else { this.functionReturn(res); } } }; /* harmony default export */ const SCLang_SCProgramInstance = (SCProgramInstance); // EXTERNAL MODULE: ./node_modules/absol/src/Print/printer.js + 2 modules var Print_printer = __webpack_require__(2691); ;// CONCATENATED MODULE: ./node_modules/absol/src/Math/measurements.js function feetToMeter(ft) { return ft / 3.28084; } function meterToFeet(mt) { return mt * 3.28084; } function meterToInch(mt) { return mt * 39.3701; } function mileToMeter(ml) { return ml * 1609.34; } function meterToMile(ml) { return ml / 1609.34; } function meterToYard(mt) { return mt * 1.09361 } function yardToMeter(yd) { return yd / 1.09361; } /** * dot is same pixel in web * @param p * @returns {number} */ function pointToDot(p) { return p * 72 / 96; } function dotToPoint(d) { return d * 96 / 72; } function pxToCentimeter(px) { } function centimeterToPx(cm) { return meterToInch(cm / 100) * 96; } var PAGE_SIZE_IN_DOT = { a0: [2383.94, 3370.39], a1: [1683.78, 2383.94], a2: [1190.55, 1683.78], a3: [841.89, 1190.55], a4: [595.28, 841.89], a5: [419.53, 595.28], a6: [297.64, 419.53], a7: [209.76, 297.64], a8: [147.4, 209.76], a9: [104.88, 147.4], a10: [73.7, 104.88], b0: [2834.65, 4008.19], b1: [2004.09, 2834.65], b2: [1417.32, 2004.09], b3: [1000.63, 1417.32], b4: [708.66, 1000.63], b5: [498.9, 708.66], b6: [354.33, 498.9], b7: [249.45, 354.33], b8: [175.75, 249.45], b9: [124.72, 175.75], b10: [87.87, 124.72], c0: [2599.37, 3676.54], c1: [1836.85, 2599.37], c2: [1298.27, 1836.85], c3: [918.43, 1298.27], c4: [649.13, 918.43], c5: [459.21, 649.13], c6: [323.15, 459.21], c7: [229.61, 323.15], c8: [161.57, 229.61], c9: [113.39, 161.57], c10: [79.37, 113.39], dl: [311.81, 623.62], letter: [612, 792], "government-letter": [576, 756], legal: [612, 1008], "junior-legal": [576, 360], ledger: [1224, 792], tabloid: [792, 1224], "credit-card": [153, 243] }; var PAGE_SIZE_IN_POINT = Object.keys(PAGE_SIZE_IN_DOT).reduce((ac, key) => { ac[key] = PAGE_SIZE_IN_DOT[key].map(d => dotToPoint(d)); return ac; }, {}); function latLngRectFromCenter(center, distance) { var lat = center.latitude; var lng = center.longitude; var r_earth = 6378; var pi = Math.PI; var northLat = lat + (distance / r_earth) * (180 / pi); var eastLng = lng + (distance / r_earth) * (180 / pi) / Math.cos(lat * pi / 180); var southLat = lat - (distance / r_earth) * (180 / pi); var westLng = lng - (distance / r_earth) * (180 / pi) / Math.cos(lat * pi / 180) return { latitude: { min: Math.min(northLat, southLat), max: Math.max(northLat, southLat) }, longitude: { min: Math.min(eastLng, westLng), max: Math.max(eastLng, westLng) } } } /*** * * @param p0 * @param p1 * @returns {number} in km */ function latLngDistance(p0, p1) { var lat0 = p0.latitude; var lat1 = p1.latitude; var lng0 = p0.longitude; var lng1 = p1.longitude; var toRad = function (value) { return value * Math.PI / 180; }; var R = 6371; var dLat = toRad(lat1 - lat0); var dLng = toRad(lng1 - lng0); lat0 = toRad(lat0); lat1 = toRad(lat1); var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) + Math.sin(dLng / 2) * Math.sin(dLng / 2) * Math.cos(lat0) * Math.cos(lat1); var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); return R * c; } ;// CONCATENATED MODULE: ./node_modules/absol/src/Converter/QRCode.js function QR8bitByte(data) { this.mode = QRMode.MODE_8BIT_BYTE; this.data = data; this.parsedData = []; // Added to support UTF-8 Characters for (var i = 0, l = this.data.length; i < l; i++) { var byteArray = []; var code = this.data.charCodeAt(i); if (code > 0x10000) { byteArray[0] = 0xF0 | ((code & 0x1C0000) >>> 18); byteArray[1] = 0x80 | ((code & 0x3F000) >>> 12); byteArray[2] = 0x80 | ((code & 0xFC0) >>> 6); byteArray[3] = 0x80 | (code & 0x3F); } else if (code > 0x800) { byteArray[0] = 0xE0 | ((code & 0xF000) >>> 12); byteArray[1] = 0x80 | ((code & 0xFC0) >>> 6); byteArray[2] = 0x80 | (code & 0x3F); } else if (code > 0x80) { byteArray[0] = 0xC0 | ((code & 0x7C0) >>> 6); byteArray[1] = 0x80 | (code & 0x3F); } else { byteArray[0] = code; } this.parsedData.push(byteArray); } this.parsedData = Array.prototype.concat.apply([], this.parsedData); if (this.parsedData.length !== this.data.length) { this.parsedData.unshift(191); this.parsedData.unshift(187); this.parsedData.unshift(239); } } QR8bitByte.prototype.getLength = function () { return this.parsedData.length; }; QR8bitByte.prototype.write = function (buffer) { for (var i = 0, l = this.parsedData.length; i < l; i++) { buffer.put(this.parsedData[i], 8); } } function QRCodeModel(typeNumber, errorCorrectLevel) { this.typeNumber = typeNumber; this.errorCorrectLevel = errorCorrectLevel; this.modules = null; this.moduleCount = 0; this.dataCache = null; this.dataList = []; } QRCodeModel.prototype.addData = function (data) { var newData = new QR8bitByte(data); this.dataList.push(newData); this.dataCache = null; }; QRCodeModel.prototype.isDark = function (row, col) { if (row < 0 || this.moduleCount <= row || col < 0 || this.moduleCount <= col) { throw new Error(row + "," + col); } return this.modules[row][col]; }; QRCodeModel.prototype.getModuleCount = function () { return this.moduleCount; }; QRCodeModel.prototype.make = function () { this.makeImpl(false, this.getBestMaskPattern()); }; QRCodeModel.prototype.makeImpl = function (test, maskPattern) { this.moduleCount = this.typeNumber * 4 + 17; this.modules = new Array(this.moduleCount); for (var row = 0; row < this.moduleCount; row++) { this.modules[row] = new Array(this.moduleCount); for (var col = 0; col < this.moduleCount; col++) { this.modules[row][col] = null; } } this.setupPositionProbePattern(0, 0); this.setupPositionProbePattern(this.moduleCount - 7, 0); this.setupPositionProbePattern(0, this.moduleCount - 7); this.setupPositionAdjustPattern(); this.setupTimingPattern(); this.setupTypeInfo(test, maskPattern); if (this.typeNumber >= 7) { this.setupTypeNumber(test); } if (this.dataCache == null) { this.dataCache = QRCodeModel.createData(this.typeNumber, this.errorCorrectLevel, this.dataList); } this.mapData(this.dataCache, maskPattern); }; QRCodeModel.prototype.setupPositionProbePattern = function (row, col) { for (var r = -1; r <= 7; r++) { if (row + r <= -1 || this.moduleCount <= row + r) continue; for (var c = -1; c <= 7; c++) { if (col + c <= -1 || this.moduleCount <= col + c) continue; if ((0 <= r && r <= 6 && (c == 0 || c == 6)) || (0 <= c && c <= 6 && (r == 0 || r == 6)) || (2 <= r && r <= 4 && 2 <= c && c <= 4)) { this.modules[row + r][col + c] = true; } else { this.modules[row + r][col + c] = false; } } } }; QRCodeModel.prototype.getBestMaskPattern = function () { var minLostPoint = 0; var pattern = 0; for (var i = 0; i < 8; i++) { this.makeImpl(true, i); var lostPoint = QRUtil.getLostPoint(this); if (i == 0 || minLostPoint > lostPoint) { minLostPoint = lostPoint; pattern = i; } } return pattern; }; QRCodeModel.prototype.setupTimingPattern = function () { for (var r = 8; r < this.moduleCount - 8; r++) { if (this.modules[r][6] != null) { continue; } this.modules[r][6] = (r % 2 == 0); } for (var c = 8; c < this.moduleCount - 8; c++) { if (this.modules[6][c] != null) { continue; } this.modules[6][c] = (c % 2 == 0); } }; QRCodeModel.prototype.setupPositionAdjustPattern = function () { var pos = QRUtil.getPatternPosition(this.typeNumber); for (var i = 0; i < pos.length; i++) { for (var j = 0; j < pos.length; j++) { var row = pos[i]; var col = pos[j]; if (this.modules[row][col] != null) { continue; } for (var r = -2; r <= 2; r++) { for (var c = -2; c <= 2; c++) { if (r == -2 || r == 2 || c == -2 || c == 2 || (r == 0 && c == 0)) { this.modules[row + r][col + c] = true; } else { this.modules[row + r][col + c] = false; } } } } } }; QRCodeModel.prototype.setupTypeNumber = function (test) { var bits = QRUtil.getBCHTypeNumber(this.typeNumber); for (var i = 0; i < 18; i++) { var mod = (!test && ((bits >> i) & 1) == 1); this.modules[Math.floor(i / 3)][i % 3 + this.moduleCount - 8 - 3] = mod; } for (var i = 0; i < 18; i++) { var mod = (!test && ((bits >> i) & 1) == 1); this.modules[i % 3 + this.moduleCount - 8 - 3][Math.floor(i / 3)] = mod; } }; QRCodeModel.prototype.setupTypeInfo = function (test, maskPattern) { var data = (this.errorCorrectLevel << 3) | maskPattern; var bits = QRUtil.getBCHTypeInfo(data); for (var i = 0; i < 15; i++) { var mod = (!test && ((bits >> i) & 1) == 1); if (i < 6) { this.modules[i][8] = mod; } else if (i < 8) { this.modules[i + 1][8] = mod; } else { this.modules[this.moduleCount - 15 + i][8] = mod; } } for (var i = 0; i < 15; i++) { var mod = (!test && ((bits >> i) & 1) == 1); if (i < 8) { this.modules[8][this.moduleCount - i - 1] = mod; } else if (i < 9) { this.modules[8][15 - i - 1 + 1] = mod; } else { this.modules[8][15 - i - 1] = mod; } } this.modules[this.moduleCount - 8][8] = (!test); }; QRCodeModel.prototype.mapData = function (data, maskPattern) { var inc = -1; var row = this.moduleCount - 1; var bitIndex = 7; var byteIndex = 0; for (var col = this.moduleCount - 1; col > 0; col -= 2) { if (col == 6) col--; while (true) { for (var c = 0; c < 2; c++) { if (this.modules[row][col - c] == null) { var dark = false; if (byteIndex < data.length) { dark = (((data[byteIndex] >>> bitIndex) & 1) == 1); } var mask = QRUtil.getMask(maskPattern, row, col - c); if (mask) { dark = !dark; } this.modules[row][col - c] = dark; bitIndex--; if (bitIndex == -1) { byteIndex++; bitIndex = 7; } } } row += inc; if (row < 0 || this.moduleCount <= row) { row -= inc; inc = -inc; break; } } } }; QRCodeModel.PAD0 = 0xEC; QRCodeModel.PAD1 = 0x11; QRCodeModel.createData = function (typeNumber, errorCorrectLevel, dataList) { var rsBlocks = QRRSBlock.getRSBlocks(typeNumber, errorCorrectLevel); var buffer = new QRBitBuffer(); for (var i = 0; i < dataList.length; i++) { var data = dataList[i]; buffer.put(data.mode, 4); buffer.put(data.getLength(), QRUtil.getLengthInBits(data.mode, typeNumber)); data.write(buffer); } var totalDataCount = 0; for (var i = 0; i < rsBlocks.length; i++) { totalDataCount += rsBlocks[i].dataCount; } if (buffer.getLengthInBits() > totalDataCount * 8) { throw new Error("code length overflow. (" + buffer.getLengthInBits() + ">" + totalDataCount * 8 + ")"); } if (buffer.getLengthInBits() + 4 <= totalDataCount * 8) { buffer.put(0, 4); } while (buffer.getLengthInBits() % 8 != 0) { buffer.putBit(false); } while (true) { if (buffer.getLengthInBits() >= totalDataCount * 8) { break; } buffer.put(QRCodeModel.PAD0, 8); if (buffer.getLengthInBits() >= totalDataCount * 8) { break; } buffer.put(QRCodeModel.PAD1, 8); } return QRCodeModel.createBytes(buffer, rsBlocks); }; QRCodeModel.createBytes = function (buffer, rsBlocks) { var offset = 0; var maxDcCount = 0; var maxEcCount = 0; var dcdata = new Array(rsBlocks.length); var ecdata = new Array(rsBlocks.length); for (var r = 0; r < rsBlocks.length; r++) { var dcCount = rsBlocks[r].dataCount; var ecCount = rsBlocks[r].totalCount - dcCount; maxDcCount = Math.max(maxDcCount, dcCount); maxEcCount = Math.max(maxEcCount, ecCount); dcdata[r] = new Array(dcCount); for (var i = 0; i < dcdata[r].length; i++) { dcdata[r][i] = 0xff & buffer.buffer[i + offset]; } offset += dcCount; var rsPoly = QRUtil.getErrorCorrectPolynomial(ecCount); var rawPoly = new QRPolynomial(dcdata[r], rsPoly.getLength() - 1); var modPoly = rawPoly.mod(rsPoly); ecdata[r] = new Array(rsPoly.getLength() - 1); for (var i = 0; i < ecdata[r].length; i++) { var modIndex = i + modPoly.getLength() - ecdata[r].length; ecdata[r][i] = (modIndex >= 0) ? modPoly.get(modIndex) : 0; } } var totalCodeCount = 0; for (var i = 0; i < rsBlocks.length; i++) { totalCodeCount += rsBlocks[i].totalCount; } var data = new Array(totalCodeCount); var index = 0; for (var i = 0; i < maxDcCount; i++) { for (var r = 0; r < rsBlocks.length; r++) { if (i < dcdata[r].length) { data[index++] = dcdata[r][i]; } } } for (var i = 0; i < maxEcCount; i++) { for (var r = 0; r < rsBlocks.length; r++) { if (i < ecdata[r].length) { data[index++] = ecdata[r][i]; } } } return data; }; var QRMode = { MODE_NUMBER: 1 << 0, MODE_ALPHA_NUM: 1 << 1, MODE_8BIT_BYTE: 1 << 2, MODE_KANJI: 1 << 3 }; var QRErrorCorrectLevel = { L: 1, M: 0, Q: 3, H: 2 }; var QRMaskPattern = { PATTERN000: 0, PATTERN001: 1, PATTERN010: 2, PATTERN011: 3, PATTERN100: 4, PATTERN101: 5, PATTERN110: 6, PATTERN111: 7 }; var QRUtil = { PATTERN_POSITION_TABLE: [[], [6, 18], [6, 22], [6, 26], [6, 30], [6, 34], [6, 22, 38], [6, 24, 42], [6, 26, 46], [6, 28, 50], [6, 30, 54], [6, 32, 58], [6, 34, 62], [6, 26, 46, 66], [6, 26, 48, 70], [6, 26, 50, 74], [6, 30, 54, 78], [6, 30, 56, 82], [6, 30, 58, 86], [6, 34, 62, 90], [6, 28, 50, 72, 94], [6, 26, 50, 74, 98], [6, 30, 54, 78, 102], [6, 28, 54, 80, 106], [6, 32, 58, 84, 110], [6, 30, 58, 86, 114], [6, 34, 62, 90, 118], [6, 26, 50, 74, 98, 122], [6, 30, 54, 78, 102, 126], [6, 26, 52, 78, 104, 130], [6, 30, 56, 82, 108, 134], [6, 34, 60, 86, 112, 138], [6, 30, 58, 86, 114, 142], [6, 34, 62, 90, 118, 146], [6, 30, 54, 78, 102, 126, 150], [6, 24, 50, 76, 102, 128, 154], [6, 28, 54, 80, 106, 132, 158], [6, 32, 58, 84, 110, 136, 162], [6, 26, 54, 82, 110, 138, 166], [6, 30, 58, 86, 114, 142, 170]], G15: (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0), G18: (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0), G15_MASK: (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1), getBCHTypeInfo: function (data) { var d = data << 10; while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15) >= 0) { d ^= (QRUtil.G15 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15))); } return ((data << 10) | d) ^ QRUtil.G15_MASK; }, getBCHTypeNumber: function (data) { var d = data << 12; while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18) >= 0) { d ^= (QRUtil.G18 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18))); } return (data << 12) | d; }, getBCHDigit: function (data) { var digit = 0; while (data != 0) { digit++; data >>>= 1; } return digit; }, getPatternPosition: function (typeNumber) { return QRUtil.PATTERN_POSITION_TABLE[typeNumber - 1]; }, getMask: function (maskPattern, i, j) { switch (maskPattern) { case QRMaskPattern.PATTERN000: return (i + j) % 2 === 0; case QRMaskPattern.PATTERN001: return i % 2 === 0; case QRMaskPattern.PATTERN010: return j % 3 === 0; case QRMaskPattern.PATTERN011: return (i + j) % 3 === 0; case QRMaskPattern.PATTERN100: return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 === 0; case QRMaskPattern.PATTERN101: return (i * j) % 2 + (i * j) % 3 === 0; case QRMaskPattern.PATTERN110: return ((i * j) % 2 + (i * j) % 3) % 2 === 0; case QRMaskPattern.PATTERN111: return ((i * j) % 3 + (i + j) % 2) % 2 === 0; default: throw new Error("bad maskPattern:" + maskPattern); } }, getErrorCorrectPolynomial: function (errorCorrectLength) { var a = new QRPolynomial([1], 0); for (var i = 0; i < errorCorrectLength; i++) { a = a.multiply(new QRPolynomial([1, QRMath.gexp(i)], 0)); } return a; }, getLengthInBits: function (mode, type) { if (1 <= type && type < 10) { switch (mode) { case QRMode.MODE_NUMBER: return 10; case QRMode.MODE_ALPHA_NUM: return 9; case QRMode.MODE_8BIT_BYTE: return 8; case QRMode.MODE_KANJI: return 8; default: throw new Error("mode:" + mode); } } else if (type < 27) { switch (mode) { case QRMode.MODE_NUMBER: return 12; case QRMode.MODE_ALPHA_NUM: return 11; case QRMode.MODE_8BIT_BYTE: return 16; case QRMode.MODE_KANJI: return 10; default: throw new Error("mode:" + mode); } } else if (type < 41) { switch (mode) { case QRMode.MODE_NUMBER: return 14; case QRMode.MODE_ALPHA_NUM: return 13; case QRMode.MODE_8BIT_BYTE: return 16; case QRMode.MODE_KANJI: return 12; default: throw new Error("mode:" + mode); } } else { throw new Error("type:" + type); } }, getLostPoint: function (qrCode) { var moduleCount = qrCode.getModuleCount(); var lostPoint = 0; for (var row = 0; row < moduleCount; row++) { for (var col = 0; col < moduleCount; col++) { var sameCount = 0; var dark = qrCode.isDark(row, col); for (var r = -1; r <= 1; r++) { if (row + r < 0 || moduleCount <= row + r) { continue; } for (var c = -1; c <= 1; c++) { if (col + c < 0 || moduleCount <= col + c) { continue; } if (r == 0 && c == 0) { continue; } if (dark == qrCode.isDark(row + r, col + c)) { sameCount++; } } } if (sameCount > 5) { lostPoint += (3 + sameCount - 5); } } } for (var row = 0; row < moduleCount - 1; row++) { for (var col = 0; col < moduleCount - 1; col++) { var count = 0; if (qrCode.isDark(row, col)) count++; if (qrCode.isDark(row + 1, col)) count++; if (qrCode.isDark(row, col + 1)) count++; if (qrCode.isDark(row + 1, col + 1)) count++; if (count == 0 || count == 4) { lostPoint += 3; } } } for (var row = 0; row < moduleCount; row++) { for (var col = 0; col < moduleCount - 6; col++) { if (qrCode.isDark(row, col) && !qrCode.isDark(row, col + 1) && qrCode.isDark(row, col + 2) && qrCode.isDark(row, col + 3) && qrCode.isDark(row, col + 4) && !qrCode.isDark(row, col + 5) && qrCode.isDark(row, col + 6)) { lostPoint += 40; } } } for (var col = 0; col < moduleCount; col++) { for (var row = 0; row < moduleCount - 6; row++) { if (qrCode.isDark(row, col) && !qrCode.isDark(row + 1, col) && qrCode.isDark(row + 2, col) && qrCode.isDark(row + 3, col) && qrCode.isDark(row + 4, col) && !qrCode.isDark(row + 5, col) && qrCode.isDark(row + 6, col)) { lostPoint += 40; } } } var darkCount = 0; for (var col = 0; col < moduleCount; col++) { for (var row = 0; row < moduleCount; row++) { if (qrCode.isDark(row, col)) { darkCount++; } } } var ratio = Math.abs(100 * darkCount / moduleCount / moduleCount - 50) / 5; lostPoint += ratio * 10; return lostPoint; } }; var QRMath = { glog: function (n) { if (n < 1) { throw new Error("glog(" + n + ")"); } return QRMath.LOG_TABLE[n]; }, gexp: function (n) { while (n < 0) { n += 255; } while (n >= 256) { n -= 255; } return QRMath.EXP_TABLE[n]; }, LOG_TABLE: new Array(256) }; QRMath.EXP_TABLE = (function () { var arr = Array(256); var i; for (i = 0; i < 8; ++i) { arr[i] = (1 << i); } for (i = 8; i < 256; ++i) { arr[i] = (arr[i - 4] ^ arr[i - 5] ^ arr[i - 6] ^ arr[i - 8]); } return arr; })(); QRMath.LOG_TABLE = (function () { var arr = Array(256).fill(0); for (var i = 0; i < 255; i++) { arr[QRMath.EXP_TABLE[i]] = i; } return arr; })(); function QRPolynomial(num, shift) { if (num.length == undefined) { throw new Error(num.length + "/" + shift); } var offset = 0; while (offset < num.length && num[offset] == 0) { offset++; } this.num = new Array(num.length - offset + shift); for (var i = 0; i < num.length - offset; i++) { this.num[i] = num[i + offset]; } } QRPolynomial.prototype.get = function (index) { return this.num[index]; }; QRPolynomial.prototype.getLength = function () { return this.num.length; }; QRPolynomial.prototype.multiply = function (e) { var num = new Array(this.getLength() + e.getLength() - 1); for (var i = 0; i < this.getLength(); i++) { for (var j = 0; j < e.getLength(); j++) { num[i + j] ^= QRMath.gexp(QRMath.glog(this.get(i)) + QRMath.glog(e.get(j))); } } return new QRPolynomial(num, 0); }; QRPolynomial.prototype.mod = function (e) { if (this.getLength() - e.getLength() < 0) { return this; } var ratio = QRMath.glog(this.get(0)) - QRMath.glog(e.get(0)); var num = new Array(this.getLength()); for (var i = 0; i < this.getLength(); i++) { num[i] = this.get(i); } for (var i = 0; i < e.getLength(); i++) { num[i] ^= QRMath.gexp(QRMath.glog(e.get(i)) + ratio); } return new QRPolynomial(num, 0).mod(e); }; function QRRSBlock(totalCount, dataCount) { this.totalCount = totalCount; this.dataCount = dataCount; } QRRSBlock.RS_BLOCK_TABLE = [[1, 26, 19], [1, 26, 16], [1, 26, 13], [1, 26, 9], [1, 44, 34], [1, 44, 28], [1, 44, 22], [1, 44, 16], [1, 70, 55], [1, 70, 44], [2, 35, 17], [2, 35, 13], [1, 100, 80], [2, 50, 32], [2, 50, 24], [4, 25, 9], [1, 134, 108], [2, 67, 43], [2, 33, 15, 2, 34, 16], [2, 33, 11, 2, 34, 12], [2, 86, 68], [4, 43, 27], [4, 43, 19], [4, 43, 15], [2, 98, 78], [4, 49, 31], [2, 32, 14, 4, 33, 15], [4, 39, 13, 1, 40, 14], [2, 121, 97], [2, 60, 38, 2, 61, 39], [4, 40, 18, 2, 41, 19], [4, 40, 14, 2, 41, 15], [2, 146, 116], [3, 58, 36, 2, 59, 37], [4, 36, 16, 4, 37, 17], [4, 36, 12, 4, 37, 13], [2, 86, 68, 2, 87, 69], [4, 69, 43, 1, 70, 44], [6, 43, 19, 2, 44, 20], [6, 43, 15, 2, 44, 16], [4, 101, 81], [1, 80, 50, 4, 81, 51], [4, 50, 22, 4, 51, 23], [3, 36, 12, 8, 37, 13], [2, 116, 92, 2, 117, 93], [6, 58, 36, 2, 59, 37], [4, 46, 20, 6, 47, 21], [7, 42, 14, 4, 43, 15], [4, 133, 107], [8, 59, 37, 1, 60, 38], [8, 44, 20, 4, 45, 21], [12, 33, 11, 4, 34, 12], [3, 145, 115, 1, 146, 116], [4, 64, 40, 5, 65, 41], [11, 36, 16, 5, 37, 17], [11, 36, 12, 5, 37, 13], [5, 109, 87, 1, 110, 88], [5, 65, 41, 5, 66, 42], [5, 54, 24, 7, 55, 25], [11, 36, 12], [5, 122, 98, 1, 123, 99], [7, 73, 45, 3, 74, 46], [15, 43, 19, 2, 44, 20], [3, 45, 15, 13, 46, 16], [1, 135, 107, 5, 136, 108], [10, 74, 46, 1, 75, 47], [1, 50, 22, 15, 51, 23], [2, 42, 14, 17, 43, 15], [5, 150, 120, 1, 151, 121], [9, 69, 43, 4, 70, 44], [17, 50, 22, 1, 51, 23], [2, 42, 14, 19, 43, 15], [3, 141, 113, 4, 142, 114], [3, 70, 44, 11, 71, 45], [17, 47, 21, 4, 48, 22], [9, 39, 13, 16, 40, 14], [3, 135, 107, 5, 136, 108], [3, 67, 41, 13, 68, 42], [15, 54, 24, 5, 55, 25], [15, 43, 15, 10, 44, 16], [4, 144, 116, 4, 145, 117], [17, 68, 42], [17, 50, 22, 6, 51, 23], [19, 46, 16, 6, 47, 17], [2, 139, 111, 7, 140, 112], [17, 74, 46], [7, 54, 24, 16, 55, 25], [34, 37, 13], [4, 151, 121, 5, 152, 122], [4, 75, 47, 14, 76, 48], [11, 54, 24, 14, 55, 25], [16, 45, 15, 14, 46, 16], [6, 147, 117, 4, 148, 118], [6, 73, 45, 14, 74, 46], [11, 54, 24, 16, 55, 25], [30, 46, 16, 2, 47, 17], [8, 132, 106, 4, 133, 107], [8, 75, 47, 13, 76, 48], [7, 54, 24, 22, 55, 25], [22, 45, 15, 13, 46, 16], [10, 142, 114, 2, 143, 115], [19, 74, 46, 4, 75, 47], [28, 50, 22, 6, 51, 23], [33, 46, 16, 4, 47, 17], [8, 152, 122, 4, 153, 123], [22, 73, 45, 3, 74, 46], [8, 53, 23, 26, 54, 24], [12, 45, 15, 28, 46, 16], [3, 147, 117, 10, 148, 118], [3, 73, 45, 23, 74, 46], [4, 54, 24, 31, 55, 25], [11, 45, 15, 31, 46, 16], [7, 146, 116, 7, 147, 117], [21, 73, 45, 7, 74, 46], [1, 53, 23, 37, 54, 24], [19, 45, 15, 26, 46, 16], [5, 145, 115, 10, 146, 116], [19, 75, 47, 10, 76, 48], [15, 54, 24, 25, 55, 25], [23, 45, 15, 25, 46, 16], [13, 145, 115, 3, 146, 116], [2, 74, 46, 29, 75, 47], [42, 54, 24, 1, 55, 25], [23, 45, 15, 28, 46, 16], [17, 145, 115], [10, 74, 46, 23, 75, 47], [10, 54, 24, 35, 55, 25], [19, 45, 15, 35, 46, 16], [17, 145, 115, 1, 146, 116], [14, 74, 46, 21, 75, 47], [29, 54, 24, 19, 55, 25], [11, 45, 15, 46, 46, 16], [13, 145, 115, 6, 146, 116], [14, 74, 46, 23, 75, 47], [44, 54, 24, 7, 55, 25], [59, 46, 16, 1, 47, 17], [12, 151, 121, 7, 152, 122], [12, 75, 47, 26, 76, 48], [39, 54, 24, 14, 55, 25], [22, 45, 15, 41, 46, 16], [6, 151, 121, 14, 152, 122], [6, 75, 47, 34, 76, 48], [46, 54, 24, 10, 55, 25], [2, 45, 15, 64, 46, 16], [17, 152, 122, 4, 153, 123], [29, 74, 46, 14, 75, 47], [49, 54, 24, 10, 55, 25], [24, 45, 15, 46, 46, 16], [4, 152, 122, 18, 153, 123], [13, 74, 46, 32, 75, 47], [48, 54, 24, 14, 55, 25], [42, 45, 15, 32, 46, 16], [20, 147, 117, 4, 148, 118], [40, 75, 47, 7, 76, 48], [43, 54, 24, 22, 55, 25], [10, 45, 15, 67, 46, 16], [19, 148, 118, 6, 149, 119], [18, 75, 47, 31, 76, 48], [34, 54, 24, 34, 55, 25], [20, 45, 15, 61, 46, 16]]; QRRSBlock.getRSBlocks = function (typeNumber, errorCorrectLevel) { var rsBlock = QRRSBlock.getRsBlockTable(typeNumber, errorCorrectLevel); if (rsBlock == undefined) { throw new Error("bad rs block @ typeNumber:" + typeNumber + "/errorCorrectLevel:" + errorCorrectLevel); } var length = rsBlock.length / 3; var list = []; for (var i = 0; i < length; i++) { var count = rsBlock[i * 3 + 0]; var totalCount = rsBlock[i * 3 + 1]; var dataCount = rsBlock[i * 3 + 2]; for (var j = 0; j < count; j++) { list.push(new QRRSBlock(totalCount, dataCount)); } } return list; }; QRRSBlock.getRsBlockTable = function (typeNumber, errorCorrectLevel) { switch (errorCorrectLevel) { case QRErrorCorrectLevel.L: return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 0]; case QRErrorCorrectLevel.M: return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 1]; case QRErrorCorrectLevel.Q: return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 2]; case QRErrorCorrectLevel.H: return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 3]; default: return undefined; } }; function QRBitBuffer() { this.buffer = []; this.length = 0; } QRBitBuffer.prototype.get = function (index) { var bufIndex = Math.floor(index / 8); return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1) === 1; }; QRBitBuffer.prototype.put = function (num, length) { for (var i = 0; i < length; i++) { this.putBit(((num >>> (length - i - 1)) & 1) === 1); } }; QRBitBuffer.prototype.getLengthInBits = function () { return this.length; }; QRBitBuffer.prototype.putBit = function (bit) { var bufIndex = Math.floor(this.length / 8); if (this.buffer.length <= bufIndex) { this.buffer.push(0); } if (bit) { this.buffer[bufIndex] |= (0x80 >>> (this.length % 8)); } this.length++; }; var QRCodeLimitLength = [[17, 14, 11, 7], [32, 26, 20, 14], [53, 42, 32, 24], [78, 62, 46, 34], [106, 84, 60, 44], [134, 106, 74, 58], [154, 122, 86, 64], [192, 152, 108, 84], [230, 180, 130, 98], [271, 213, 151, 119], [321, 251, 177, 137], [367, 287, 203, 155], [425, 331, 241, 177], [458, 362, 258, 194], [520, 412, 292, 220], [586, 450, 322, 250], [644, 504, 364, 280], [718, 560, 394, 310], [792, 624, 442, 338], [858, 666, 482, 382], [929, 711, 509, 403], [1003, 779, 565, 439], [1091, 857, 611, 461], [1171, 911, 661, 511], [1273, 997, 715, 535], [1367, 1059, 751, 593], [1465, 1125, 805, 625], [1528, 1190, 868, 658], [1628, 1264, 908, 698], [1732, 1370, 982, 742], [1840, 1452, 1030, 790], [1952, 1538, 1112, 842], [2068, 1628, 1168, 898], [2188, 1722, 1228, 958], [2303, 1809, 1283, 983], [2431, 1911, 1351, 1051], [2563, 1989, 1423, 1093], [2699, 2099, 1499, 1139], [2809, 2213, 1579, 1219], [2953, 2331, 1663, 1273]]; /** * Get the type by string length * * @private * @param {String} sText * @param {Number} nCorrectLevel * @return {Number} type */ function _getTypeNumber(sText, nCorrectLevel) { var nType = 1; var length = _getUTF8Length(sText); for (var i = 0, len = QRCodeLimitLength.length; i <= len; i++) { var nLimit = 0; switch (nCorrectLevel) { case QRErrorCorrectLevel.L : nLimit = QRCodeLimitLength[i][0]; break; case QRErrorCorrectLevel.M : nLimit = QRCodeLimitLength[i][1]; break; case QRErrorCorrectLevel.Q : nLimit = QRCodeLimitLength[i][2]; break; case QRErrorCorrectLevel.H : nLimit = QRCodeLimitLength[i][3]; break; } if (length <= nLimit) { break; } else { nType++; } } if (nType > QRCodeLimitLength.length) { throw new Error("Too long data"); } return nType; } function _getUTF8Length(sText) { var replacedText = encodeURI(sText).toString().replace(/\%[0-9a-fA-F]{2}/g, 'a'); return replacedText.length + (replacedText.length != sText ? 3 : 0); } function QRCode(opt) { this.opt = { width: 255, height: 255, typeNumber: 4, correctLevel: QRErrorCorrectLevel.H }; if (typeof opt === 'string') { this.opt.text = opt; } else Object.assign(this.opt, opt); if (this.opt.text) { this.makeCode(this.opt.text); } } /** * Make the QRCode * * @param {String} sText link data */ QRCode.prototype.makeCode = function (sText) { this._oQRCode = new QRCodeModel(_getTypeNumber(sText, this.opt.correctLevel), this.opt.correctLevel); this._oQRCode.addData(sText); this._oQRCode.make(); }; QRCode.prototype.getBitmap = function () { var n = this._oQRCode.getModuleCount(); return Array(n).fill(null).map((u, i) => Array(n).fill(null).map((u, j) => this._oQRCode.isDark(i, j))); }; /** * @name QRCode.CorrectLevel */ QRCode.CorrectLevel = QRErrorCorrectLevel; /* harmony default export */ const Converter_QRCode = (QRCode); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DelaySignal.js var DelaySignal = __webpack_require__(8098); ;// CONCATENATED MODULE: ./node_modules/absol/src/Math/BezierCurve.js /** * * @param {Vec2} startPoint * @param {Vec2} ctrlPoint1 * @param {Vec2} ctrlPoint2 * @param {Vec2} endPoint * @constructor */ function BezierCurve(startPoint, ctrlPoint1, ctrlPoint2, endPoint) { this.startPoint = startPoint; this.ctrlPoint1 = ctrlPoint1; this.ctrlPoint2 = ctrlPoint2; this.endPoint = endPoint; } /** * * @param {number} t */ BezierCurve.prototype.pointAt = function (t) { var s1 = this.ctrlPoint1.sub(this.startPoint).mult(t).add(this.startPoint); var s2 = this.ctrlPoint2.sub(this.ctrlPoint1).mult(t).add(this.ctrlPoint1); var s3 = this.endPoint.sub(this.ctrlPoint2).mult(t).add(this.ctrlPoint2); var s4 = s2.sub(s1).mult(t).add(s1); var s5 = s3.sub(s2).mult(t).add(s2); return s5.sub(s4).mult(t).add(s4); }; /** * * @param {Vec2} point * @returns {number} */ BezierCurve.prototype.nearestBzParamToPoint = function (point) { var low = 0; var high = 1; var ml; var mh; var delta = 0.00001; while (high - low > delta) { ml = low + (high - low) / 3; mh = high - (high - low) / 3; if (this.pointAt(ml).dist(point) < this.pointAt(mh).dist(point)) { high = mh; } else { low = ml; } } return (low + high) / 2; }; /** * * @param {Vec2} point * @returns {*} */ BezierCurve.prototype.distanceToPoint = function (point) { return this.pointAt(this.nearestBzParamToPoint(point)).dist(point); }; /** * * @param {BezierCurve} otherCurve * @returns {{current: number, other: number}} */ BezierCurve.prototype.nearestBParamToOtherBzCurve = function (otherCurve) { var res = { current: 0, other: 0 }; var delta = 0.00001; var low = 0; var high = 1; var ml; var mh; var currentPointL, currentPointH; while (high - low > delta) { ml = low + (high - low) / 3; mh = high - (high - low) / 3; currentPointL = this.pointAt(ml); currentPointH = this.pointAt(mh); if (otherCurve.distanceToPoint(currentPointL) < otherCurve.distanceToPoint(currentPointH)) { high = mh; } else { low = ml; } } res.current = (low + high) / 2; currentPointL = this.pointAt(res.current); res.other = otherCurve.nearestBzParamToPoint(currentPointL); return res; }; /** * @returns {BezierCurve} */ BezierCurve.prototype.copy = function () { return new BezierCurve(this.startPoint.copy(), this.ctrlPoint1.copy(), this.ctrlPoint2.copy(), this.endPoint.copy()); }; /* harmony default export */ const Math_BezierCurve = (BezierCurve); ;// CONCATENATED MODULE: ./node_modules/absol/src/SCLang/SCCodeValidation.js /** * @typedef {Object} SCCodeValidationOption * @property {string} target - default: "program" * @variables {string[]} variables * */ /** * * @param {string} source * @param {SCCodeValidationOption} opt * @constructor */ function SCCodeValidation(source, opt) { this.source = source; this.opt = opt || {}; this.error = null; this.parsed = null; this.usedGlobalVariables = []; this.glolbalScope = new VarScope/* default */.Z(); this.topScope = new VarScope/* default */.Z(this.glolbalScope); console.log(this.topScope) this.stack = [ { scope: this.glolbalScope, }, { scope: this.topScope, } ]; this.execute(); } SCCodeValidation.prototype.execute = function () { this.parsed = SCLang_SCParser.parse(this.source, this.opt.target || 'program'); this.calcErrorMessages(); if (!this.parsed.error) { this.accept(this.parsed.ast); this.calcNameError(); } }; SCCodeValidation.prototype.accept = function (node) { var visitor = this.visitors[node.type]; if (visitor) { return this.visitors[node.type].apply(this, arguments); // try { // // } catch (e) { // console.error(e, node) // } } else { // throw this.makeError("NotHandle", 'Can not handle node type ' + node && node.type, node); } }; SCCodeValidation.prototype.visitors = { Program: function (nd) { var i = 0; var statements = nd.body; while (i < statements.length) { this.accept(statements[i]); i++; } }, BlockStatement: function (nd) { var i = 0; var statements = nd.body; while (i < statements.length) { this.accept(statements[i]); i++; } }, ExpressionStatement: function (nd) { this.accept(nd.expression); }, VariableDeclarator: function (nd) { var name = this.accept(nd.id); this.topScope.declare(name, null, true); if (nd.init) this.accept(nd.init, 'get_var'); }, VariableDeclaration: function (nd) { if (nd.declarations) nd.declarations.forEach(it => { this.accept(it); }) }, ArrayExpression: function (nd) { nd.elements.forEach(it => { this.accept(it); }); }, ForCountStatement: function (nd) { this.accept(nd.from, 'get_var'); this.accept(nd.to, 'get_var'); this.accept(nd.for, 'get_var'); this.accept(nd.body); }, WhileStatement: function (nd) { this.accept(nd.test, 'get_var'); this.accept(nd.body); }, DoWhileStatement: function (nd) { this.accept(nd.test, 'get_var'); this.accept(nd.body); }, ForOfStatement: function (nd) { this.accept(nd.for, 'get_var'); this.accept(nd.of, 'get_var'); this.accept(nd.body); }, ForInStatement: function (nd) { this.accept(nd.for, 'get_var'); this.accept(nd.in, 'get_var'); this.accept(nd.body); }, AssignmentExpression: function (nd) { this.accept(nd.left, 'get_var'); this.accept(nd.right, 'get_var'); }, IfStatement: function (nd) { this.accept(nd.test, 'get_var'); this.accept(nd.consequent); if (nd.alternate) { this.accept(nd.alternate); } }, ConditionalExpression: function (nd) { this.accept(nd.test, 'get_var'); this.accept(nd.consequent); this.accept(nd.alternate); }, BinaryExpression: function (nd) { this.accept(nd.left, 'get_var'); this.accept(nd.right, 'get_var'); }, UnaryExpression: function (nd) { this.accept(nd.argument, 'get_var'); }, CallExpression: function (nd) { this.accept(nd.callee, 'get_var'); nd.arguments.forEach(it => { this.accept(it, 'get_var'); }); }, FunctionDeclaration: function (nd) { }, NewExpression: function (nd) { this.accept(nd.callee, 'get_var'); nd.arguments.forEach(it => { this.accept(it, 'get_var'); }); }, ObjectProperty: function (nd) { this.accept(nd.value, 'get_var'); }, ObjectExpression: function (nd) { nd.properties.forEach(it => { this.accept(it, 'get_var'); }) }, /** * @this {SCCodeValidation} * @param nd */ MemberExpression: function (nd) { this.accept(nd.object, 'get_var'); if (nd.computed) { this.accept(nd.property, 'get_var'); } }, ReturnStatement: function (nd){ this.accept(nd.argument, 'get_var'); }, Identifier: function (nd, type) { var name = nd.name; var scope; if (type === 'get_var') { scope = this.topScope.findScope(name); if (!scope) { this.glolbalScope.declare(name, null, true); } } return name; }, } SCCodeValidation.prototype.calcErrorMessages = function () { var rawError = this.parsed.error; var ist = this.parsed; var rows; var errorText = ''; var error = ist.error; var token, charIdx, rowIdx; if (rawError) { rows = this.source.split('\n'); switch (error.type) { case 'unexpected': errorText = `<span style="color:red;">${error.message}</span>`; token = ist.tokens[error.tokenIdx]; charIdx = token.start; rowIdx = 0; while (rowIdx < rows.length) { if (charIdx <= rows[rowIdx].length) { errorText = `<strong>Line ${rowIdx + 1}:</strong> ` + errorText errorText += '<br>'; errorText += `<div style="color:blue; white-space: pre-wrap; font-family: Consolas, serif;">${rows[rowIdx]}</div>`; errorText += `<div style=" --text-color:red; white-space: pre-wrap; font-family: Consolas, serif;" class="as-blink-text">${' '.repeat(charIdx)}^</div>`; break; } charIdx -= rows[rowIdx].length + 1;//by \n rowIdx++; } break; default: errorText = `<span style="color:red">${error.message}</span>`; break; } this.error = { type: 'syntax', message: rawError.message, htmlMessage: errorText }; } }; SCCodeValidation.prototype.calcNameError = function (){ var variables = this.opt.variables || []; var variableDict = variables.reduce((ac, cr)=>{ ac[cr] = true; return ac; }, {}); var undefinedVariables = Object.keys(this.glolbalScope.data).filter(name=> !variableDict[name]); if (undefinedVariables.length > 0){ this.error = { type: 'name', message: 'Undefined variables: ' + undefinedVariables.join(', '), htmlMessage: `<span style="color:red;">Undefined variables: ${undefinedVariables.join(', ')}</span>` } } }; /* harmony default export */ const SCLang_SCCodeValidation = ((/* unused pure expression or super */ null && (SCCodeValidation))); function validateSCCode(code, opt) { return new SCCodeValidation(code, opt); } /* var d = absol.sclang.validateSCCode(` var name = nd.name; var scope; var a; a = b; var m = {a: a, b: b, d: d}; if (type === 'get_var') { x = y; scope = this.topScope.findScope(nd.object); if (!scope) { this.glolbalScope.declare(name, null, true); } } z = Math.max(x,y, scope[a]); return name;`, {variables: ['Math', 'Date', 'x','this']}); if (d.error) { console.log(d.error); var div = document.createElement('div'); setTimeout(() => { document.body.appendChild(div); div.innerHTML = d.error.htmlMessage; }, 100) } */ ;// CONCATENATED MODULE: ./node_modules/absol/src/index.js var src_absol = { int: Math_int, array: DataStructure_Array, safeThrow: safeThrow/* default */.Z, Rectangle: Rectangle/* default */.Z, BezierCurve: Math_BezierCurve, ResizeSystem: HTML5_ResizeSystem/* default */.Z, Arc: Math_Arc, Polygon: Polygon/* default */.Z, NumRange: Math_NumRange, CookieStore: Cookie_CookieStore, parseCookieString: parseCookieString, CMDRunner: CMDRunner/* default */.Z, ContextManager: ContextManager/* default */.Z, Application: AppPattern_Application, Fragment: Fragment/* default */.Z, VarScope: VarScope/* default */.Z, Context: Context/* default */.Z, Activity: AppPattern_Activity, Element: Element/* default */.Z, ElementNS: AElementNS/* default */.Z, AElement: Element/* default */.Z, AElementNS: AElementNS/* default */.Z, DomSignal: DomSignal/* default */.ZP, DelaySignal: DelaySignal/* default */.Z, JSPath: JSPath/* default */.Z, TemplateString: TemplateString/* default */.Z, TemplateXML: JSMaker_TemplateXML, Dom: HTML5_Dom/* default */.ZP, Svg: Svg/* default */.ZP, BrowserDetector: BrowserDetector/* default */.Z, OOP: OOP/* default */.ZP, XML: XML_XML, Color: Color/* default */.Z, EventEmitter: EventEmitter/* default */.ZP, JSZip: window.JSZip, IFrameBridge: IFrameBridge/* default */.Z, JSDocx: JSDocx_JSDocx, Broadcast: Network_Broadcast, text: Text, file: file, base64: base64, Alarm: Time_Alarm, coreDom: HTML5_Dom/* default.ShareInstance */.ZP.ShareInstance, coreSvg: Svg/* default.ShareInstance */.ZP.ShareInstance, require: function (tagName) { return this.coreDom.require(tagName) || this.coreSvg.require(tagName); }, domCreator: HTML5_Dom/* default.ShareInstance.creator */.ZP.ShareInstance.creator, svgCreator: HTML5_Dom/* default.ShareInstance.creator */.ZP.ShareInstance.creator, _: HTML5_Dom/* default.ShareInstance._ */.ZP.ShareInstance._, $: HTML5_Dom/* default.ShareInstance.$ */.ZP.ShareInstance.$, $$: HTML5_Dom/* default.ShareInstance.$$ */.ZP.ShareInstance.$$, _svg: Svg/* default.ShareInstance._ */.ZP.ShareInstance._, $svg: Svg/* default.ShareInstance.$ */.ZP.ShareInstance.$, Ref: Ref/* default */.Z, Const: AppPattern_Const, XHR: XHR/* default */.Z, string: Object.assign({}, stringFormat, stringGenerate), jsx: { dom: dom_namespaceObject, attribute: JSX_attribute }, QRCode:Converter_QRCode, clipboard: Clipboard, dataStructure: { Heap: Heap/* default */.ZP }, datetime: datetime, Vec2: Vec2/* default */.Z, Mat3: Mat3/* default */.Z, LanguageSystem: LanguageSystem/* default */.ZP, ALogger: Code_ALogger, FlagManager: Code_FlagManager, ObservableArray: AppPattern_ObservableArray, ObservableStruct: AppPattern_ObservableStruct, circuit: { CCBlock: circuit_CCBlock, CCLine: circuit_CCLine }, FileSaver: FileSaver, Thread: Thread/* default */.Z, setDomImmediate: DomSignal/* setDomImmediate */.J6, clearDomImmediate: DomSignal/* clearDomImmediate */.fi, generateJSVariable: generator/* generateJSVariable */.NQ, copyJSVariable: generator/* copyJSVariable */.Ew, normalizeIdent: stringFormat.normalizeIdent, replaceDateStringJSVariable: generator/* replaceDateStringJSVariable */.wP, remoteNodeRequireAsync: remoteRequireNodeAsync, shareConfiguration: AppPattern_ShareConfiguration.instance, DynamicCSS: HTML5_DynamicCSS/* default */.Z, getSystemFontSize: HTML5_Dom/* getSystemFontSize */.Z4, sclang:{ 'SCParser': SCLang_SCParser, 'SCProgramInstance': SCLang_SCProgramInstance, 'SCOperatorExecutor': SCLang_SCOperatorExecutor, 'SCStaticLibScope':SCStaticLibScope, 'SCDynamicLibScope': SCDynamicLibScope, 'SCScope': SCLang_SCScope, 'SCCodeGenerator': SCLang_SCCodeGenerator, 'generateSCCode': generateSCCode, 'generateSCHighlightPreviewCode': generateSCHighlightPreviewCode, 'validateSCCode': validateSCCode }, printer: Print_printer, measurements: measurements_namespaceObject }; /* harmony default export */ const src = (src_absol); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElement.js var AElement = __webpack_require__(7951); ;// CONCATENATED MODULE: ./node_modules/absol/src/absol.js //for old plugin src['HTML'+'El'+'ement'.toLowerCase()] = src.Element; src.dom = src.Dom; src.event = src.EventEmitter; src.Event = src.EventEmitter; src.color = src.Color; src.documentReady = src.Dom.documentReady; window.AComp = src.AComp; window.PhotoSwipeViewer = src.PhotoSwipeViewer; window.IFrameBridge = src.IFrameBridge; window.absol = src; var mapKeys = { ShareDom: 'coreDom', ShareDomCreator: 'domCreator', ShareSvgC: 'coreSvgCreator', ShareSvgCreator: 'svgCreator', ShareCreator: 'domCreator' }; src.logData = []; src.log = function () { src.logData.push([new Error('TraceError')].concat(Array.prototype.slice.call(arguments))) } Object.keys(mapKeys).forEach(function (key) { var valueKey = mapKeys[key]; Object.defineProperty(src, key, { get: function () { if (!this['__warn' + key + '__']) { this['__warn' + key + '__'] = true; src.log("use " + valueKey + ' instead of ' + key); } return this[valueKey]; } }); }); /** * @deprecated * @param {string|Array} className * @returns {Boolean} */ AElement/* default.prototype.containsClass */.Z.prototype.containsClass = function (className) { if (className.forEach && className.map) { for (var i = 0; i < className.length; ++i) if (!this.classList.containsClass(className[i])) return false; return true; } else return this.classList.contains(className); }; /** * @deprecated * @param {string|Array} className * @returns {Boolean} */ AElementNS/* default.prototype.containsClass */.Z.prototype.containsClass = AElement/* default.prototype.containsClass */.Z.prototype.containsClass; // EXTERNAL MODULE: ./node_modules/absol-acomp/AComp.js + 1 modules var AComp = __webpack_require__(6657); // EXTERNAL MODULE: ./node_modules/absol/src/String/stringMatching.js var stringMatching = __webpack_require__(991); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/keeview.css var keeview = __webpack_require__(1561); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/QuickMenu.js var QuickMenu = __webpack_require__(1274); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ChromeCalendar.js var ChromeCalendar = __webpack_require__(4845); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Radio.js var Radio = __webpack_require__(7002); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiChars.js var EmojiChars = __webpack_require__(7712); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiAnims.js var EmojiAnims = __webpack_require__(4670); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/messageinput/MessageInput.js + 2 modules var MessageInput = __webpack_require__(4877); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/EmojiPicker.js var EmojiPicker = __webpack_require__(2948); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ContextMenu.js var ContextMenu = __webpack_require__(7054); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/dom/install.js + 242 modules var install = __webpack_require__(6369); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Searcher.js var Searcher = __webpack_require__(9024); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var absol_acomp_ACore = __webpack_require__(3855); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/materializeIconTrigger.js function materializeIconTrigger() { Dom.documentReady.then(function () { var linkMaterial = ACore.$('link', document.head, function (elt) { if (elt.href && elt.href.indexOf('Material+Icons')) return true; }); if (!linkMaterial) return; var checkInv = -1; function onLoaded() { if (checkInv > 0) { clearTimeout(checkInv); checkInv = -1; } linkMaterial.off('loaded', onLoaded) .off('load', onLoaded) .off('error', onLoaded); i.remove(); requestAnimationFrame(function () { ResizeSystem.update(); if (document.cookie.indexOf('absol_debug') >= 0) { console.info('Resize after MaterialIcons load'); } }); } linkMaterial.on('loaded', onLoaded) .on('load', onLoaded) .on('error', onLoaded); var i = ACore._({ tag: 'i', class:"material-icons", style: { fontSize: '14px', position: 'fixed', top: '0', left: '0', zIndex: '-1000', visibility: 'hidden' }, child: { text: 'account_balance_wallet' } }).addTo(document.body); var iBox = i.getBoundingClientRect(); if (iBox.width < iBox.height * 3) { onLoaded(); return; } var intervalCount = 50; checkInv = setInterval(function () { intervalCount--; if (intervalCount < 0) { onLoaded(); } iBox = i.getBoundingClientRect(); if (iBox.width < iBox.height * 3) { onLoaded(); } }, 200); }); } // EXTERNAL MODULE: ./node_modules/absol-acomp/js/VariantColors.js var VariantColors = __webpack_require__(8494); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Tooltip.js var Tooltip = __webpack_require__(5194); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextMeasure.js + 1 modules var TextMeasure = __webpack_require__(2610); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/BContextCapture.js var BContextCapture = __webpack_require__(9782); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/cpuviewer.css var cpuviewer = __webpack_require__(8858); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/CPUViewer.js /*** * @extends AElement * @constructor */ function CPUViewer() { /*** * * @type {HTMLCanvasElement} */ this.$canvas = (0,absol_acomp_ACore.$)('canvas', this); this.ctx = this.$canvas.getContext('2d'); this.offsetTime = 0; this.inv = -1; this.usage = Array(120).fill(0); this.holdStart = 0; this.holdTime = 0; this.logOffset = 0; this.counter = 0; this['tick'] = this.tick.bind(this); } CPUViewer.tag = 'CPUViewer'.toLowerCase(); CPUViewer.render = function () { return (0,absol_acomp_ACore._)({ class: 'as-cpu-viewer', child: { tag: 'canvas', attr: { width: '120px', height: '50px' } } }); }; CPUViewer.prototype.start = function () { if (this.inv < 0) { this.offsetTime = new Date().getTime(); setInterval(this.tick, 250) } }; CPUViewer.prototype.stop = function () { if (this.inv > 0) { clearInterval(this.inv); this.inv = -1; } }; CPUViewer.prototype.tick = function () { while (this.holdTime > 250) { this.holdTime -= 250; this.usage.push(100); } this.usage.push(this.holdTime * 100 / 250); while (this.usage.length > 120) { this.usage.shift(); } this.ctx.fillStyle = 'black'; this.ctx.fillRect(0, 0, 120, 50); var y; this.ctx.fillStyle = 'yellow'; for (var x = 0; x < this.usage.length; ++x) { y = this.usage[x] / 2; this.ctx.fillRect(x, 50 - y, 1, y); } var now = new Date().getTime(); this.logOffset = now; this.holdStart = now; this.holdTime = 0; }; CPUViewer.prototype.hold = function () { if (this.counter === 0) { this.holdStart = new Date().getTime(); } this.counter++; }; CPUViewer.prototype.release = function () { if (this.counter <= 0) return; this.counter--; if (this.counter === 0) { this.holdTime += new Date().getTime() - this.holdStart; } }; /*** * * @type {CPUViewer} */ CPUViewer.instance = null; CPUViewer.state = 'NOT_INIT'; CPUViewer.start = function () { if (!this.instance) { this.instance = (0,absol_acomp_ACore._)('cpuviewer'); this.state = "NOT_ATTACHED"; } if (this.state === "NOT_ATTACHED") { this.state = "RUNNING"; HTML5_Dom/* default.documentReady.then */.ZP.documentReady.then(function () { document.body.appendChild(this.instance); }.bind(this)); } this.instance.start(); CPUViewer.hold = function () { this.instance.hold(); }; CPUViewer.release = function () { this.instance.release(); }; }; CPUViewer.stop = function () { if (!this.instance) return; if (this.state !== "RUNNING") return; this.instance.stop(); this.instance.remove(); this.state = 'NOT_ATTACHED'; }; CPUViewer.hold = function () { }; CPUViewer.release = function () { }; absol_acomp_ACore/* default.install */.Z.install(CPUViewer); /* harmony default export */ const js_CPUViewer = (CPUViewer); function AttachHookView() { } HTML5_Dom/* default.documentReady.then */.ZP.documentReady.then(() => { return; if (!window.ABSOL_DEBUG && location.href.indexOf('localhost') < 0) { return; } var elt = (0,absol_acomp_ACore._)({ class:'as-pending-attachhook-count' }).addTo(document.body); setInterval(() => { elt.innerHTML = '' + Object.keys(pendingAttachHooks).length }, 2000); }); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/list/ListDictionary.js var ListDictionary = __webpack_require__(103); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/keeview/overviewwidget.css var overviewwidget = __webpack_require__(2553); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TabView.js + 2 modules var TabView = __webpack_require__(7); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Hanger.js var Hanger = __webpack_require__(655); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/OnScreenWidget.js var OnScreenWidget = __webpack_require__(7315); // EXTERNAL MODULE: ./node_modules/absol-acomp/css/keeview/owmodal.css var owmodal = __webpack_require__(4672); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/FlexiconButton.js var FlexiconButton = __webpack_require__(3929); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/keeview/OWModalManager.js function implicitNode(data) { if (!data) return (0,absol_acomp_ACore._)('div'); if (data instanceof Array) { return data.map(implicitNode); } else if ((0,HTML5_Dom/* isDomNode */.mV)(data)) { return data; } else if (typeof data === "string") { return (0,absol_acomp_ACore._)({ tag: 'span', child: { text: data } }); } else if (typeof data === "object") { return (0,absol_acomp_ACore._)(data); } else return (0,absol_acomp_ACore._)('div'); } /*** * * @constructor */ function OWModalManager() { } OWModalManager.prototype.getView = function () { if (!this.$view) this.createView(); return this.$view; }; OWModalManager.prototype.createView = function () { this.$view = (0,absol_acomp_ACore._)('.kv-ow-modal-manager'); }; OWModalManager.prototype.createModal = function (opt, caller) { console.trace(1); opt = opt || {}; var modal = (0,absol_acomp_ACore._)({ class: 'kv-ow-modal', child: { class: 'kv-ow-modal-window', child: [ { class: 'kv-ow-modal-header', child: [ { class: 'kv-ow-modal-title', child: { text: 'Tiêu đề' } } ] }, { class: 'kv-ow-modal-body', child: Array(3).fill({ tag: 'span', child: { text: 'Bạn có chắc muốn thoát khỏi nhóm? Đây là nội dung hơi bị dài luôn nè' } }) }, { class: 'kv-ow-modal-footer' } ] } }); modal.$body = (0,absol_acomp_ACore.$)('.kv-ow-modal-body', modal); modal.$title = (0,absol_acomp_ACore.$)('.kv-ow-modal-title', modal); modal.$footer = (0,absol_acomp_ACore.$)('.kv-ow-modal-footer', modal); if (modal.$title) { if (typeof opt.title === "string") { modal.$title.clearChild().addChild((0,absol_acomp_ACore._)({ text: opt.title })); } else { modal.$title.clearChild().addChild(implicitNode(opt.title)); } } else { modal.$title.addStyle('display', 'none'); } modal.$body.clearChild(); if (opt.content || opt.contentbody) { modal.$body.addChild(implicitNode(opt.content || opt.contentbody)); } modal.$footer.clearChild(); if (opt.buttons || opt.buttonlist) { modal.$footer.addChild((opt.buttons || opt.buttonlist).map(function (bt) { var props = Object.assign({}, bt); delete props.onclick; var onclick = bt.onclick; return (0,absol_acomp_ACore._)({ tag: FlexiconButton/* default.tag */.Z.tag, props: props, on: { click: function (event) { if (typeof onclick === "function") { onclick.call(this, event, modal, caller); } } } }) })); } return modal; }; OWModalManager.prototype.showModal = function (opt, caller) { var modal = this.createModal(opt, caller); var minZIndex = Array.prototype.reduce.call(this.getView(), function (ac, cr) { return Math.max(ac, parseFloat(cr.style.zIndex) || 0) }, 0); modal.addStyle('zIndex', minZIndex + 1 + ''); this.$view.addChild(modal); return modal; }; /* harmony default export */ const keeview_OWModalManager = (OWModalManager); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/keeview/OverviewWidget.js /*** * @extends Fragment * @param {{}} host * @param {Fragment[]} children * @constructor */ function OverviewWidget(host, children) { Fragment/* default.call */.Z.call(this); this.setting = { viewPos: { x: 0, y: 0 }, minimize: true }; this.host = host; this.children = children || []; this.childrenById = this.children.reduce(function (ac, child) { ac[child.id] = child; return ac; }, {}); this._position = new Vec2/* default */.Z(0, 0); this.setContext("OVERVIEW_WIDGET", this); this.children.forEach(function (fg) { fg.attach(this); }.bind(this)); this.modalMng = new keeview_OWModalManager(); } OOP/* default.mixClass */.ZP.mixClass(OverviewWidget, Fragment/* default */.Z); OverviewWidget.prototype.createView = function () { this.$title = (0,absol_acomp_ACore._)({ tag: 'span', class: 'kv-overview-widget-title', child: { text: '...' } }); this.$tabs = this.children.map(function (fg) { return (0,absol_acomp_ACore._)({ tag: 'tabframe', class: 'kv-overview-widget-page', child: fg.getView(), props: { name: ' '.repeat(5),//||fg.name, tabIcon: fg.tabIcon, id: fg.id } }); }); this.$view = (0,absol_acomp_ACore._)({ class: 'kv-overview-widget', style: { '--x': '0px', '--y': '0px', visibility: 'hidden' }, child: [ { tag: Hanger/* default.tag */.Z.tag, class: 'kv-overview-widget-header', child: [ this.$title, { class: 'kv-overview-widget-header-window-action', child: [ { tag: 'button', child: 'span.mdi.mdi-window-minimize', on: { click: this.minimize.bind(this) } } ] } ], on: { predrag: this.ev_headerPredrag.bind(this), dragstart: this.ev_headerDragStart.bind(this), drag: this.ev_headerDrag.bind(this), dragend: this.ev_headerDragEnd.bind(this), } }, { class: 'kv-overview-widget-body', child: { tag: TabView/* default.tag */.Z.tag, class: ['kv-overview-widget-tab-view', 'xp-tiny'], child: this.$tabs, on: { activetab: this.ev_activeTab.bind(this) } } }, this.modalMng.getView() ] }); this._updateViewPosition(); this.$bubble = (0,absol_acomp_ACore._)({ tag: OnScreenWidget/* default.tag */.Z.tag, class: 'kv-overview-widget-bubble', id: 'overview_widget_bubble', style: { // visibility: 'hidden' '--cx': '0.02', '--cy': '0.96' }, child: [ '<svg class="kv-overview-widget-bubble-background" viewBox="0 0 24 24">\n' + ' <path fill="currentColor" d="M3 11H11V3H3M5 5H9V9H5M13 21H21V13H13M15 15H19V19H15M3 21H11V13H3M5 15H9V19H5M13 3V11H21V3M19 9H15V5H19Z" />\n' + '</svg>', { class: 'kv-overview-widget-bubble-badge', child: { tag: 'span', child: { text: '0' } } } ], on: { click: this.toggle.bind(this) } }); this.$tabview = (0,absol_acomp_ACore.$)('.kv-overview-widget-tab-view', this.$view); this.$action = (0,absol_acomp_ACore.$)('.kv-overview-widget-header-window-action', this.$view); this.$bubbleBadge = (0,absol_acomp_ACore.$)('.kv-overview-widget-bubble-badge', this.$bubble); this.$badgeText = (0,absol_acomp_ACore.$)('span', this.$bubbleBadge); this.$badgeText.requestUpdateSize = this._updateViewPosition.bind(this); var self = this; this.$tabs.forEach(function (tabElt) { tabElt.on('active', function () { self.childrenById[this.id].start(); }); tabElt.on('deactive', function () { self.childrenById[this.id].pause(); }); }); this.updateCounter(); }; OverviewWidget.prototype.saveSetting = function () { localStorage.setItem('overview_widget_setting', JSON.stringify(this.setting)); }; OverviewWidget.prototype.loadSetting = function () { var setting = {}; try { var settingJson = localStorage.getItem('overview_widget_setting'); if (settingJson) setting = JSON.parse(settingJson); } catch (err) { } Object.assign(this.setting, setting); this._position = new Vec2/* default */.Z(this.setting.viewPos.x, this.setting.viewPos.y); this._updateViewPosition(); }; OverviewWidget.prototype.updateCounter = function (from) { var id; var tabElt; var counter; if (from) { id = from.id; tabElt = this.$tabview.getTabById(id); counter = from.counter; if (counter) tabElt.name = '(' + counter + ')'; else tabElt.name = ' '.repeat(5); } else { this.$tabs.forEach(function (tabElt) { id = tabElt.id; var frg = this.childrenById[id]; var counter = frg.counter; if (counter) tabElt.name = '(' + counter + ')'; else tabElt.name = ' '.repeat(5); }.bind(this)); } var sumCounter = this.children.reduce(function (ac, cr) { return ac + cr.counter; }, 0); this.$badgeText.firstChild.data = sumCounter + ''; if (sumCounter > 0) { this.$bubbleBadge.removeStyle('visibility'); } else { this.$bubbleBadge.addStyle('visibility', 'hidden'); } }; OverviewWidget.prototype.onStart = function () { this.getView(); this.loadSetting(); this.$view.addTo(document.body); this.$bubble.addTo(document.body); HTML5_ResizeSystem/* default.add */.Z.add(this.$badgeText); this._updateViewPosition(); if (this.setting.minimize) { this.$bubble.removeStyle('visibility'); } else { this.$view.removeStyle('visibility'); } this.children.forEach(function (fg) { fg.start(true); }); var activeTabId = this.$tabview.getActiveTabId(); this.childrenById[activeTabId].start(); }; OverviewWidget.prototype.onStop = function () { this.getView().remove(); }; OverviewWidget.prototype.ev_activeTab = function (event) { var frag = this.childrenById[event.id]; this.$title.firstChild.data = frag.name + ''; }; OverviewWidget.prototype.ev_headerPredrag = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.$action, event)) { event.cancel(); } }; OverviewWidget.prototype.ev_headerDragStart = function (event) { var bound = this.$view.getBoundingClientRect(); this._dragData = { bound: bound, p0: new Vec2/* default */.Z(bound.left, bound.top), modal: (0,absol_acomp_ACore._)({ style: { position: 'fixed', zIndex: '1000000000', left: 0, right: 0, top: 0, bottom: 0, background: 'transparent' } }).addTo(document.body) }; }; OverviewWidget.prototype.ev_headerDrag = function (event) { var d = event.currentPoint.sub(event.startingPoint); this._position = this._dragData.p0.add(d); this._updateViewPosition(); }; OverviewWidget.prototype.ev_headerDragEnd = function (event) { this._dragData.modal.remove(); this.setting.viewPos.x = this._position.x; this.setting.viewPos.y = this._position.y; this.saveSetting(); }; OverviewWidget.prototype._updateViewPosition = function () { if (!this.$view) return; var screenSize = (0,HTML5_Dom/* getScreenSize */.tE)(); var bound = this.$view.getBoundingClientRect(); var x = Math.max(0, Math.min(this._position.x, screenSize.width - bound.width)); var y = Math.max(0, Math.min(this._position.y, screenSize.height - bound.height)); this.$view.addStyle({ '--x': x + 'px', '--y': y + 'px' }); }; OverviewWidget.prototype.showModal = function (opt) { return this.modalMng.showModal(opt, this); }; Object.defineProperty(OverviewWidget.prototype, 'position', { set: function (value) { if (!value) value = new Vec2/* default */.Z(0, 0); if (value instanceof Array) { if ((0,utils.isRealNumber)(value[0] && (0,utils.isRealNumber)(value[1]))) { value = new Vec2/* default */.Z(value[0], value[1]); } else { value = new Vec2/* default */.Z(0, 0); } } else if (!(value instanceof Vec2/* default */.Z)) { if ((0,utils.isRealNumber)(value.x && (0,utils.isRealNumber)(value.y))) { value = new Vec2/* default */.Z(value[0], value[1]); } else { value = new Vec2/* default */.Z(0, 0); } } this._position = value; this._updateViewPosition(); }, get: function () { return this._position; } }); OverviewWidget.prototype.minimize = function () { this.$view.addStyle('visibility', 'hidden'); // this.$bubble.removeStyle('visibility'); this.setting.minimize = true; this.saveSetting(); var activeTabId = this.$tabview.getActiveTabId(); this.childrenById[activeTabId].pause(); }; OverviewWidget.prototype.maximize = function () { // this.$bubble.addStyle('visibility', 'hidden'); this.$view.removeStyle('visibility'); this.setting.minimize = false; this.saveSetting(); var activeTabId = this.$tabview.getActiveTabId(); this.childrenById[activeTabId].start(); }; OverviewWidget.prototype.toggle = function () { if (this.setting.minimize) { this.maximize(); } else { this.minimize(); } }; /* harmony default export */ const keeview_OverviewWidget = (OverviewWidget); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/keeview/OverviewPage.js /*** * @extends Fragment * @param {{}} host * @constructor */ function OverviewPage(host) { Fragment/* default.call */.Z.call(this); this.host = host; this.id = (0,stringGenerate.randomIdent)(5); this._counter = 0; } OOP/* default.mixClass */.ZP.mixClass(OverviewPage, Fragment/* default */.Z); OverviewPage.prototype.tabIcon = 'span.mdi.mdi-cube-outline'; OverviewPage.prototype.name = 'Overview Page'; OverviewPage.prototype.createView = function () { return (0,absol_acomp_ACore._)({ child: { tag: 'span', child: { text: 'OverviewPage' } } }); }; OverviewPage.prototype.showModal = function (opt) { if (this.parent && this.parent.showModal) return this.parent.showModal(opt, this); }; Object.defineProperty(OverviewPage.prototype, 'counter', { set: function (value) { /*** * * @type {OverviewWidget} */ var parent = this.parent; if (!(0,utils.isRealNumber)(value)) value = 0; value = Math.max(0, value >> 0); this._counter = value; parent.updateCounter(); }, get: function () { return this._counter; } }); /* harmony default export */ const keeview_OverviewPage = (OverviewPage); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/finder/Finder.js + 2 modules var Finder = __webpack_require__(8556); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Toast.js var Toast = __webpack_require__(1376); // EXTERNAL MODULE: ./node_modules/absol/src/Print/pdf.js var pdf = __webpack_require__(9673); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ProgressBar.js var ProgressBar = __webpack_require__(6535); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/printer.js function silentDownloadAsPdf(adapter) { if (!adapter) throw new Error("Invalid print data"); adapter.parallel = adapter.parallel || 8; adapter.delay = adapter.delay || 0; adapter.chuckLength = 100; adapter.fileName = adapter.fileName || 'exports.pdf'; if (adapter.paddingEven !== false) { adapter.paddingEven = true; } if (!adapter.fileName.toLowerCase().endsWith('.pdf')) adapter.fileName += '.pdf'; var hiddenDiv = (0,absol_acomp_ACore._)({ style: { overflow: 'scroll', visibility: 'hidden', opacity: 0, pointerEvents: 'none', position: 'fixed', zIndex: -1000, } }).addTo(document.body); var progressBar = (0,absol_acomp_ACore._)({ tag: ProgressBar/* default */.Z, style: { margin: '5px' } }); var message = (0,absol_acomp_ACore._)({ tag: 'span', style: { margin: '5px' }, child: { text: 'Render' } }); /*** * * @type {Toast} */ var toast = Toast/* default.make */.Z.make({ props: { htitle: "Export DPF" }, child: [ { tag: 'div', style: { margin: '5px' }, child: { tag: 'strong', child: { text: adapter.fileName } } }, message, progressBar ] }); return new Promise(resolve => { var docs = adapter.docs.slice(); var docsN = docs.length; var serializer = Print_printer.ShareSerializer; var chucks = []; var chuckRemain; var printer; var finish = () => { message.firstChild.data = "Create PDF"; (0,pdf/* mergePdfs */.I)(chucks, pData => { progressBar.value = 0.9 + (pData.loaded + pData.merged) / (pData.all || 1) / 10; }).then(mergedPdf => { mergedPdf.save().then(file => { (0,FileSaver.saveAs)(new Blob([file]), adapter.fileName); progressBar.value = 1; message.firstChild.data = "Complete"; setTimeout(() => { toast.disappear(); }, 5000); }); }) } var nextChuck = () => { chuckRemain = Math.min(adapter.chuckLength, docs.length); printer = new Print_printer.PaperPrinter(Object.assign({ lastPagePaddingEven: docs.length <= chuckRemain }, adapter)); process(); } var finishChuck = () => { chucks.push(printer.pdfDoc.output('arraybuffer')); if (docs.length > 0) { nextChuck(); } else { finish(); } }; var process = () => { message.firstChild.data = 'Render (' + (docsN - docs.length) + '/' + docsN + ')'; var pg0 = 0.9 * (1 - docs.length / (docsN || 1)); progressBar.value = pg0; if (chuckRemain === 0) { finishChuck(); return; } var cDocs = docs.splice(0, Math.min(adapter.parallel, chuckRemain)); chuckRemain -= cDocs.length; var localSync = cDocs.map(doc => { var ctn = (0,absol_acomp_ACore._)({ style: { width: '2048px' } }).addTo(hiddenDiv); var renderSync = doc.render(ctn, doc); if (renderSync && renderSync.then) { renderSync = renderSync.then(() => Object.assign({}, doc, { elt: ctn.firstChild })); } else { renderSync = Promise.resolve(Object.assign({}, doc, { elt: ctn.firstChild })); } return renderSync.then(doc => { var delaySync = []; delaySync.push(new Promise(resolve => { setTimeout(resolve, adapter.delay); })) var elt = doc.elt; if (elt.fmComponent) { if (!doc.opt) doc.opt = {}; if (!doc.opt.margin) { doc.opt.margin = { top: elt.fmComponent.style.paddingTop || 57, left: elt.fmComponent.style.paddingLeft || 57, bottom: elt.fmComponent.style.paddingBottom || 57, right: elt.fmComponent.style.paddingRight || 57 }; } delaySync.push(elt.fmComponent.fragment.afterEntryCompleted()); } return Promise.all(delaySync).then(() => doc); }) }); Promise.all(localSync).then(docList => { return serializer.serialize(docList, printer, (pData) => { if (!pData.pdf) return; var ng1 = pg0 + pData.pdf.done / (pData.pdf.all || 1) * cDocs.length / (docsN || 1) * 0.9; if (ng1 - progressBar.value > 0.05) { progressBar.value = ng1; } }); }).then(() => printer.flush()) .then(() => process()); }; nextChuck(); }); } // EXTERNAL MODULE: ./node_modules/absol-acomp/css/mobileapp.css var mobileapp = __webpack_require__(8789); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/mobile/MApplication.js /** * @extends Fragment * @constructor */ function MApplication() { Fragment/* default.call */.Z.call(this); this.stack = []; this.pendingLoop = []; this.loopRunning = false; } OOP/* default.mixClass */.ZP.mixClass(MApplication, Fragment/* default */.Z); MApplication.prototype.createView = function () { this.$view = (0,absol_acomp_ACore._)({ class: ['am-application', 'am-stack'] }) }; MApplication.prototype.postHandler = function (handler) { this.pendingLoop.push(handler); if (this.loopRunning) return; while (this.pendingLoop.length > 0) { this.pendingLoop.shift()(); } }; MApplication.prototype.startActivity = function (clazz, bundle) { var handle = () => { var curAct = this.stack[this.stack.length - 1]; if (curAct) { curAct.pause(); } var newAct = new clazz(bundle); var view = newAct.getView(); this.$view.addChild(view); this.stack.push(newAct); newAct.attach(this); newAct.onCreated(); if (this.state === "PAUSE") { newAct.start(true); } else if (this.state === 'RUNNING') { if (curAct) curAct.pause(); newAct.start(); } } this.postHandler(handle); }; MApplication.prototype.replaceActivity = function (clazz, bundle) { var curAct = this.stack[this.stack.length - 1]; if (curAct) this.finishActivity(curAct, true); this.startActivity(clazz, bundle); }; /** * * @param act * @param {boolean=} replace */ MApplication.prototype.finishActivity = function (act, replace) { this.postHandler(() => { var curAct = this.stack[this.stack.length - 1]; if (curAct) { if (curAct !== act) throw new Error("Activity stack error!"); curAct.detach(); curAct.getView().remove(); this.stack.pop(); curAct.destroy(); curAct = this.stack[this.stack.length - 1]; if (curAct && this.state === 'RUNNING' && !replace) { curAct.resume(); } } }); }; MApplication.prototype.onStart = function () { for (var i = 0; i < this.stack.length; ++i) { this.stack[i].start(true); } }; MApplication.prototype.onResume = function () { var curAct = this.stack[this.stack.length - 1]; if (curAct) { curAct.resume(true); } }; MApplication.prototype.onPause = function () { var curAct = this.stack[this.stack.length - 1]; if (curAct) { curAct.pause(); } }; MApplication.prototype.onStop = function () { for (var i = this.stack.length - 1; i >= 0; --i) { this.stack[i].stop(); } }; MApplication.prototype.onDestroy = function () { while (this.stack.length) { this.stack.pop().destroy(); } }; /* harmony default export */ const mobile_MApplication = (MApplication); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/js/mobile/MActivity.js function MActivity(bundle) { Fragment/* default.call */.Z.call(this); this.caller = null; this.arguments = null; this.result = null; } OOP/* default.mixClass */.ZP.mixClass(MActivity, Fragment/* default */.Z); MActivity.prototype.createView = function () { this.$view = (0,absol_acomp_ACore._)({ class: 'am-activity' }); }; // // // MActivity.prototype.finish = function () { // if (!this.session) { // throw new Error("Activity is not started!"); // } // this.stop(); // if (this.onFinished) this.onFinished(); // if (this.caller) { // this.caller.activityReturn(this.session, this, this.result); // this.caller= null; // this.result = null; // this.arguments = null; // this.session = null; // } // }; // // /** // * @param {MActivity} activity // * @param {*} bundle // */ // MActivity.prototype.startActivity = function (session, activity, args) { // activity.stop();//stop before call new // this.pause(); // activity.caller = this; // activity.arguments = args; // activity.result = null; // activity.session = session; // activity.attach(this); // activity.viewToApp(); // activity.start(); // }; // // MActivity.prototype.activityReturn = function (session, act, result) { // if (this.onActivityReturn) { // this.onActivityReturn(session, act, result); // } // // this.viewToApp(); // this.resume(); // }; /* harmony default export */ const mobile_MActivity = (MActivity); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/list/ListSearchMaster.js + 1 modules var ListSearchMaster = __webpack_require__(4623); ;// CONCATENATED MODULE: ./node_modules/absol-acomp/dev.js absol.VariantColors = VariantColors/* default */.Z; absol.parseMessage = MessageInput/* parseMessage */.kW; absol.vScrollIntoView = utils.vScrollIntoView; //for export to window absol.Tooltip = Tooltip/* default */.Z; absol.QuickMenu = QuickMenu/* default */.Z; absol.AComp = AComp/* default */.Z; absol.Radio = Radio/* default */.Z; absol.EmojiChars = EmojiChars/* default */.Z; absol.EmojiAnims = EmojiAnims/* default */.Z; absol.ChromeCalendar = ChromeCalendar/* default */.Z; (0,install/* default */.Z)(absol.coreDom); //old module absol.coreDom.install('searchcrosstextinput', Searcher/* default */.Z); Object.assign(absol.string, stringMatching); absol.MessageInput = MessageInput/* default */.ZP absol.EmojiPicker = EmojiPicker/* default */.Z; absol.ContextCaptor = ContextMenu/* default */.Z; absol.ListDictionary = ListDictionary/* default */.Z; absol.FinderFileSystem = Finder/* FinderFileSystem */.Vm; window.AComp = absol.AComp; absol.TextMeasure = TextMeasure/* default */.Z; absol.printer.silentDownloadAsPdf = silentDownloadAsPdf; absol.ListSearchMaster = ListSearchMaster/* default */.Z; HTML5_Dom/* default.documentReady.then */.ZP.documentReady.then(function () { var mdiLink = absol.$('link', document.head, function (e) { if (e.href && e.href.toLowerCase().indexOf('materialdesignicons') >= 0) return true; }); if (!mdiLink) { mdiLink = absol._({ tag: 'link', attr: { rel: 'stylesheet', href: 'https://absol.cf/vendor/materialdesignicons/materialdesignicons.css' } }).addTo(document.head); } }); Object.assign(absol.$, utils); // materializeIconTrigger(); absol.openFileDialog = utils.openFileDialog; absol.CPUViewer = js_CPUViewer; absol.OverviewWidget = keeview_OverviewWidget; absol.OverviewPage = keeview_OverviewPage; absol.MApplication = mobile_MApplication; absol.MActivity = mobile_MActivity; HTML5_Dom/* default.documentReady.then */.ZP.documentReady.then(function () { ContextMenu/* default.auto */.Z.auto(); }); function testFont() { var dynamicCSs = new DynamicCSS(); var value = parseInt(localStorage.getItem('as_test_font_size')) || 14; var fontSizeInput = absol._({ tag: 'numberinput', props: { step: 1, min: 5, value: value }, on: { change: () => { localStorage.setItem('as_test_font_size', fontSizeInput.value + ''); dynamicCSs.setProperty(':root', 'font-size', fontSizeInput.value + 'px') .commit(); window.dispatchEvent(new Event('resize')) } } }); dynamicCSs.setProperty(':root', 'font-size', fontSizeInput.value + 'px') .commit(); window.dispatchEvent(new Event('resize')) var modal = absol._({ style: { background: 'white', position: 'fixed', top: '5px', right: '5px', padding: '5px', border: '1px solid #ddd', zIndex: 1e9 }, child: ['<label>font-size </label>', fontSizeInput] }).addTo(document.body); } if (location.href.indexOf('localhost') >= 0) { // Dom.documentReady.then(testFont); } })(); // This entry need to be wrapped in an IIFE because it need to be in strict mode. (() => { "use strict"; // NAMESPACE OBJECT: ./src/helper.js var helper_namespaceObject = {}; __webpack_require__.r(helper_namespaceObject); __webpack_require__.d(helper_namespaceObject, { "addDevContextMenu": () => (addDevContextMenu), "autoCurve": () => (autoCurve), "beautyStep": () => (beautyStep), "calBeautySegment": () => (calBeautySegment), "circle": () => (circle), "fresherColor": () => (fresherColor), "generateBackgroundColors": () => (generateBackgroundColors), "getGlobalBBox": () => (getGlobalBBox), "getMaxHeightBox": () => (getMaxHeightBox), "getMaxWidthBox": () => (getMaxWidthBox), "getMinHeightBox": () => (getMinHeightBox), "getMinWidthBox": () => (getMinWidthBox), "getSubNumberArray": () => (getSubNumberArray), "hline": () => (hline), "isNumber": () => (isNumber), "lighterColor": () => (lighterColor), "line": () => (line), "map": () => (map), "measureArial14TextWidth": () => (measureArial14TextWidth), "moveHLine": () => (moveHLine), "moveVLine": () => (moveVLine), "paddingLeft": () => (paddingLeft), "pathTokenize": () => (pathTokenize), "rect": () => (rect), "text": () => (helper_text), "toLocalString": () => (toLocalString), "vline": () => (vline), "wrapChartInWHResizer": () => (wrapChartInWHResizer), "wrapToLines": () => (wrapToLines) }); // NAMESPACE OBJECT: ./src/template.js var template_namespaceObject = {}; __webpack_require__.r(template_namespaceObject); __webpack_require__.d(template_namespaceObject, { "rotate": () => (rotate), "translate": () => (translate) }); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Svg.js var Svg = __webpack_require__(6821); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/svg/Core.js var Core = new Svg/* default */.ZP(); /* harmony default export */ const svg_Core = (Core); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElementNS.js var AElementNS = __webpack_require__(2510); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Vec2.js var Vec2 = __webpack_require__(557); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/controller/Turtle.js /** * @typedef TurtleCommand * @property {String} cmd * @property {String} action * @property {Number[]} args * @property {Vec2} dest * @property {Vec2} tangent */ /*** * * @constructor */ function Turtle() { /** * @type {Array<TurtleCommand>} */ this._commands = []; /** * @type {Vec2} */ this._pos = new Vec2/* default */.Z(0, 0); /** * @type {Vec2} */ this._startPos = this._pos; /** * @type {Vec2} */ this._tangent = new Vec2/* default */.Z(0, 0); } /** * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.moveBy = function (dx, dy) { this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._startPos = this._pos; this._commands.push({ cmd: 'm', action: 'moveBy', args: [dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.moveTo = function (x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._startPos = this._pos; this._commands.push({ cmd: 'M', action: 'moveTo', args: [x, y], dest: this._pos, tangent: this._tangent }); return this; }; Turtle.prototype.moveForward = function (length) { var dV = this._tangent.normalized().mult(length); this._pos = this._pos.add(dV); this._startPos = this._pos; this._commands.push({ cmd: 'm', action: 'moveTo', args: [dV.x, dV.y], dest: this._pos, tangent: this._tangent }); return this; }; Turtle.prototype.lineForward = function (length) { var dV = this._tangent.normalized().mult(length); this._pos = this._pos.add(dV); this._startPos = this._pos; this._commands.push({ cmd: 'l', action: 'moveTo', args: [dV.x, dV.y], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} angle - degree * @returns {Turtle} */ Turtle.prototype.rotateDirTo = function (angle) { this._tangent = Vec2/* default.fromDirection */.Z.fromDirection(angle * Math.PI / 180); return this; }; /*** * * @param {Number} dAngle * @returns {Turtle} */ Turtle.prototype.rotateDirBy = function (dAngle) { this._tangent = this._tangent.rotate(dAngle * Math.PI / 180); return this; }; /** * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.lineBy = function (dx, dy) { this._tangent = new Vec2/* default */.Z(x, y); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'l', action: 'lineBy', args: [dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.lineTo = function (x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'L', action: 'lineTo', args: [x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.lineBy = function (dx, dy) { this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'l', action: 'lineBy', args: [dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @returns {Turtle} */ Turtle.prototype.hLineTo = function (x) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, this._pos.y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'H', action: 'hLineTo', args: [x], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @returns {Turtle} */ Turtle.prototype.hLineBy = function (x) { this._tangent = new Vec2/* default */.Z(x, 0); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'h', action: 'hLineBy', args: [x], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} y * @returns {Turtle} */ Turtle.prototype.vLineTo = function (y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(this._pos.x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'V', action: 'vLineTo', args: [y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} y * @returns {Turtle} */ Turtle.prototype.vLineBy = function (y) { this._tangent = new Vec2/* default */.Z(0, y); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'v', action: 'vLineBy', args: [y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c1x * @param {Number} c1y * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.cubicBezierTo = function (c1x, c1y, c2x, c2y, x, y) { this._tangent = new Vec2/* default */.Z(c2x, c2y); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'C', action: 'cubicBezierTo', args: [c1x, c1y, c2x, c2y, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c1dx * @param {Number} c1dy * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.cubicBezierBy = function (c1dx, c1dy, c2dx, c2dy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(c2dx, c2dy)); this._pos = new Vec2/* default */.Z(dx, dy); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'c', action: 'cubicBezierBy', args: [c1dx, c1dy, c2dx, c2dy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.smoothCubicBezierTo = function (c2x, c2y, x, y) { this._tangent = new Vec2/* default */.Z(c2x, c2y); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'S', action: 'smoothCubicBezierTo', args: [c2x, c2y, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.smoothCubicBezierBy = function (c2dx, c2dy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(c2dx, c2dy)); this._pos = new Vec2/* default */.Z(dx, dy); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 's', action: 'smoothCubicBezierBy', args: [c2dx, c2dy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.quadraticBezierTo = function (cx, cy, x, y) { this._tangent = new Vec2/* default */.Z(cx, cy); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'Q', action: 'quadraticBezierTo', args: [cx, cy, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.quadraticBezierBy = function (cdx, cdy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(cdx, cdy)); this._pos = new Vec2/* default */.Z(dx, dy); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'q', action: 'quadraticBezierBy', args: [cdx, cdy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {Turtle} */ Turtle.prototype.smoothQuadraticBezierTo = function (cx, cy, x, y) { this._tangent = new Vec2/* default */.Z(cx, cy); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'T', action: 'smoothQuadraticBezierTo', args: [cx, cy, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.smoothQuadraticBezierBy = function (cdx, cdy, dx, dy) { this._tangent = this._pos.add(new Vec(cdx, cdy)); this._pos = new Vec2/* default */.Z(dx, dy); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 't', action: 'smoothQuadraticBezierBy', args: [cdx, cdy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} rx * @param {Number} ry * @param {Number} angle * @param {Number} large * @param {Number} sweep * @param {Number} x * @param {Number} y * @return {Turtle} */ Turtle.prototype.arcTo = function (rx, ry, angle, large, sweep, x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); var AB = this._pos.sub(this._tangent); //in ellipse var AB_inE = AB.rotate(-angle / 180 * Math.PI); //in circle var AB_inC = new Vec2/* default */.Z(AB_inE.x / rx, AB_inE.y / ry); var AH_inC; var HO_length_inC; var AH_length_inC; var HO_inC; var BO_inC; var tangent_inC; var tangent_inE; AH_inC = AB_inC.div(2); AH_length_inC = AH_inC.abs(); HO_length_inC = Math.sqrt(1 - AH_length_inC * AH_length_inC); if (!sweep != !large) { HO_inC = AB_inC.rotate90().normalized().mult(HO_length_inC); BO_inC = AH_inC.inv().add(HO_inC); tangent_inC = BO_inC.rotate90().inv(); } else { HO_inC = AB_inC.rotate90().inv().normalized().mult(HO_length_inC);//ok BO_inC = AH_inC.inv().add(HO_inC); tangent_inC = BO_inC.rotate90(); } if (large) tangent_inC = tangent_inC.inv(); tangent_inE = new Vec2/* default */.Z(tangent_inC.x * rx, tangent_inC.y * ry); this._tangent = tangent_inE.rotate(angle / 180 * Math.PI); this._commands.push({ cmd: 'A', action: 'lineTo', args: [rx, ry, angle, large, sweep, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} rx * @param {Number} ry * @param {Number} angle * @param {Number} large * @param {Number} sweep * @param {Number} dx * @param {Number} dy * @return {Turtle} */ Turtle.prototype.arcBy = function (rx, ry, angle, large, sweep, dx, dy) { //todo: wrong_tangent this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'a', action: 'arcBy', args: [rx, ry, angle, large, sweep, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @returns {Turtle} */ Turtle.prototype.closePath = function () { this._tangent = this._pos; this._pos = this._startPos; this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'z', action: 'closePath', args: [], dest: this._pos }); return this; }; /** * @param {Number} dx * @param {Number} dy * @returns {Turtle} */ Turtle.prototype.translate = function (dx, dy) { var command; var deltaVec = new Vec2/* default */.Z(dx, dy); for (var i = 0; i < this._commands.length; ++i) { command = this._commands[i]; command.dest = command.dest.add(deltaVec); switch (command.cmd) { case 'M': case 'L': command.args[0] = command.dest.x; command.args[1] = command.dest.y; break; case 'H': command.args[0] = command.dest.x; break; case 'V': command.args[0] = command.dest.y; break; case 'C': command.args[0] += dx; command.args[1] += dy; command.args[2] += dx; command.args[3] += dy; command.args[4] = command.dest.x; command.args[5] = command.dest.y; break; case 'Q': command.args[0] += dx; command.args[1] += dy; command.args[3] = command.dest.x; command.args[4] = command.dest.y; break; case 'A': command.args[5] = command.dest.x; command.args[6] = command.dest.y; break; } } return this; }; /** * @returns {String} */ Turtle.prototype.getPath = function () { return this._commands.map(function (command) { return command.cmd + ' ' + command.args.join(','); }).join(' '); }; /*** * * @return {Turtle} */ Turtle.prototype.reset = function () { this._commands = []; this._pos = new Vec2/* default */.Z(0, 0); this._startPos = this._pos; this._tangent = new Vec2/* default */.Z(0, 0); return this; }; Turtle.prototype.clone = function () { var res = new Turtle(); res._commands.push.apply(res._commands, this._commands); res._pos = this._pos.copy(); res._startPos = this._startPos.copy(); res._tangent = this._tangent.copy() return res; }; /* harmony default export */ const controller_Turtle = (Turtle); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/svg/Shape.js var _ = svg_Core._; var $ = svg_Core.$; /*** * @extends {AElementNS} * @constructor */ function Shape() { this._turtle = new controller_Turtle(); } Shape.tag = 'shape'; Shape.render = function () { return _('path'); }; /*** * * @return {Shape} */ Shape.prototype.begin = function () { this._turtle.reset(); return this; }; /*** * * @return {Shape} */ Shape.prototype.end = function () { this.attr('d', this._turtle.getPath()); return this; }; /*** * * @param {Number} angle - degree * @returns {Shape} */ Shape.prototype.rotateDirTo = function (angle) { this._turtle.rotateDirTo(angle); return this; }; /*** * * @param {Number} dAngle * @returns {Shape} */ Shape.prototype.rotateDirBy = function (dAngle) { this._turtle.rotateDirBy(dAngle); return this; }; /*** * * @param {Number} x * @param {Number} y * @return {Shape} */ Shape.prototype.moveTo = function (x, y) { this._turtle.moveTo(x, y); return this; }; /*** * * @param {Number} dx * @param {Number} dy * @return {Shape} */ Shape.prototype.moveBy = function (dx, dy) { this._turtle.moveBy(dx, dy); return this; }; /*** * * @return {Shape} */ Shape.prototype.closePath = function () { this._turtle.closePath(); return this; } /*** * * @param {Number} x * @param {Number} y * @return {Shape} */ Shape.prototype.lineTo = function (x, y) { this._turtle.lineTo(x, y); return this; }; /*** * * @param {Number} dx * @param {Number} dy * @return {Shape} */ Shape.prototype.lineBy = function (dx, dy) { this._turtle.lineBy(dx, dy); return this; }; /*** * * @param {Number} x * @return {Shape} */ Shape.prototype.hLineTo = function (x) { this._turtle.hLineTo(x); return this; }; /*** * * @param {Number} dx * @return {Shape} */ Shape.prototype.hLineBy = function (dx) { this._turtle.hLineBy(x); return this; }; /*** * * @param {Number} y * @return {Shape} */ Shape.prototype.vLineTo = function (y) { this._turtle.vLineTo(y); return this; }; /*** * * @param {Number} dy * @return {Shape} */ Shape.prototype.vLineBy = function (dy) { this._turtle.vLineBy(dy); return this; }; /** * @param {Number} c1x * @param {Number} c1y * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {Shape} */ Shape.prototype.cubicBezierTo = function (c1x, c1y, c2x, c2y, x, y) { this._turtle.cubicBezierTo(c1x, c1y, c2x, c2y, x, y); return this; }; /** * @param {Number} c1dx * @param {Number} c1dy * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {Shape} */ Shape.prototype.cubicBezierBy = function (c1dx, c1dy, c2dx, c2dy, dx, dy) { this._turtle.cubicBezierBy(c1dx, c1dy, c2dx, c2dy, dx, dy); return this; }; /** * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {Shape} */ Shape.prototype.smoothCubicBezierTo = function (c2x, c2y, x, y) { this._turtle.smoothCubicBezierTo(c2x, c2y, x, y); return this; }; /** * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {Shape} */ Shape.prototype.smoothCubicBezierBy = function (c2dx, c2dy, dx, dy) { this._turtle.smoothCubicBezierBy(c2dx, c2dy, dx, dy); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {Shape} */ Shape.prototype.quadraticBezierTo = function (cx, cy, x, y) { this._turtle.quadraticBezierTo(cx, cy, x, y); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {Shape} */ Shape.prototype.quadraticBezierBy = function (cdx, cdy, dx, dy) { this._turtle.quadraticBezierBy(cdx, cdy, dx, dy); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {Shape} */ Shape.prototype.smoothQuadraticBezierTo = function (cx, cy, x, y) { this._turtle.smoothQuadraticBezierTo(cx, cy, x, y); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {Shape} */ Shape.prototype.smoothQuadraticBezierBy = function (cdx, cdy, dx, dy) { this._turtle.smoothQuadraticBezierBy(cdx, cdy, dx, dy); return this; }; /*** * * @param {Number} x * @param {Number} y * @param {Number} rx * @param {Number} ry * @param {Number} lf * @param {Number} sf * @param {Number} xRotate * @return {Shape} */ Shape.prototype.arcTo = function (x, y, rx, ry, lf, sf, xRotate) { ry = ry || rx; lf = lf || 0; sf = sf || 0; xRotate = xRotate || 0; this._turtle.arcTo(rx, ry, xRotate, lf, sf, x, y); return this; }; /*** * * @param {Number} dx * @param {Number} yd * @param {Number} rx * @param {Number} ry * @param {Number} lf * @param {Number} sf * @param {Number} xRotate * @return {Shape} */ Shape.prototype.arcBy = function (dx, yd, rx, ry, lf, sf, xRotate) { ry = ry || rx; lf = lf || 0; sf = sf || 0; xRotate = xRotate || 0; this._turtle.arcBy(rx, ry, xRotate, lf, sf, dx, yd); return this; }; /*** * * @param {Number} x * @param {Number} y * @param {Number} x0 * @param {Number} y0 * @param {Number} x1 * @param {Number} y1 * @return {Shape} */ Shape.prototype.curveTo = function (x, y, x0, y0, x1, y1) { this._turtle.cubicBezierTo(x0, y0, x1, y1, x, y); return this; }; svg_Core.install(Shape); /* harmony default export */ const svg_Shape = (Shape); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/Dom.js + 1 modules var Dom = __webpack_require__(6628); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/ResizeSystem.js var ResizeSystem = __webpack_require__(6700); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/controller/CSvgBox.js /*** * * @param {SvgCanvas} $svg * @constructor */ function CSvgBox($svg) { this.$svg = $svg; this._width = 0; this._height = 0; this.width = 0; this.height = 0; } /*** * * @param {number} width * @param {number} height */ CSvgBox.prototype.setSize = function (width, height) { this.$svg.attr('width', width + ''); this.$svg.attr('height', height + ''); this.$svg.attr('viewBox', [-0.5, -0.5, width, height].join(' ')); this._width = width; this._height = height; }; Object.defineProperty(CSvgBox.prototype, 'width', { /*** * * @param {Number} width */ set: function (width) { this.setSize(width, this._height); }, /*** * * @return {number} */ get: function () { return this._width; } }); Object.defineProperty(CSvgBox.prototype, 'height', { /*** * * @param {Number} height */ set: function (height) { this.setSize(this._width, height); }, /*** * * @return {number} */ get: function () { return this._height; } }); Object.defineProperty(CSvgBox.prototype, 'size', { /*** * * @param {{width: number, height:number}} size */ set: function (size) { this.setSize(size.width, size.height); }, /*** * * @return {{width: number, height: number}} */ get: function () { return { width: this._width, height: this._height }; } }); /* harmony default export */ const controller_CSvgBox = (CSvgBox); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/svg/SvgCanvas.js var SvgCanvas_ = svg_Core._; var SvgCanvas_$ = svg_Core.$; /*** * @extends AElementNS * @constructor */ function SvgCanvas() { var thisSC = this; this.box = new controller_CSvgBox(this); this.$attachhook = SvgCanvas_$('sattachhook', this) .on('attached', this.eventHandler.svgAttached); this.$attachhook.requestUpdateSize = function (){ thisSC.updateSize(); } } SvgCanvas.tag = 'svgcanvas'; SvgCanvas.render = function () { return SvgCanvas_({ tag: 'svg', class:'ag-canvas', child: 'sattachhook' }); }; SvgCanvas.prototype.clearChild = function () { while (this.lastChild && this.lastChild !== this.$attachhook) { this.removeChild(this.firstChild); } return this; }; SvgCanvas.prototype._updateCanvasSize = function () { var bound = this.getBoundingClientRect(); var width = bound.width; var height = bound.height; this.box.setSize(width, height); }; SvgCanvas.prototype.updateSize = function (){ this._updateCanvasSize(); }; /*** * @type {SvgCanvas} */ SvgCanvas.eventHandler = {}; SvgCanvas.eventHandler.svgAttached = function (){ ResizeSystem/* default.add */.Z.add(this.$attachhook); this.updateSize(); } svg_Core.install(SvgCanvas); /* harmony default export */ const svg_SvgCanvas = (SvgCanvas); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/controller/CContainerBox.js /*** * * @param {GContainer} $g * @constructor */ function CContainerBox($g) { this.$g = $g; this._width = 0; this._height = 0; this._x = 0; this._y = 0; this.width = 0; this.height = 0; this.x = 0; this.y = 0; } /*** * * @param {number} width * @param {number} height * @returns {CContainerBox} */ CContainerBox.prototype.setSize = function (width, height) { this._width = width; this._height = height; return this; }; /*** * * @param {number} x * @param {number} y * @returns {CContainerBox} */ CContainerBox.prototype.setPosition = function (x, y) { if (x === 0 && y === 0) { } else { this.$g.attr('transform', 'translate(' + x + ',' + y + ')'); } this._x = x; this._y = y; }; Object.defineProperty(CContainerBox.prototype, 'width', { /*** * * @param {number} width */ set: function (width) { this.setSize(width, this._height); }, /*** * * @return {number} */ get: function () { return this._width; } }); Object.defineProperty(CContainerBox.prototype, 'height', { /*** * * @param {number} height */ set: function (height) { this.setSize(this._width, height); }, /*** * * @return {number} */ get: function () { return this._height; } }); Object.defineProperty(CContainerBox.prototype, 'size', { /*** * * @param {{width: number, height:number}} size */ set: function (size) { this.setSize(size.width, size.height); }, /*** * * @return {{width: number, height: number}} */ get: function () { return { width: this._width, height: this._height }; } }); Object.defineProperty(CContainerBox.prototype, 'x', { /*** * * @param {number} x */ set: function (x) { this.setPosition(x, this._y); }, /*** * * @return {number} */ get: function () { return this._x; } }); Object.defineProperty(CContainerBox.prototype, 'y', { /*** * * @param {number} y */ set: function (y) { this.setPosition(this._x, y); }, /*** * * @return {number} */ get: function () { return this._y; } }); Object.defineProperty(CContainerBox.prototype, 'position', { /*** * * @param {{x: number, y:number}} position */ set: function (position) { this.setPosition(position.x, position.y); }, /*** * * @return {{x: number, y:number}} */ get: function () { return { x: this._x, y: this._y }; } }); /* harmony default export */ const controller_CContainerBox = (CContainerBox); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/svg/GContainer.js var GContainer_ = svg_Core._; var GContainer_$ = svg_Core.$; /*** * @extends {AElementNS} * @constructor */ function GContainer() { this.box = new controller_CContainerBox(this); } GContainer.tag = 'gcontainer'; GContainer.render = function () { return GContainer_('g'); }; /* harmony default export */ const svg_GContainer = (GContainer); ;// CONCATENATED MODULE: ./node_modules/absol-svg/js/svg/install.js var Creators = [ svg_Shape, svg_SvgCanvas, svg_GContainer ]; /*** * * @param {Dom | Svg} core */ function install(core) { core.install(Creators); }; ;// CONCATENATED MODULE: ./src/VCore.js var VCore = new Svg/* default */.ZP(); install(VCore); var VCore_ = VCore._; var VCore_$ = VCore.$; /* harmony default export */ const src_VCore = (VCore); // EXTERNAL MODULE: ./src/style/minicomp.css var minicomp = __webpack_require__(1799); // EXTERNAL MODULE: ./src/style/basechart.css var basechart = __webpack_require__(8184); // EXTERNAL MODULE: ./src/style/linechart.css var linechart = __webpack_require__(2312); // EXTERNAL MODULE: ./src/style/tooltip.css var tooltip = __webpack_require__(8734); // EXTERNAL MODULE: ./src/style/rangechart.css var rangechart = __webpack_require__(4695); // EXTERNAL MODULE: ./src/style/assessmentchart.css var assessmentchart = __webpack_require__(286); // EXTERNAL MODULE: ./src/style/columnchart.css var columnchart = __webpack_require__(2687); // EXTERNAL MODULE: ./src/style/rangegroupchart.css var rangegroupchart = __webpack_require__(9033); // EXTERNAL MODULE: ./src/style/rankchart.css var rankchart = __webpack_require__(6053); // EXTERNAL MODULE: ./src/style/sunburstchart.css var sunburstchart = __webpack_require__(622); // EXTERNAL MODULE: ./src/style/squarechart.css var squarechart = __webpack_require__(301); // EXTERNAL MODULE: ./src/style/grouprankchart.css var grouprankchart = __webpack_require__(1595); // EXTERNAL MODULE: ./src/style/mappingchart.css var mappingchart = __webpack_require__(8856); // EXTERNAL MODULE: ./src/style/imagechart.css var imagechart = __webpack_require__(4516); // EXTERNAL MODULE: ./src/style/horizontalbarchart.css var horizontalbarchart = __webpack_require__(5233); // EXTERNAL MODULE: ./src/style/resizeablediv.css var resizeablediv = __webpack_require__(7139); ;// CONCATENATED MODULE: ./src/style/vchartStyle.js /* harmony default export */ const vchartStyle = ({}); ;// CONCATENATED MODULE: ./src/Axis.js var Axis_ = src_VCore._; var Axis_$ = src_VCore.$; /*** * @extends GContainer * @constructor */ function Axis() { this.$oxy = Axis_$('#oxy', this); this.$oxArrow = Axis_$('#ox-arrow', this); this.$oyArrow = Axis_$('#oy-arrow', this); this.$oyDivision = Axis_$('.cv-oy-division', this); this.oxLength = 1; this.oyLength = 1; this.oyPadding = 0; this.oyDivision = NaN; } Axis.tag = 'Axis'.toLowerCase(); Axis.render = function () { return Axis_({ tag: 'gcontainer', "class": "vchart-axis", child: [{ tag: 'path', id: "oy-arrow", attr: { d: "m-5 0h10l-5-6.8z" } }, { tag: 'path', id: "ox-arrow", attr: { d: 'm0 -5v10l6.8 -5z' } }, { tag: 'path', id: 'oxy', attr: { d: 'm0 -1v1 h1', fill: 'none' } }, { tag: 'path', "class": 'cv-oy-division', style: { display: 'none' } }] }); }; Axis.prototype.updateOyDivision = function () { if (this.oyDivision) { this.$oyDivision.removeStyle('display'); var y = this.oyDivision + this.oyPadding; if (this.oyPadding) y -= this.oyDivision; var d = ''; while (y <= this.oyLength) { d += 'M-2 ' + -y + 'H 2 '; y += this.oyDivision; } this.$oyDivision.attr('d', d); } else { this.$oyDivision.addStyle('display', 'none'); } }; Axis.prototype.updateSize = function () { this.$oxy.attr('d', 'm0 ' + -this.oyLength + 'v' + this.oyLength + ' h' + this.oxLength); this.$oxArrow.attr('transform', 'translate(' + this.oxLength + ', 0)'); this.$oyArrow.attr('transform', 'translate(0, ' + -this.oyLength + ')'); this.updateOyDivision(); }; Axis.prototype.resize = function (oxLength, oyLength) { this.oxLength = oxLength; this.oyLength = oyLength; this.updateSize(); }; Axis.prototype.moveTo = function (x, y) { this.attr('transform', 'translate(' + x + ',' + y + ')'); }; Axis.prototype.init = function (props) { if (props) { if (props.oxLength && props.oyLength) this.resize(props.oxLength, props.oyLength); if (props.x && props.y) this.moveTo(props.x, props.y); } }; src_VCore.install(Axis); /* harmony default export */ const src_Axis = ((/* unused pure expression or super */ null && (Axis))); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Mat3.js var Mat3 = __webpack_require__(9846); // EXTERNAL MODULE: ./src/style/scrollarrow.css var scrollarrow = __webpack_require__(6227); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/EventEmitter.js var EventEmitter = __webpack_require__(863); ;// CONCATENATED MODULE: ./src/ScrollArrow.js var ScrollArrow_ = src_VCore._; var ScrollArrow_$ = src_VCore.$; function ScrollArrow() { this.$left = ScrollArrow_$('.vc-scroll-arrow-left', this); this.$right = ScrollArrow_$('.vc-scroll-arrow-right', this); this.width = 100; this.on('pointerdown', this.eventHandler.pointerDown); this.$leftArrow = this.$left; this.$rightArrow = this.$right; this._pointerItv = -1; // .on('pointerdown', function (event) { // event.preventDefault(); // var iv = setInterval(function () { // res.emit('pressleft', event, res); // }, 30); // // function finish(event) { // clearInterval(iv); // this.off('pointerleave', finish); // this.off('pointerup', finish); // }; // this.on('pointerleave', finish); // this.on('pointerup', finish); // }); // // res.$hitBoxLeft = _({ // tag: 'rect', // attr: { // x: -5, // y: -5, // width: 30, // height: 37, // rx: 5, // ry: 5 // }, // style: { // fill: 'rgba(0, 0, 255, 0.1)' // } // }).addTo(res.$leftArrow); // // res.$rightArrow = _( // [ // '<g>', // '<g transform="translate(0,-270)">', // '<g transform="matrix(.26164 0 0 .26164 .23843 218.56)" style="fill:#00a5d6">', // '<path d="m0.99976 198 49.214 48.519-49.213 49.481v-14.201l35.215-35.079-35.164-34.611z" style="fill:#00a5d6"/>', // '<path d="m28.531 198.44v13.96l35.057 34.608-35.057 34.963v13.555l48.91-48.844z" style="fill:#00a5d6"/>', // '</g>', // '</g>', // '</g>' // ].join('') // ).addTo(res) // .on('pointerdown', function (event) { // event.preventDefault(); // var iv = setInterval(function () { // res.emit('pressright', event, res); // }, 30); // // function finish(event) { // clearInterval(iv); // this.off('pointerleave', finish); // this.off('pointerup', finish); // }; // this.on('pointerleave', finish); // this.on('pointerup', finish); // }); // // res.$hitBoxRight = _({ // tag: 'rect', // attr: { // x: -5, // y: -5, // width: 30, // height: 37, // rx: 5, // ry: 5 // }, // style: { // fill: 'rgba(0, 0, 255, 0.1)' // } // }).addTo(res.$rightArrow); // // return res; } Mat3/* default.prototype.apply2DTransform */.Z.prototype.apply2DTransform = function (v, isPoint) { var a = this.data; var x0 = v.x; var y0 = v.y; var x = x0 * a[0] + y0 * a[3] + (isPoint ? a[6] : 0); var y = x0 * a[1] + y0 * a[4] + (isPoint ? a[7] : 0); return new Vec2/* default */.Z(x, y); }; ScrollArrow.tag = 'ScrollArrow'.toLowerCase(); ScrollArrow.render = function () { return ScrollArrow_({ tag: 'gcontainer', extendEvent: ['pressleft', 'pressright'], "class": 'vc-scroll-arrow', child: [{ attr: {// transform: "matrix(.26164 0 0 .26164 .23843 218.56)" }, child: [{ tag: 'gcontainer', "class": 'vc-scroll-arrow-left', child: [{ tag: 'rect', "class": 'vc-scroll-arrow-hit-box', attr: { x: 0, y: -19, width: 30, height: 38, rx: 5, ry: 5 } }, { tag: 'path', "class": 'vc-scroll-arrow-icon', attr: { d: 'm 24.02314720639999998 -12.3647199999999984 -12.876350959999998 12.69451116 12.87608932 12.946208839999999' + ' v -3.71554964 l -9.2136526 -9.178069559999999 9.20030896 -9.05562204 z' + ' M 17.226420839999999 -12.4798416000000003 v 3.6524944 l -9.17231348 9.054837119999998 9.17231348 9.14771932' + ' v 3.5465302 l -12.796812399999999 -12.77954416 z' } }] }, { tag: 'gcontainer', "class": 'vc-scroll-arrow-right', child: [{ tag: 'rect', "class": 'vc-scroll-arrow-hit-box', attr: { x: -30, y: -19, width: 30, height: 38, rx: 5, ry: 5 } }, { tag: 'path', "class": 'vc-scroll-arrow-icon', attr: { d: 'm -22.5000072064 -12.3647199999999984 12.876350959999998 12.69451116 -12.87608932 12.946208839999999' + ' v -3.71554964 l 9.2136526 -9.178069559999999 -9.20030896 -9.05562204 z ' + 'M -15.70328084 -12.4798416000000003 v 3.6524944 l 9.17231348 9.054837119999998 ' + '-9.17231348 9.14771932 v 3.5465302 l 12.796812399999999 -12.77954416 z' } }] }] }] }); }; ScrollArrow.property = { width: { set: function set(value) { this.box.width = value; this.$right.box.x = value; }, get: function get() { return this.box.width; } } }; ScrollArrow.eventHandler = {}; ScrollArrow.eventHandler.pointerDown = function (event) { event.preventDefault(); var button = EventEmitter/* default.hitElement */.ZP.hitElement(this.$left, event) ? 0 : 1; var thisSB = this; this._buttonIdx = button; if (this._pointerItv < 0) { this._pointerItv = setInterval(function () { if (thisSB._buttonIdx === 0) { thisSB.emit('pressleft', event, thisSB); } else if (thisSB._buttonIdx === 1) { thisSB.emit('pressright', event, thisSB); } }, 30); } ScrollArrow_$(document.body).on('pointerup', this.eventHandler.pointerUp); if (thisSB._buttonIdx === 0) { thisSB.emit('pressleft', event, thisSB); } else if (thisSB._buttonIdx === 1) { thisSB.emit('pressright', event, thisSB); } }; ScrollArrow.eventHandler.pointerUp = function () { clearInterval(this._pointerItv); this._pointerItv = -1; ScrollArrow_$(document.body).off('pointerup', this.eventHandler.pointerUp); }; src_VCore.install(ScrollArrow); /* harmony default export */ const src_ScrollArrow = ((/* unused pure expression or super */ null && (ScrollArrow))); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/OOP.js var OOP = __webpack_require__(3349); // EXTERNAL MODULE: ./node_modules/absol/src/Color/Color.js var Color = __webpack_require__(257); // EXTERNAL MODULE: ./node_modules/absol-acomp/AComp.js + 1 modules var AComp = __webpack_require__(6657); // EXTERNAL MODULE: ./node_modules/absol-acomp/ACore.js var ACore = __webpack_require__(3855); ;// CONCATENATED MODULE: ./src/vchart.resizablediv.js var vchart_resizablediv_ = ACore/* default._ */.Z._; var vchart_resizablediv_$ = ACore/* default.$ */.Z.$; function ResizeableDiv() { this.$resizebox = vchart_resizablediv_$('resizebox', this).on('beginmove', this.eventHandler.beginMove); this.on('click', this.eventHandler.click); } ResizeableDiv.tag = 'ResizeableDiv'.toLowerCase(); ResizeableDiv.render = function () { return vchart_resizablediv_({ "class": ['vchart-resizable-div'], extendEvent: 'sizechange', child: { tag: 'resizebox', props: { canResize: true } } }); }; ACore/* default.install */.Z.install('resizablediv', ResizeableDiv); ResizeableDiv.eventHandler = {}; ResizeableDiv.eventHandler.click = function () { this.enableResize(); }; ResizeableDiv.eventHandler.clickBody = function (event) { if (EventEmitter/* default.hitElement */.ZP.hitElement(this.$modal, event) || EventEmitter/* default.hitElement */.ZP.hitElement(this, event)) return; this.disableResize(); }; ResizeableDiv.eventHandler.beginMove = function (event) { this.$modal = (this.$modal || vchart_resizablediv_({ style: { position: 'fixed', left: '1px', right: '1px', top: '1px', bottom: '1px', zIndex: '1000' } })).addTo(document.body); this.$resizebox.on('moving', this.eventHandler.moving); this.$resizebox.on('endmove', this.eventHandler.endMove); this._preBound = this.getBoundingClientRect(); }; ResizeableDiv.eventHandler.moving = function (event) { var w = this._preBound.width; var h = this._preBound.height; if (event.option.bottom) { h += event.clientDY; this.addStyle('height', this._preBound.height + event.clientDY + 'px'); } if (event.option.right) { w += event.clientDX; this.addStyle('width', this._preBound.width + event.clientDX + 'px'); } this.emit('sizechange', { type: 'type', target: this, width: w, height: h, originEvent: event.originEvent || event }); }; ResizeableDiv.eventHandler.endMove = function (event) { this.$resizebox.off('moving', this.eventHandler.moving); this.$resizebox.off('endmove', this.eventHandler.endMove); this.$modal.remove(); }; ResizeableDiv.prototype.enableResize = function () { if (this.containsClass('vchart-resizable-div-active')) return; this.addClass('vchart-resizable-div-active'); vchart_resizablediv_$(document.body).on('click', this.eventHandler.clickBody); }; ResizeableDiv.prototype.disableResize = function () { if (!this.containsClass('vchart-resizable-div-active')) return; this.removeClass('vchart-resizable-div-active'); vchart_resizablediv_$(document.body).off('click', this.eventHandler.clickBody); }; /* harmony default export */ const vchart_resizablediv = ((/* unused pure expression or super */ null && (ResizeableDiv))); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/TextMeasure.js + 1 modules var TextMeasure = __webpack_require__(2610); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/BContextCapture.js var BContextCapture = __webpack_require__(9782); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Rectangle.js var Math_Rectangle = __webpack_require__(2759); ;// CONCATENATED MODULE: ./src/helper.js var helper_ = src_VCore._; var beautyStep = [0.001, 0.002, 0.0025, 0.005, 0.01, 0.02, 0.025, 0.05, 0.1, 0.2, 0.25, 0.5, 1, 2, 5].concat(function () { var res = []; var h = 1; while (h < 10000000000) { res.push(10 * h); res.push(20 * h); res.push(25 * h); res.push(50 * h); h *= 10; } return res; }()); function circle(x, y, r, eClss) { return helper_({ tag: 'circle', "class": eClss, attr: { cx: x, cy: y, r: r } }); } ; /** * @param {String} text * @param {Number} x * @param {Number} y * @param {String=} eClss * @returns {SVGTextElement} */ function helper_text(text, x, y, eClss) { if (eClss instanceof Array) eClss = eClss.join(' '); return helper_('<text x="' + x + '" y="' + y + '" ' + (eClss ? 'class="' + eClss + '"' : '') + '>' + text + '</text>'); } function vline(x, y, length, eClss) { return helper_({ tag: 'path', "class": eClss, attr: { d: 'm' + x + ' ' + y + 'v' + length } }); } function moveVLine(e, x, y, length) { return e.attr('d', 'm' + x + ' ' + y + 'v' + length); } function hline(x, y, length, eClss) { return helper_({ tag: 'path', "class": eClss, attr: { d: 'm' + x + ' ' + y + 'h' + length } }); } function moveHLine(e, x, y, length) { return e.attr('d', 'm' + x + ' ' + y + 'h' + length); } /** * * @param {Number} x * @param {Number} y * @param {Number} width * @param {Number} height * @param {Number} eClss * @returns {SVGRect} */ function rect(x, y, width, height, eClss) { var option = { tag: 'rect', attr: { x: x, y: y, width: width, height: height }, "class": eClss }; return helper_(option); } function line(x0, y0, x1, y1) { return helper_({ tag: 'path', "class": eClss, attr: { d: 'M' + x0 + ' ' + y0 + 'L' + x1 + ' ' + y1 } }); } function calBeautySegment(maxSegment, minValue, maxValue, integerOnly) { var i = 0; var res = { step: 1, segmentCount: maxValue - minValue, maxValue: maxValue, minValue: minValue }; while (i < beautyStep.length) { var step = beautyStep[i]; if (!integerOnly || step >= 1) { var bot = Math.floor(minValue / step); var top = Math.ceil(maxValue / step); if (top - bot <= maxSegment) { res.step = step; res.segmentCount = top - bot; res.maxValue = top * step; res.minValue = bot * step; break; } } ++i; } return res; } //x[i] < x[i+1] function autoCurve(points, strong, free) { if (!(strong > 0)) strong = 0.5; if (points.length == 0) { return ''; } var paddingLeft = points[0].slice(); var paddingRight = points[points.length - 1].slice(); if (typeof free == "number") { paddingLeft[0] -= (points[1][0] - points[0][0]) * free; paddingLeft[1] -= (points[1][1] - points[0][1]) * free; paddingRight[0] += (points[points.length - 1][0] - points[points.length - 2][0]) * free; paddingRight[1] += (points[points.length - 1][1] - points[points.length - 2][1]) * free; } else if (free instanceof Array) { paddingLeft[0] -= free[0][0]; paddingLeft[1] -= free[0][1]; paddingRight[0] += free[1][0]; paddingRight[1] += free[1][1]; } points = [paddingLeft].concat(points).concat([paddingRight]); var Cs = []; Cs.push('M' + points[1].join(' ')); for (var i = 1; i < points.length - 2; ++i) { var A = Vec2/* default.make */.Z.make(points[i - 1]); var B = Vec2/* default.make */.Z.make(points[i]); var C = Vec2/* default.make */.Z.make(points[i + 1]); var D = Vec2/* default.make */.Z.make(points[i + 2]); var AB = B.sub(A); var BC = C.sub(B); var CB = BC.inv(); var DC = C.sub(D); var lAB = AB.abs(); var lBC = BC.abs(); var lDC = DC.abs(); var lCB = lBC; var h1 = Math.sqrt(lAB * lBC); var h2 = Math.sqrt(lBC * lDC); if (h1 == 0) h1 = 1; if (h2 == 0) h2 = 1; var N1 = AB.normalized().add(BC.normalized()).normalized(); var N2 = CB.normalized().add(DC.normalized()).normalized(); var lN1 = lBC == 0 ? 0 : lBC * (N1.dot(BC) / (N1.abs() * BC.abs())) * h1 / (h1 + h2) * strong; var lN2 = lCB == 0 ? 0 : lCB * (N2.dot(CB) / (N2.abs() * CB.abs())) * h2 / (h1 + h2) * strong; N1 = N1.mult(lN1); N2 = N2.mult(lN2); var P1 = B.add(N1); var P2 = C.add(N2); var x1 = P1.x; var y1 = P1.y; var x2 = P2.x; var y2 = P2.y; var x = C.x; var y = C.y; Cs.push('C ' + x1 + ' ' + y1 + ', ' + x2 + ' ' + y2 + ', ' + x + ' ' + y); } return Cs.join(''); } ; function generateBackgroundColors(n) { var l = Math.ceil(Math.sqrt(n)); var arrs = Array(n).fill(null).reduce(function (ac, cr, i) { var tail = ac[ac.length - 1]; if (tail.length >= l) { tail = []; ac.push(tail); } var color = Color/* default.fromHSL */.Z.fromHSL(i / n, 0.5, 0.5); tail.push(color); return ac; }, [[]]); var res = []; var i = 0; while (res.length < n) { if (arrs[i].length > 0) { res.push(arrs[i].shift()); } i = (i + 1) % arrs.length; } return res; } function isNumber(x) { return -Infinity < x && x < Infinity && typeof x == 'number'; } function toLocalString(fixedRight) { var separatorReal = 1.5.toLocaleString().replace(/[0-9]/g, ''); var separatorInt = 10000 .toLocaleString().replace(/[0-9]/g, ''); return function (value) { var x = Math.abs(value); if (fixedRight !== undefined) x = x.toFixed(fixedRight); var s = x.toString().split('.'); var _int = s[0] || ''; var realText = s[1] || ''; _int = _int.split('').reduce(function (ac, cr, i, arr) { if (i == 0 || (arr.length - i) % 3 == 0) { ac.push(cr); } else { ac[ac.length - 1] += cr; } return ac; }, []).join(separatorInt); return (value < 0 ? '-' : '') + _int + (realText.length > 0 ? separatorReal + realText : ''); }; } ; function map(x, l, h, L, H) { return L + (x - l) * (H - L) / (h - l); } function getSubNumberArray(arr) { return arr.reduce(function (ac, value, j) { if (isNumber(value)) { var cr; if (ac.last + 1 < j) { cr = { start: j, values: [] }; ac.currentSubArea = cr; ac.result.push(cr); } else { cr = ac.currentSubArea; } ac.last = j; cr.values.push(value); } return ac; }, { last: -100, result: [], currentSubArea: null }).result; } function wrapChartInWHResizer(chartElt, outerParam) { outerParam = outerParam || {}; var newVersion = chartElt.containsClass('ag-canvas'); if (newVersion) { outerParam.style = outerParam.style || {}; outerParam.style.width = outerParam.width || chartElt.style.width; outerParam.style.height = outerParam.width || chartElt.style.height; if (chartElt._isAutoWidth) { outerParam.style.width = 'auto'; chartElt.addStyle({ height: '100%' }); setTimeout(function () { res.addStyle('width', chartElt.getBoundingClientRect().width + 'px'); chartElt.addStyle({ width: '100%', height: '100%' }); }, 1000); } else { chartElt.addStyle({ width: '100%', height: '100%' }); } } var res = AComp/* default._ */.Z._({ tag: 'resizablediv', style: { display: 'inline-block', verticalAlign: 'top' }, child: chartElt, on: { sizechange: function sizechange(event) { if (chartElt.update) { if (event.width) { chartElt.canvasWidth = event.width; } if (event.height) { chartElt.canvasHeight = event.height; } chartElt.update(); } else if (newVersion) { chartElt.updateSize(); } } } }, false, true).addStyle(outerParam.style || {}); return res; } function paddingLeft(text, _char, length) { while (text.length < length) { text = _char + '' + text; } return text; } /** * * @param {String} text */ function pathTokenize(text) { return text.match(/[a-zA-Z]+|(\-?[0-9\.]+(e\-?[0-9]+)?)/g); } /** * @argument {Array<SVGElement>} * @returns {Number} */ function getMinWidthBox() { return Array.prototype.reduce.call(arguments, function (ac, elt) { return Math.min(ac, elt.getBBox().width); }, 100000000); } /** * @argument {Array<SVGElement>} * @returns {Number} */ function getMinHeightBox() { return Array.prototype.reduce.call(arguments, function (ac, elt) { return Math.min(ac, elt.getBBox().height); }, 100000000); } /** * @argument {Array<SVGElement>} * @returns {Number} */ function getMaxWidthBox() { return Array.prototype.reduce.call(arguments, function (ac, elt) { return Math.max(ac, elt.getBBox().width); }, -100000000); } /** * @argument {Array<SVGElement>} * @returns {Number} */ function getMaxHeightBox() { return Array.prototype.reduce.call(arguments, function (ac, elt) { return Math.max(ac, elt.getBBox().height); }, -100000000); } /** * * @param {import ('absol/src/Color/Color').default} color * @returns {import ('absol/src/Color/Color').default} */ function lighterColor(color, delta) { delta = delta || 0; var hsla = color.toHSLA(); hsla[2] = Math.max(0, Math.min(1, hsla[2] + delta)); return Color/* default.fromHSLA.apply */.Z.fromHSLA.apply(Color/* default */.Z, hsla); } function fresherColor(color, delta) { delta = delta || 0.2; var hsla = color.toHSLA(); hsla[1] = Math.max(0, Math.min(1, hsla[1] + delta)); return Color/* default.fromHSLA.apply */.Z.fromHSLA.apply(Color/* default */.Z, hsla); } /*** * Default font size: Arial * @param {string} text * @param {number} fontSize * @param {number} width */ function wrapToLines(text, fontSize, width) { var words = text.split(' '); var line = [words.shift()]; var lines = [line]; var newText; for (var i = 0; i < words.length; ++i) { newText = line.concat([words[i]]).join(' '); if (TextMeasure/* default.measureWidth */.Z.measureWidth(newText, 'Arial', 14) <= width) { line.push(words[i]); } else { line = [words[i]]; lines.push(line); } } for (var i = 0; i < lines.length; ++i) { lines[i] = lines[i].join(' '); } return lines; } function addDevContextMenu(svg) { BContextCapture/* default.auto */.Z.auto(); svg.defineEvent('contextmenu'); svg.on({ contextmenu: function contextmenu(event) { var img = this; event.showContextMenu({ items: [{ icon: 'span.mdi.mdi-download-outline', text: 'Download as SVG', cmd: 'download' }] }, function (ev) { var menuItem = ev.menuItem; if (menuItem.cmd === 'download') { var url = absol.Svg.svgToSvgUrl(img); var a = absol._({ tag: 'a', style: { display: 'none' }, attr: { href: url, download: 'export.svg' } }).addTo(document.body); a.click(); a.remove(); } }); } }); } function measureArial14TextWidth(text) { return TextMeasure/* default.measureWidth */.Z.measureWidth(text, 'Arial', 14); } function getGlobalBBox(svgElement) { var bbox = svgElement.getBBox(); var matrix = svgElement.getCTM(); var points = [svgElement.ownerSVGElement.createSVGPoint(), svgElement.ownerSVGElement.createSVGPoint(), svgElement.ownerSVGElement.createSVGPoint(), svgElement.ownerSVGElement.createSVGPoint()]; points[0].x = bbox.x; points[0].y = bbox.y; points[1].x = bbox.x + bbox.width; points[1].y = bbox.y; points[2].x = bbox.x; points[2].y = bbox.y + bbox.height; points[3].x = bbox.x + bbox.width; points[3].y = bbox.y + bbox.height; points = points.map(function (point) { return point.matrixTransform(matrix); }); var minX = Math.min(points[0].x, points[1].x, points[2].x, points[3].x); var minY = Math.min(points[0].y, points[1].y, points[2].y, points[3].y); var maxX = Math.max(points[0].x, points[1].x, points[2].x, points[3].x); var maxY = Math.max(points[0].y, points[1].y, points[2].y, points[3].y); return new Math_Rectangle/* default */.Z(minX, minY, maxX - minX, maxY - minY); } ;// CONCATENATED MODULE: ./src/template.js function translate(x, y) { return 'translate(' + x + ', ' + y + ')'; } ; function rotate() { return 'rotate(' + Array.prototype.join.call(arguments, ',') + ')'; } ; ;// CONCATENATED MODULE: ./src/BaseChart.js var BaseChart_ = src_VCore._; var BaseChart_$ = src_VCore.$; function BaseChart() { var _ = vchart._; var $ = vchart.$; var res = _({ tag: 'svg', "class": 'base-chart', child: [{ tag: 'g', attr: { id: 'contentBox' }, child: 'g#content' }, { tag: 'path', "class": 'base-chart-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,0 0,200 200,200 200,0z' } }, 'axis', 'hscrollbar'] }); res.sync = res.afterAttached(); res.$axis = $('axis', res); res.$whiteBoxMask = $('.base-chart-white-mask', res); res.$content = $('g#content', res); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, BaseChart.eventHandler); // res.on('wheel', res.eventHandler.wheel); res.$hscrollbar = $('hscrollbar', res).on('scroll', res.eventHandler.scrollbarscroll); res.integerOnly = false; return res; } ; BaseChart.prototype.integerOnly = false; BaseChart.eventHandler = {}; BaseChart.eventHandler.wheel = function (event) { var d = this.scrollBy(event.deltaY); if (d != 0) { event.preventDefault(); } }; BaseChart.eventHandler.scrollArrowsPressLeft = function (event) { this.scrollBy(-60); }; BaseChart.eventHandler.scrollArrowsPressRight = function (event) { this.scrollBy(60); }; BaseChart.eventHandler.scrollbarscroll = function (event) { this.scrollLeft = this.$hscrollbar.scrollLeft; event.preventDefault(); }; BaseChart.prototype.scrollBy = function (dX) { var scrollLeft = this.scrollLeft + dX / 5; var scrollLeft = Math.max(0, Math.min(this.oxContentLength - this.oxLength, scrollLeft)); var deltaX = scrollLeft - this.scrollLeft; if (deltaX != 0) { this.scrollLeft = scrollLeft; this.$hscrollbar.scrollLeft = scrollLeft; } return deltaX; }; BaseChart.prototype._createOyValues = function (minValue, step, segmentCount, extendOY) { var child = Array(segmentCount + 1 + (extendOY ? 1 : 0)).fill(0).map(function (u, i) { var value; if (extendOY) { if (i == 0) { value = 0; } else { value = minValue + (i - 1) * step; } } else { value = minValue + i * step; } return { tag: 'text', attr: { x: '-14', y: '0', 'text-anchor': 'end' }, props: { innerHTML: this.numberToString(value) } }; }.bind(this)); return vchart._({ tag: 'g', child: child }); }; BaseChart.prototype._createOYSegmentLines = function (n) { var _ = vchart._; var res = _({ tag: 'g', child: Array(n).fill('path.vchart-segment-line') }); return res; }; BaseChart.prototype.numberToString = function (value) { return value.toString(); }; BaseChart.prototype.mapOYValue = function (val) { return -this.paddingnAxisBottom + (this.extendOY ? -this.oySegmentLength : 0) - map(val, this.oyMinValue, this.oyMaxValue, 0, this.oyLength - (this.extendOY ? this.oySegmentLength : 0)); }; BaseChart.prototype.preInit = function () {}; BaseChart.prototype.updateSize = function () { this.attr({ width: this.canvasWidth + '', height: this.canvasHeight + '', viewBox: [0, 0, this.canvasWidth, this.canvasHeight].join(' ') }); }; BaseChart.prototype.updateOyValues = function () { this.oyLength = this.oxyBottom - 70 - this.paddingnAxisBottom; this.oySegmentLength = this.oyLength / (this.oySegmentCount + (this.extendOY ? 1 : 0)); Array.prototype.forEach.call(this.$oyValues.childNodes, function (e, i) { e.attr({ y: -i * this.oySegmentLength + 5 - this.paddingnAxisBottom, x: -10 }); }.bind(this)); var oyValuesBox = this.$oyValues.getBBox(); this.oxyLeft = Math.max(this.oxyLeft, oyValuesBox.width + 14, this.$oyName.getBBox().width); this.oxLength = this.oxLength || this.canvasWidth - this.oxyLeft - 50; this.$oyValues.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); }; BaseChart.prototype.updateOYSegmentLines = function () { this.$oySegmentLines.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); Array.prototype.forEach.call(this.$oySegmentLines.childNodes, function (e, i) { moveHLine(e, -2, -i * this.oySegmentLength - this.paddingnAxisBottom, 4); }.bind(this)); }; BaseChart.prototype.updateBackComp = function () { this.$title.attr('x', this.canvasWidth / 2); this.updateOyValues(); this.updateOYSegmentLines(); }; BaseChart.prototype.updateAxis = function () { this.$axis.attr('transform', translate(this.oxyLeft, this.oxyBottom)); this.$axis.resize(this.canvasWidth - this.oxyLeft - 10, this.oxyBottom - 50); this.$oyName.attr({ x: this.oxyLeft, y: 30, 'text-anchor': 'end' }); this.$whiteBoxMask.attr('d', 'M0,0 0,cvh cvw,cvh cvw,0zMleft,top left,bottom right,bottom right,topz'.replace(/cvh/g, this.canvasHeight).replace(/cvw/g, this.canvasWidth).replace(/left/g, this.oxyLeft).replace(/top/g, 1).replace(/bottom/g, this.canvasHeight).replace(/right/g, this.canvasWidth - 10)); this.$content.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); this.$oxName.attr({ x: this.canvasWidth - this.$oxName.getBBox().width - 3, y: this.oxyBottom - 9 }); }; BaseChart.prototype.updateFrontComp = function () {}; BaseChart.prototype.updateComp = function () {}; BaseChart.prototype.updateScrollArrows = function () { this.$scrollArrows.box.setPosition(this.oxyLeft + 7, this.oxyBottom - this.oyLength / 2); this.$scrollArrows.width = this.oxLength - 15; this.scrollLeft = this.scrollLeft + 0; //update this.$hscrollbar.resize(this.oxLength, 10); this.$hscrollbar.moveTo(this.oxyLeft, this.oxyBottom - 10); this.$hscrollbar.outterWidth = this.oxLength; this.$hscrollbar.innerWidth = this.oxContentLength; }; BaseChart.prototype.update = function () { if (typeof this.canvasWidth != 'number') { this.canvasWidth = 300; this.autoWidth = true; } this.oxLength = 0; //init this.updateSize(); this.updateBackComp(); this.updateAxis(); this.updateComp(); this.updateScrollArrows(); this.updateFrontComp(); requestAnimationFrame(function () { if (this.autoWidth) { var requireWidth = this.canvasWidth + this.overflowOX; var proviceWidth = this.parentElement.getBoundingClientRect().width; this.canvasWidth = Math.max(Math.min(requireWidth, proviceWidth), 300); this.autoWidth = false; this.update(); } }.bind(this)); }; BaseChart.prototype.initScroll = function () { this.$scrollArrows = vchart._('scrollarrow').addTo(this).on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); }; BaseChart.prototype.preInit = function () { this.canvasWidth = 900; this.canvasHeight = 600; this.paddingnAxisBottom = 0; this.maxSegment = 9; this.oyMaxValue = 10; this.oyMinValue = 0; this.valueName = ''; this.keyName = ''; this.colorTable = ['#821616', ' #824116', '#826C16', '#6C8216', '#418216', '#168216', '#168241', '#16826C', '#166C82', '#164182', '#161682', '#411682', '#6C1682', '#82166C', '#821641']; }; BaseChart.prototype.processMinMax = function () { this.minValue = 0; this.maxValue = 10; }; BaseChart.prototype.beautifyMinMax = function () { if (!(this.maxValue >= this.minValue)) { this.maxValue = 10; this.minValue = 0; } if (this.maxValue == this.minValue) this.maxValue += this.maxSegment; var btSgmt = calBeautySegment(this.maxSegment, this.minValue, this.maxValue, this.integerOnly); this.oySegmentCount = btSgmt.segmentCount; this.oyMinValue = btSgmt.minValue; this.oyMaxValue = btSgmt.maxValue; this.extendOY = !!(this.zeroOY && this.oyMinValue > 0); this.oyStep = btSgmt.step; this.oxyLeft = 20; this.oxyBottom = this.canvasHeight - 40; }; BaseChart.prototype.initBackComp = function () { this.$oyValues = this._createOyValues(this.oyMinValue, this.oyStep, this.oySegmentCount, this.extendOY).addTo(this); this.$oySegmentLines = this._createOYSegmentLines(this.oySegmentCount + 1 + (this.extendOY ? 1 : 0)).addTo(this); this.$title = helper_text(this.title || '', 0, 19, 'base-chart-title').attr('text-anchor', 'middle').addTo(this); this.$oyName = helper_text(this.valueName || '', 0, 0, 'base-chart-oxy-text').addTo(this); this.$oxName = helper_text(this.keyName || '', 0, 0, 'base-chart-oxy-text').addTo(this); }; BaseChart.prototype.initComp = function () {}; BaseChart.prototype.initFrontComp = function () {}; BaseChart.prototype.initScroll = function () { this.$scrollArrows = vchart._('scrollarrow').addTo(this).on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); }; BaseChart.prototype.init = function (props) { for (var key in props) { if (props[key] === undefined) delete props[key]; } this.preInit(); this["super"](props); this.processMinMax(); this.beautifyMinMax(); this.initBackComp(); this.initComp(); this.initFrontComp(); this.initScroll(); this.sync = this.sync.then(this.update.bind(this)); }; BaseChart.property = {}; BaseChart.property.scrollLeft = { set: function set(value) { this._scrollLeft = value || 0; this.$content.attr('transform', 'translate(' + (this.oxyLeft - this.scrollLeft) + ',' + this.oxyBottom + ')'); if (this.scrollLeft > 0.001) { this.$scrollArrows.$leftArrow.removeStyle('display'); } else { this.$scrollArrows.$leftArrow.addStyle('display', 'none'); } if (this.oxContentLength - this.oxLength > this.scrollLeft + 0.001) { this.$scrollArrows.$rightArrow.removeStyle('display'); } else { this.$scrollArrows.$rightArrow.addStyle('display', 'none'); } }, get: function get() { return this._scrollLeft || 0; } }; BaseChart.property.overflowOX = { get: function get() { return Math.max(0, this.oxContentLength - this.oxLength); } }; BaseChart.property.showInlineValue = { set: function set(value) { if (value) { this.addClass('vchart-show-inline-value'); } else { this.removeClass('vchart-show-inline-value'); } }, get: function get() { return this.containsClass('vchart-show-inline-value'); } }; src_VCore.creator.basechart = BaseChart; /* harmony default export */ const src_BaseChart = (BaseChart); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/utils.js var utils = __webpack_require__(1477); ;// CONCATENATED MODULE: ./src/ToolTip.js function TooltipSession(content, x, y) { this.content = content; this.x = (0,utils.isRealNumber)(x) ? x : 0; this.y = (0,utils.isRealNumber)(y) ? y : 0; this.open(); } /** * * @type {{$ctn: AElement, $anchor: AElement, holder: TooltipSession}} */ TooltipSession.prototype.share = { $anchor: null, $ctn: null, holder: null }; TooltipSession.prototype._prepare = function () { if (this.share.$anchor) return; this.share.$ctn = (0,ACore._)({ "class": "vchart-tooltip-container" }); this.share.$anchor = (0,ACore._)({ "class": 'vchart-tooltip-anchor', child: this.share.$ctn }); }; TooltipSession.prototype.open = function () { var _this = this; this._prepare(); if (this.share.holder === this) return; if (this.share.holder) { this.share.holder.close(); } this.share.holder = this; this.share.$anchor.addStyle({ visibility: 'hidden', left: this.x + 'px', top: this.y + 'px' }).addTo(document.body); this.share.$ctn.clearChild(); if (typeof this.content === "string") { this.content.split(/\r?\n/).forEach(function (line, i) { if (i) (0,ACore._)('br').addTo(_this.share.$ctn); (0,ACore._)({ tag: 'span', child: { text: line } }).addTo(_this.share.$ctn); }); } else { console.error("Not support tooltip.content ", this.content); } var bound = this.share.$ctn.getBoundingClientRect(); var screenBound = (0,Dom/* getScreenSize */.tE)(); if (this.y < bound.height) { this.share.$ctn.addStyle('top', '0').addStyle('bottom', 'unset'); } else { this.share.$ctn.removeStyle('top').removeStyle('bottom'); } if (this.x + bound.width > screenBound.width) { this.share.$ctn.addStyle('right', '0').addStyle('left', 'unset'); } else { this.share.$ctn.removeStyle('right').removeStyle('left'); } this.share.$anchor.removeStyle('visibility'); }; TooltipSession.prototype.close = function () { if (this.share.holder !== this) return; this.share.holder = null; this.share.$ctn.clearChild(); this.share.$anchor.remove(); }; /** * adapt old version * @param cb * @returns {TooltipSession} */ TooltipSession.prototype.then = function (cb) { if (typeof cb === "string") { cb(this); } return this; }; function showTooltip(text, clientX, clientY) { return new TooltipSession(text, clientX, clientY); } function closeTooltip(token) { if (token && token.close) token.close(); } ;// CONCATENATED MODULE: ./src/HLineArrow.js var HLineArrow_ = src_VCore._; var HLineArrow_$ = src_VCore.$; /*** * @extends AElementNS * @constructor */ function HLineArrow() { this._length = 0; this.$line = HLineArrow_$('path.vchart-line-arrow-line', this); this.$arrow = HLineArrow_$('.vchart-line-arrow-rect', this); this.length = 0; } HLineArrow.tag = 'HLineArrow'.toLowerCase(); HLineArrow.render = function () { return HLineArrow_({ "class": 'vchart-line-arrow', child: ['path.vchart-line-arrow-line', { tag: 'path', "class": 'vchart-line-arrow-rect', attr: { d: 'm-6.8 -5v10l6.8 -5z' } }] }); }; HLineArrow.prototype.resize = function (length) { if (typeof length !== 'number') length = parseFloat(length + ''); length = length || 0; if (length < 0) length = 0; this._length = length; this.$arrow.attr('transform', translate(length, 0)); moveHLine(this.$line, 0, 0, length); this._length = length; }; HLineArrow.property = {}; HLineArrow.property.length = { set: function set(value) { this.resize(this._length); }, get: function get() { return this._length; } }; src_VCore.creator.hlinearrow = HLineArrow; /* harmony default export */ const src_HLineArrow = ((/* unused pure expression or super */ null && (HLineArrow))); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Draggable.js var Draggable = __webpack_require__(5611); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Hanger.js var Hanger = __webpack_require__(655); ;// CONCATENATED MODULE: ./src/HScrollBar.js var HScrollBar_ = src_VCore._; var HScrollBar_$ = src_VCore.$; /** * @augments Hanger * @augments GContainer * @constructor */ function HScrollBar() { var res = HScrollBar_({ tag: Hanger/* default */.Z, elt: this }); this._scrollLeft = 0; this.on('predrag', res.eventHandler.predrag).on('drag', res.eventHandler.drag); this.$bar = HScrollBar_$('.vchart-vscrollbar-bar', this); this.$button = HScrollBar_$('.vchart-vscrollbar-button', this); } HScrollBar.tag = 'HScrollBar'.toLowerCase(); HScrollBar.render = function () { return HScrollBar_({ tag: 'gcontainer', extendEvent: ['scroll'], "class": 'vchart-vscrollbar', child: [{ tag: 'rect', "class": 'vchart-vscrollbar-bar', attr: { x: '0', y: '0' } }, { tag: 'rect', "class": 'vchart-vscrollbar-button' }] }); }; HScrollBar.eventHandler = {}; HScrollBar.eventHandler.predrag = function (event) { var bBox = this.$bar.getBBox(); var bound = this.$bar.getBoundingClientRect(); if (event.target !== this.$button) { var centerOfset = Math.max(0, Math.min(1, (event.clientX - bound.left) / bound.width)); var newScrollLeft = centerOfset * this.innerWidth - this.outterWidth / 2; newScrollLeft = Math.max(0, Math.min(this.innerWidth - this.outterWidth, newScrollLeft)); this._scrollLeft = newScrollLeft; this.updateButtonPosition(); } this.__predragScrollLeft = this._scrollLeft; this.emit('scroll', event, this); }; HScrollBar.eventHandler.drag = function (event) { event.preventDefault(); var bBox = this.$bar.getBBox(); var bound = this.$bar.getBoundingClientRect(); var scaleX = bBox.width / bound.width * this.innerWidth / this.outterWidth; event.moveDX = event.currentPoint.sub(event.startingPoint).x; var newScrollLeft = this.__predragScrollLeft + event.moveDX * scaleX; newScrollLeft = Math.max(0, Math.min(this.innerWidth - this.outterWidth, newScrollLeft)); this._scrollLeft = newScrollLeft; this.updateButtonPosition(); this.emit('scroll', event, this); }; HScrollBar.prototype.updateButtonPosition = function () { var maxButtonX = (this.innerWidth - this.outterWidth) / this.innerWidth * this.width; var buttonX = this.scrollLeft / this.innerWidth * this.width; if (maxButtonX < 0) maxButtonX = 0; if (!(buttonX >= 0)) buttonX = 0; if (!(buttonX <= maxButtonX)) buttonX = maxButtonX; this.$button.attr('x', buttonX + ''); }; HScrollBar.prototype.updateView = function () { if (this.outterWidth >= this.innerWidth) { this.addClass('vchart-hidden'); } else { this.removeClass('vchart-hidden'); this.$bar.attr({ rx: this.height / 2.5 + '', ry: this.height / 2.5 + '' }); var buttonWidth = 1 / (this.innerWidth / this.outterWidth) * this.width; if (!(buttonWidth >= 0 && buttonWidth < Infinity)) buttonWidth = 0; this.$button.attr('width', buttonWidth + ''); this.$button.attr({ height: this.height * 0.8 + '', y: this.height / 10 + '', rx: this.height / 2.5 + '', ry: this.height / 2.5 + '' }); this.updateButtonPosition(); } }; HScrollBar.property = { width: { set: function set(value) { this.$bar.attr('width', value + ''); this.updateView(); }, get: function get() { var r = (this.$bar.attr('width') || '0').replace(/px|em|rem/g, ''); var c = parseFloat(r); if (c > 0) return c; return 0; } }, height: { set: function set(value) { this.$bar.attr('height', value + ''); this.updateView(); }, get: function get() { var r = (this.$bar.attr('height') || '0').replace(/px|em|rem/g, ''); var c = parseFloat(r); if (c > 0) return c; return 0; } }, innerWidth: { set: function set(value) { if (value >= 0) { this._innerWidth = value; this.updateView(); } }, get: function get() { return this._innerWidth || 0; } }, outterWidth: { set: function set(value) { if (value >= 0) { this._outterWidth = value; this.updateView(); } }, get: function get() { return this._outterWidth || 0; } }, scrollLeft: { set: function set(value) { value = Math.max(0, value); value = Math.min(value, this.innerWidth - this.outterWidth); this._scrollLeft = value; this.updateView(); }, get: function get() { return this._scrollLeft || 0; } } }; HScrollBar.prototype.resize = function (width, height) { this.height = height; this.width = width; }; HScrollBar.prototype.moveTo = function (x, y) { this.attr('transform', translate(x, y)); }; src_VCore.creator.hscrollbar = HScrollBar; /* harmony default export */ const src_HScrollBar = ((/* unused pure expression or super */ null && (HScrollBar))); // EXTERNAL MODULE: ./src/style/base.css var base = __webpack_require__(9957); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DomSignal.js var DomSignal = __webpack_require__(5150); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/ResizeBox.js var ResizeBox = __webpack_require__(4860); // EXTERNAL MODULE: ./src/style/chartresizebox.css var chartresizebox = __webpack_require__(4601); ;// CONCATENATED MODULE: ./src/ChartResizeBox.js var ChartResizeBox_ = ACore/* default._ */.Z._; var ChartResizeBox_$ = ACore/* default.$ */.Z.$; /*** * @augments AElement * @extends ResizeBox * @constructor */ function ChartResizeBox() { /*** * * @type {null|AElement} */ this.$target = null; this._listenInterval = -1; this.$attachhook = ChartResizeBox_$('attachhook', this); this.updateSize = this.updateSize.bind(this); this.$attachhook.requestUpdateSize = this.updateSize; this.$attachhook.cancelWaiting(); this.$trackedScrollers = []; this.canResize = true; this._endMoveTime = 0; this.on({ beginmove: this.eventHandler.crbBeginMove, moving: this.eventHandler.crbMove, endmove: function endmove() { this._endMoveTime = new Date().getTime(); } }); } ChartResizeBox.tag = 'ChartResizeBox'.toLowerCase(); ChartResizeBox.render = function () { return ChartResizeBox_({ tag: ResizeBox/* default.tag */.Z.tag, "class": 'vc-chart-resize-box', child: ['attachhook'] }, true); }; ChartResizeBox.prototype.isAttached = function (target) { return this.$target === target; }; ChartResizeBox.prototype.isAfterMoving = function () { return new Date().getTime() - this._endMoveTime < 5; }; ChartResizeBox.prototype.attachTo = function (target) { if (this.$target === target) return; this.detach(); if (!target || !(0,Dom/* isDomNode */.mV)(target)) return; ResizeSystem/* default.add */.Z.add(this.$attachhook); this.$target = target; this.sponsorElement = target; var pe = target.parentElement; if (pe) { pe.appendChild(this); } while (pe) { if (pe.addEventListener) { pe.addEventListener('scroll', this.updateSize); this.$trackedScrollers.push(pe); } else break; pe = pe.parentElement; } document.addEventListener('scroll', this.updateSize); this.$trackedScrollers.push(document); this.updateSize(); }; ChartResizeBox.prototype.detach = function () { clearInterval(this._listenInterval); this._listenInterval = -1; while (this.$trackedScrollers.length > 0) { this.$trackedScrollers.pop().removeEventListener('scroll', this.updateSize); } this.remove(); this.$target = null; }; ChartResizeBox.prototype.updateSize = function () { var target = this.$target; if (!target) return; var bound = target.getBoundingClientRect(); this.addStyle({ left: bound.left + 'px', top: bound.top + 'px', width: bound.width + 'px', height: bound.height + 'px' }); }; ChartResizeBox.eventHandler = {}; ChartResizeBox.eventHandler.crbBeginMove = function (event) { this._targetInitBound = this.$target.getBoundingClientRect(); }; ChartResizeBox.eventHandler.crbMove = function (event) { if (event.option.right) { this.$target.addStyle('width', this._targetInitBound.width + event.clientDX + 'px'); } if (event.option.bottom) { this.$target.addStyle('height', this._targetInitBound.height + event.clientDY + 'px'); } ResizeSystem/* default.update */.Z.update(); }; ACore/* default.install */.Z.install(ChartResizeBox); /* harmony default export */ const src_ChartResizeBox = (ChartResizeBox); // EXTERNAL MODULE: ./node_modules/absol-acomp/js/colorpicker/SelectColorSchemeMenu.js var SelectColorSchemeMenu = __webpack_require__(5830); // EXTERNAL MODULE: ./src/style/note.css var note = __webpack_require__(2859); ;// CONCATENATED MODULE: ./src/KeyNote.js /** * @typedef KeyNoteItem * @property {string} text * @property {null|"rect"|"point"|"line"} noteType * @property {string|Color} color * @property {string} key */ /** * @extends {GContainer} * @constructor */ function KeyNote() { this._noteType = null; this._text = ''; this._color = 'black'; this.$type = null; this.$hitbox = VCore_$('.vc-note-hit', this); this.$text = VCore_$('.vc-note-text', this); } KeyNote.tag = 'KeyNote'.toLowerCase(); KeyNote.render = function () { // var fontSize = AElement.prototype.getComputedStyleValue.call(document.body, 'font-size'); // fontSize = parseFloat((fontSize || '14px').replace('px', '')); var fontSize = 14; return VCore_({ tag: svg_GContainer, "class": 'vc-note', child: [{ tag: 'rect', "class": 'vc-note-hit', attr: { x: 0, y: 0, // width: measureArial14TextWidth(), height: fontSize + '' } }, { tag: 'text', "class": 'vc-note-text', attr: { x: Math.ceil(30 * fontSize / 14) + '', y: Math.ceil(11 * fontSize / 14) + '' } }] }); }; KeyNote.prototype.typeHandlers = {}; KeyNote.prototype.typeHandlers["null"] = { view: function view() { // var fontSize = getComputedStyle(document.body).getPropertyValue('font-size'); // fontSize = parseFloat((fontSize || '14px').replace('px', '')); var fontSize = 14; this.$type = VCore_({ tag: 'rect', "class": 'vc-note-rect', attr: { x: 0, y: 0, width: Math.ceil(24 * fontSize / 14) + '', height: fontSize + '' } }); }, color: function color(value) { this.$type.addStyle('fill', value); } }; KeyNote.prototype.typeHandlers.rect = KeyNote.prototype.typeHandlers["null"]; KeyNote.prototype.typeHandlers.rhombus = { view: function view() { var fontSize = 14; this.$rhombus = VCore_({ tag: 'rect', "class": 'vc-note-rect', attr: { x: -fontSize / 2.8, y: -fontSize / 2.8, width: fontSize / 1.4, height: fontSize / 1.4, transform: 'rotate(45)' } }); this.$type = VCore_({ tag: svg_GContainer, child: this.$rhombus }); this.$type.box.x = Math.ceil(24 * fontSize / 14 / 2); this.$type.box.y = Math.ceil(fontSize / 2); }, color: function color(value) { this.$rhombus.addStyle('fill', value); } }; KeyNote.prototype.typeHandlers.point = { view: function view() { // var fontSize = getComputedStyle(document.body).getPropertyValue('font-size'); // fontSize = parseFloat((fontSize || '14px').replace('px', '')); var fontSize = 14; this.$type = VCore_({ tag: 'circle', "class": 'vc-note-point', style: { strokeWidth: 2, stroke: 'white' }, attr: { cx: Math.ceil(10 * fontSize / 14) + '', cy: Math.ceil(7 * fontSize / 14) + '', r: Math.ceil(8 * fontSize / 14) + '' } }); }, color: function color(value) { this.$type.addStyle('fill', value); } }; KeyNote.prototype.typeHandlers.line = { view: function view() { this.$type = VCore_({ tag: 'path', "class": 'vc-note-line', attr: { d: 'M0 9 h24' } }); }, color: function color(value) { this.$type.addStyle('stroke', value); } }; KeyNote.prototype.typeHandlers.stroke = KeyNote.prototype.typeHandlers.line; KeyNote.property = { noteType: { set: function set(value) { if (!this.typeHandlers[value]) { value = null; } if (this._noteType === value) return; this._noteType = value; if (this.$type) { this.$type.remove(); this.$type = null; } this.typeHandlers[value + ''].view.call(this); if (this.$type) this.typeHandlers[value + ''].color.call(this, this._color + ''); this.addChildAfter(this.$type, this.$hitbox); }, get: function get() { return this._noteType; } }, text: { set: function set(value) { // var fontSize = getComputedStyle(document.body).getPropertyValue('font-size'); // fontSize = parseFloat((fontSize || '14px').replace('px', '')); var fontSize = 14; value = value || ''; this._text = value; this.$text.clearChild().addChild(VCore_({ text: value })); var width = 30 * fontSize / 14 + measureArial14TextWidth(value); this.$hitbox.attr('width', 30 * fontSize / 14 + measureArial14TextWidth(value)); this.box.width = width; this.box.height = Math.ceil(24 * fontSize / 14); }, get: function get() { return this._text; } }, color: { set: function set(value) { this._color = value; if (this.typeHandlers[this._noteType + ''] && this.$type) { this.typeHandlers[this._noteType + ''].color.call(this, value.toString()); } }, /** * @this {KeyNote} * @returns {*} */ get: function get() { return this._color; } }, key: { set: function set(value) { this.attr('data-key', value + ''); }, get: function get() { return this.attr('data-key'); } } }; src_VCore.install(KeyNote); /* harmony default export */ const src_KeyNote = (KeyNote); /** * @extends GContainer * @constructor */ function KeyNoteGroup() { this.extendStyle = {}; /** * * @type {KeyNote[]} */ this.$items = []; /** * * @type {KeyNoteItem[]} * @private */ this._items = []; /** * @type {KeyNoteItem[]} * @name items * @memberof KeyNoteGroup# */ } KeyNoteGroup.tag = 'KeyNodeGroup'.toLowerCase(); KeyNoteGroup.render = function () { return VCore_({ tag: svg_GContainer }); }; KeyNoteGroup.prototype.updateSize = function () { var maxWidth = this.$items.reduce(function (ac, it) { return Math.max(ac, it.box.width); }, 0); maxWidth = Math.ceil(maxWidth) + 20; var col = Math.floor(this.box.width / maxWidth) || 1; var y = 0; var itemElt; var height = 0; for (var i = 0; i < this.$items.length; ++i) { itemElt = this.$items[i]; itemElt.box.position = { x: maxWidth * (i % col), y: y }; height = y + itemElt.box.height; if ((i + 1) % col === 0) { y += itemElt.box.height * 1.5; } } this.box.height = height; }; // // KeyNoteGroup.prototype.styleHandlers = {}; // // KeyNoteGroup.prototype.styleHandlers.width = function (value) { // console.log(value) // }; // // // KeyNoteGroup.prototype.addStyle = function (arg0, arg1) { // var handler; // if ((typeof arg0 === "string")) { // handler = this.styleHandlers[arg0] || this.styleHandlers[kebabCaseToCamelCase(arg0)] // } // // if (handler) handler.call(this, arg1); // else AElementNS.prototype.addStyle.apply(this, arguments); // return this; // }; // KeyNoteGroup.prototype.removeStyle = function (arg0) { // this.addStyle(arg0, ''); // return this; // }; KeyNoteGroup.property = {}; KeyNoteGroup.property.items = { /** * @this KeyNoteGroup * @param items */ set: function set(items) { items = items || []; this._items = items; this.clearChild(); this.$items = items.map(function (it) { return VCore_({ tag: KeyNote, props: Object.assign({}, it) }); }); this.addChild(this.$items); }, /** * @this KeyNoteGroup */ get: function get() { return this._items; }, configurable: true }; // EXTERNAL MODULE: ./node_modules/absol-acomp/js/Tooltip.js var Tooltip = __webpack_require__(5194); // EXTERNAL MODULE: ./node_modules/absol/src/Code/noop.js var noop = __webpack_require__(1432); // EXTERNAL MODULE: ./node_modules/absol/src/DataStructure/Object.js var DataStructure_Object = __webpack_require__(2722); ;// CONCATENATED MODULE: ./src/BChart.js var BChart_ = src_VCore._; var BChart_$ = src_VCore.$; /** * * @param chartElt * @constructor */ function ChartResizeController(chartElt) { this.chartElt = chartElt; this.ev_click = this.ev_click.bind(this); this.ev_clickOut = this.ev_clickOut.bind(this); this.chartElt.on('click', this.ev_click); } ChartResizeController.prototype.ev_click = function (event) { if (!this.chartElt.resizable) return; this.prepare(); if (this.share.$resizebox.isAttached(this.chartElt)) return; this.share.$resizebox.attachTo(this.chartElt); document.addEventListener('click', this.ev_clickOut); }; ChartResizeController.prototype.ev_clickOut = function (event) { if ((0,EventEmitter/* hitElement */.EY)(this.chartElt, event)) return; if (this.share.$resizebox.isAfterMoving()) return; if (this.share.$resizebox.isAttached(this.chartElt)) this.share.$resizebox.detach(); document.removeEventListener('click', this.ev_clickOut); }; ChartResizeController.prototype.revokeResource = function () { document.removeEventListener('click', this.ev_clickOut); }; ChartResizeController.prototype.share = { /** * @type {ChartResizeBox} */ $resizebox: null }; ChartResizeController.prototype.prepare = function () { if (this.share.$resizebox) return; this.share.$resizebox = ACore/* default._ */.Z._({ tag: src_ChartResizeBox.tag }); }; /** * * @param {BChart|SvgCanvas} elt * @constructor */ function ChartTitleController(elt) { var _this = this; this.elt = elt; Object.keys(this.constructor.prototype).filter(function (key) { return key.startsWith('ev_'); }).forEach(function (key) { return _this[key] = _this[key].bind(_this); }); this.elt.on('mouseover', this.ev_mouseEnter).on('mouseout', this.ev_mouseOut); this.titleElt = null; this.contentElt = ACore/* default._ */.Z._({ tag: 'div', style: { font: '14px Arial' } }).on('mouseover', this.ev_mouseEnter).on('mouseout', this.ev_mouseOut); this.closeTO = -1; this.sessonToken = null; } ChartTitleController.prototype.revokeResource = function () { this.elt.off('mouseover', this.ev_mouseEnter).off('mouseout', this.ev_mouseOut); this.contentElt.off('mouseover', this.ev_mouseEnter).off('mouseout', this.ev_mouseOut); (0,utils.revokeResource)(this.contentElt); delete this.elt; delete this.contentElt; this.revokeResource = (0,noop/* default */.Z)(); }; ChartTitleController.prototype.ev_mouseEnter = function (event) { var _this2 = this; if ((0,EventEmitter/* hitElement */.EY)(this.contentElt, event)) { clearTimeout(this.closeTO); return; } var hasTileElt = this.findTitleElt(event.target); if (hasTileElt) { clearTimeout(this.closeTO); if (hasTileElt !== this.titleElt) { this.titleElt = hasTileElt; this.sessonToken = Tooltip/* default.show */.Z.show(this.titleElt, this.makeTooltipContent(this.titleElt.attr('title'))); } } else { if (this.titleElt) { clearTimeout(this.closeTO); this.closeTO = setTimeout(function () { _this2.titleElt = null; Tooltip/* default.close */.Z.close(_this2.sessonToken); }, 500); } } }; ChartTitleController.prototype.ev_mouseOut = function (event) { var _this3 = this; if (this.titleElt && (event.target === this.titleElt || event.target === this.contentElt || event.target.isDescendantOf && !event.target.isDescendantOf(this.titleElt) && !event.target.isDescendantOf(this.contentElt))) { clearTimeout(this.closeTO); this.closeTO = setTimeout(function () { _this3.titleElt = null; Tooltip/* default.close */.Z.close(_this3.sessonToken); }, 500); } }; ChartTitleController.prototype.makeTooltipContent = function (text) { this.contentElt.clearChild(); return ACore/* default._ */.Z._({ elt: this.contentElt, child: text.split('\n').reduce(function (ac, cr) { ac.push({ text: cr }, 'br'); return ac; }, []) }); }; ChartTitleController.prototype.findTitleElt = function (elt) { while (elt && elt !== this.elt) { if (elt.attr && elt.attr('title')) return elt; elt = elt.parentElement; } return null; }; /*** * @extends SvgCanvas * @constructor */ function BChart() { var _this4 = this; this.resizable = false; this.ready = false; this.contentPadding = 5; this.title = ''; this.domSignal = new DomSignal/* default */.ZP(BChart_$('sattachhook.vc-dom-signal', this)); this.domSignal.on({ updateContent: this.updateContent.bind(this) }); /** * @type {GContainer} */ this.$body = BChart_$('.vc-body', this); /** * @type {GContainer} */ this.$noteCtn = BChart_$('.vc-note-ctn', this); this.domSignal.emit('updateContent'); this.$title = BChart_$('.vc-title', this); this.computedData = { /*** * @type {Array<{color: Color, type: ("stroke"|"rect"), text:string}>} */ notes: [] }; this.resizeCtrl = new ChartResizeController(this); this.titleCtrl = new ChartTitleController(this); if (!this.numberToText) { OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'numberToText', 'numberToString'); } (0,DataStructure_Object/* observePropertyChanges */.U)(this, this.dataKeys, function () { if (_this4.domSignal) _this4.domSignal.emit('updateContent'); }); /** * @name colorScheme * @type {null|number} * @memberof BChart# */ } BChart.tag = 'BChart'.toLowerCase(); BChart.render = function (data, o, dom) { var res = BChart_({ tag: 'svgcanvas', "class": 'vc-chart', child: [{ tag: 'gcontainer', "class": 'vc-body' }, { tag: 'text', "class": 'vc-title', child: { text: '' } }, { tag: 'gcontainer', "class": 'vc-note-ctn' }, 'sattachhook.vc-dom-signal'] }); var colorScheme = o && o.props && o.props.colorScheme; if ((0,utils.isNaturalNumber)(colorScheme)) { colorScheme = Math.max(0, Math.min(SelectColorSchemeMenu/* DEFAULT_CHART_COLOR_SCHEMES.length */.cF.length, colorScheme)); res.attr('data-color-scheme', colorScheme + ''); } return res; }; BChart.prototype.dataKeys = ['title']; BChart.prototype.revokeResource = function () { (0,DataStructure_Object/* unobservePropertyChanges */.i3)(this, this.dataKeys); (0,utils.revokeResource)(this.resizeCtrl); (0,utils.revokeResource)(this.titleCtrl); while (this.lastChild) { (0,utils.revokeResource)(this.lastChild); this.lastChild.remove(); } this.revokeResource = noop/* default */.Z; this.computedData = null; }; BChart.prototype.normalizeData = function () {}; BChart.prototype.computeData = function () { this.computedData.notes = this.computeNotes(); }; BChart.prototype._createNote = function () { var _this5 = this; var thisC = this; this.$noteCtn.clearChild(); this.$notes = this.computedData.notes.map(function (note, idx) { var noteElt = BChart_({ tag: src_KeyNote, props: { color: note.color, text: note.text, noteType: note.type }, attr: { 'data-idx': idx }, on: { mouseenter: function mouseenter(event) { if (_this5.eventHandler['mouseEnterNote']) { _this5.eventHandler['mouseEnterNote'](idx, event); } }, mouseleave: function mouseleave(event) { if (_this5.eventHandler['mouseLeaveNote']) { _this5.eventHandler['mouseLeaveNote'](idx, event); } } } }); thisC.$noteCtn.addChild(noteElt); return noteElt; }); }; BChart.prototype._createTitle = function () { this.$title.firstChild.data = this.title || ''; }; BChart.prototype.createContent = function () { this.ready = true; this._createTitle(); this._createNote(); }; BChart.prototype._updateNotesPosition = function () { var noteBoundWidth = this.$notes.reduce(function (ac, noteElt) { var box = noteElt.getBBox(); return Math.max(ac, box.width); }, 0); var noteCtnMaxWidth = Math.max(this.box.width - this.contentPadding * 2, noteBoundWidth + 1); var x = 0; var y = 0; var pieceElt; for (var i = 0; i < this.$notes.length; ++i) { pieceElt = this.$notes[i]; if (x + noteBoundWidth > noteCtnMaxWidth) { x = 0; y += 20; } pieceElt.box.setPosition(x, y); x += noteBoundWidth + 15; } var noteCtnBound = this.$noteCtn.getBBox(); this.$noteCtn.box.setPosition(this.box.width / 2 - noteCtnBound.width / 2, this.box.height - this.contentPadding - noteCtnBound.height); }; BChart.prototype._updateTitlePosition = function () { this.$title.attr({ x: this.box.width / 2, y: 18 }); }; BChart.prototype.updateBodyPosition = function () { var titleHeight = this.$title.getBBox().height; var top = this.contentPadding; if (titleHeight > 0) top += titleHeight + 10; this.$body.box.setPosition(this.contentPadding, top); this.$body.box.setSize(this.box.width - this.contentPadding * 2, this.$noteCtn.box.y - top - 10); }; BChart.prototype.updateContentPosition = function () { this._updateTitlePosition(); this._updateNotesPosition(); this.updateBodyPosition(); }; /*** * * @returns {{color: Color, text: string, type: ("stroke"|"rect")}[]} */ BChart.prototype.computeNotes = function () { return []; }; BChart.prototype.updateContent = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('updateContent'); return; } this.normalizeData(); this.computeData(); this.createContent(); this.updateContentPosition(); }; BChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); if (!this.ready) return; this.updateContentPosition(); }; BChart.property = {}; BChart.property.canvasWidth = { get: function get() { return this.box.width; }, set: function set(value) { this.addStyle('width', value + 'px'); this.updateSize(); } }; BChart.property.canvasHeight = { get: function get() { return this.box.height; }, set: function set(value) { this.addStyle('height', value + 'px'); this.updateSize(); } }; BChart.property.showInlineValue = { set: function set(value) { if (value) { this.addClass('vc-show-inline-value'); } else { this.removeClass('vc-show-inline-value'); } }, get: function get() { return this.containsClass('vc-show-inline-value'); } }; BChart.property.colorScheme = { set: function set(value) { this.attr('data-color-scheme', value + ''); if (this.isDescendantOf(document.body)) { this.domSignal.emit("updateContent"); } }, get: function get() { var res = this.attr('data-color-scheme'); if (res) res = parseInt(res, 10); if (!(0,utils.isNaturalNumber)(res)) res = null; return res; } }; BChart.eventHandler = {}; src_VCore.install(BChart); /* harmony default export */ const src_BChart = (BChart); // EXTERNAL MODULE: ./node_modules/absol/src/Math/int.js var Math_int = __webpack_require__(7988); ;// CONCATENATED MODULE: ./src/LineChart.js function LineChart() { this.titleCtrl = new ChartTitleController(this); } LineChart.tag = 'LineChart'.toLowerCase(); LineChart.render = function () { return VCore_('basechart', true); }; LineChart.prototype.processMinMax = function () { this.minValue = this.lines.reduce(function (minValue, line) { return line.values.reduce(function (minValue, value) { if (!isNumber(value)) return minValue; return Math.min(minValue, value); }, minValue); }, 1000000000); this.maxValue = this.lines.reduce(function (maxValue, line) { return line.values.reduce(function (maxValue, value) { if (!isNumber(value)) return maxValue; return Math.max(maxValue, value); }, maxValue); }, -1000000000); if (this.minValue > this.maxValue) { this.minValue = 0; this.maxValue = this.minValue + 10; } }; LineChart.prototype._createLineNote = function (name, color) { var res = VCore_('g'); res.$line = hline(0, -5, this.noteLineLength, 'line-chart-line').addStyle('stroke', color).addTo(res); res.$name = helper_text(name, this.noteLineLength + 5, 0).addTo(res); return res; }; LineChart.prototype._createKeyName = function (key) { var res = VCore_('g'); res.$text = helper_text(key, 0, 5).addTo(res); return res; }; LineChart.prototype._createLine = function (line, color) { var res = VCore_({ tag: 'g', style: { fill: color, stroke: color } }); res.$path = VCore_('shape.line-chart-line').addTo(res); res.$plots = line.values.map(function (u, i) { var plot = circle(0, 0, this.plotRadius, 'line-chart-plot').addTo(res); var text = line.texts && line.texts[i]; if (text) plot.attr('title', text); // .on('mouseenter', function (event) { // var text = line.texts && line.texts[i]; // if (!text) return; // // var currentBound = this.getBoundingClientRect(); // // showTooltip(text, (currentBound.left + currentBound.right) / 2, (currentBound.top + currentBound.bottom) / 2).then(function (token) { // this.once('mouseleave', function () { // setTimeout(function () { // closeTooltip(token); // }, 1000); // }); // }.bind(this)); // }); if (line.plotColors && line.plotColors[i]) { plot.addStyle('fill', line.plotColors[i]); } return plot; }.bind(this)); return res; }; LineChart.prototype.initBackComp = function () { this["super"](); this.colors = this.lines.map(function (line, i, arr) { if (line.color) return line.color; return this.colorTable[Math.floor(this.colorTable.length * i / arr.length)]; }.bind(this)); this.$lineNotes = this.lines.map(function (line, i) { return this._createLineNote(line.name, this.colors[i]).addTo(this); }.bind(this)); this.$keyNames = this.keys.map(function (key) { return this._createKeyName(key).addTo(this.$content); }.bind(this)); }; LineChart.prototype.updateBackComp = function () { this["super"](); this.oxyBottom = this.canvasHeight - 25; var lineNoteWidth = this.$lineNotes.reduce(function (lineNoteWidth, $lineNote) { return lineNoteWidth + $lineNote.getBBox().width + 15; }.bind(this), 0); this.$lineNotes.reduce(function (x, $lineNote) { $lineNote.attr('transform', translate(x, this.canvasHeight - 5)); return x + $lineNote.getBBox().width + 15; }.bind(this), (this.canvasWidth - lineNoteWidth) / 2); var maxKeyNameWidth = this.$keyNames.reduce(function (w, $keyName) { return Math.max(w, $keyName.$text.getBBox().width); }, 0); this.oxSegmentLength = this.oxLength / this.keys.length; this.oxContentLength = this.oxLength; if (this.oxSegmentLength < maxKeyNameWidth + this.keyPaddingH * 2) { this.rotateText = true; } else if (this.minOXSegmentLength > this.oxSegmentLength) { this.oxSegmentLength = this.minOXSegmentLength; this.rotateText = true; this.oxContentLength = this.oxSegmentLength * this.keys.length; } if (this.rotateText) { this.$keyNames.forEach(function (e, i) { e.attr('transform', translate((i + 0.5) * this.oxSegmentLength - 5, 12)); e.$text.attr('transform', rotate(45)); }.bind(this)); this.oxyBottom -= maxKeyNameWidth / 1.4 + 12; } else { this.$keyNames.forEach(function (e, i) { e.attr('transform', translate((i + 0.5) * this.oxSegmentLength, 12)); e.$text.attr('text-anchor', 'middle'); }.bind(this)); this.oxyBottom -= 30; } //reupdate because update oxybottom this["super"](); }; LineChart.prototype.initComp = function () { this.$lines = this.lines.map(function (line, i) { return this._createLine(line, this.colors[i]).addTo(this.$content); }.bind(this)); }; LineChart.prototype.updateComp = function () { this.$lines.map(function ($line, i) { var line = this.lines[i]; $line.$plots.forEach(function ($plot, j) { $plot.attr('display'); var value = line.values[j]; if (isNumber(value)) { $plot.attr({ cx: this.oxSegmentLength * (j + 0.5), cy: this.mapOYValue(value) }); } else { $plot.attr('display', 'none'); } }.bind(this)); $line.$path.begin(); line.values.reduce(function (state, value, j) { if (line.length == 1) { if (!isNumber(value)) return 'NOT_START'; var y = this.mapOYValue(value); var x = this.oxSegmentLength * j; $line.$path.moveTo(x, y); x = this.oxSegmentLength * (j + 1); $line.$path.lineTo(x, y); return "IN_LINE"; } if (state == "NOT_START") { if (!isNumber(value)) return 'NOT_START'; var y = this.mapOYValue(value); var x = this.oxSegmentLength * (j + 0.5); $line.$path.moveTo(x, y); return 'IN_LINE'; } else if (state == 'IN_LINE') { if (!isNumber(value)) return 'NOT_START'; var y = this.mapOYValue(value); var x = this.oxSegmentLength * (j + 0.5); $line.$path.lineTo(x, y); return 'IN_LINE'; } return ac; }.bind(this), "NOT_START"); $line.$path.end(); }.bind(this)); }; LineChart.prototype.preInit = function () { this["super"](); this.rotateText = true; this.noteLineLength = 40; this.plotRadius = 6; this.keyPaddingH = 4; this.minOXSegmentLength = 25; this.colorTable = ['#821616', ' #824116', '#826C16', '#6C8216', '#418216', '#168216', '#168241', '#16826C', '#166C82', '#164182', '#161682', '#411682', '#6C1682', '#82166C', '#821641']; this.lines = []; }; src_VCore.install(LineChart); /* harmony default export */ const src_LineChart = (LineChart); /** * @extends SvgCanvas * @constructor */ function LineChart2() { this.titleCtrl = new ChartTitleController(this); this.$title = VCore_$('.vc-title', this); /** * * @type {KeyNoteGroup} */ this.$keyNoteGroup = VCore_$(KeyNoteGroup.tag, this); this.$oyLabelCtn = VCore_$('.vc-oy-label-ctn', this); this.$body = VCore_$('.vc-body', this); this.$keyCtn = VCore_$('.vc-key-ctn', this); this.$oxy = VCore_$('.vc-oxy', this); this.$oxyArrow = VCore_$('.vc-oxy-arrow', this); this.$content = VCore_$('.vc-content', this); this.$valueName = VCore_$('.vc-value-name', this); this.$keyName = VCore_$('.vc-key-name', this); this.$lines = []; this.cpData = { min: 0, max: 1, oyLabelLength: 0, keyNameWidth: 0, valueNameWidth: 0 }; this.$keys = []; /** * @type {{name: string, values: number[], texts: string[], color: string, plotColors: (string|Color)[]}[]} * @name lines * @memberof LineChart2# */ /** * * @type {string[]} * @name keys */ /** * * @type {boolean} * @name zeroOY * @memberof LineChart2# */ /** * * @type {string} * @name keyName * @memberof LineChart2# */ /** * * @type {string} * @name valueName * @memberof LineChart2# */ } LineChart2.tag = 'LineChart2'.toLowerCase(); LineChart2.render = function () { return VCore_({ tag: svg_SvgCanvas, "class": ['vc-chart', 'vc-line-chart'], child: [{ tag: 'text', "class": 'vc-title', child: { text: "" } }, { tag: svg_GContainer, "class": 'vc-body', child: [{ tag: 'path', "class": 'vc-oxy' }, { tag: 'path', "class": 'vc-oxy-arrow' }, { tag: 'text', "class": 'vc-value-name', child: { text: '' } }, { tag: 'text', "class": 'vc-key-name', child: { text: '' } }, { tag: svg_GContainer, "class": 'vc-oy-label-ctn' }, { tag: svg_GContainer, "class": 'vc-key-ctn' }, { tag: svg_GContainer, "class": 'vc-content' }] }, { tag: KeyNoteGroup }] }); }; LineChart2.prototype.colorTable = ['#821616', ' #824116', '#826C16', '#6C8216', '#418216', '#168216', '#168241', '#16826C', '#166C82', '#164182', '#161682', '#411682', '#6C1682', '#82166C', '#821641']; LineChart2.prototype.paddingContent = 5; LineChart2.prototype.plotRadius = 6; LineChart2.prototype.integerOnly = false; LineChart2.prototype.numberToString = function (value) { return (0,Math_int.numberToString)(value); }; LineChart2.prototype.requestUpdate = function () { var _this = this; if (this.pendingUpdate) return; this.pendingUpdate = true; setTimeout(function () { _this.updateContent(); _this.updatePosition(); }); }; LineChart2.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updatePosition(); }; LineChart2.prototype.computeData = function () { var cpData = this.cpData; var lines = this.lines || []; cpData.max = lines.reduce(function (ac, cr) { var values = cr.values || []; return values.reduce(function (ac2, cr2) { return Math.max(ac2, cr2); }, ac); }, this.zeroOY ? 0 : -1000000000); cpData.min = lines.reduce(function (ac, cr) { var values = cr.values || []; return values.reduce(function (ac2, cr2) { return Math.min(ac2, cr2); }, ac); }, this.zeroOY ? 0 : 1000000000); if (cpData.min > cpData.max) { cpData.min = 0; cpData.max = 1; } else if (cpData.min === cpData.max) { cpData.max = cpData.min + 1; } cpData.oyLabelLength = Math.max((cpData.max + '').length, (cpData.min + '').length); cpData.keyNameWidth = 0; if (this.keyName) { cpData.keyNameWidth = TextMeasure/* default.measureWidth */.Z.measureWidth(this.keyName, TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14); } else { cpData.keyNameWidth = 0; } cpData.keyNameWidth = Math.round(cpData.keyNameWidth); if (this.valueName) { cpData.valueNameWidth = TextMeasure/* default.measureWidth */.Z.measureWidth(this.valueName, TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14); } else { cpData.valueNameWidth = 0; } cpData.valueNameWidth = Math.round(cpData.valueNameWidth); }; LineChart2.prototype.makeLine = function (lineData, i) { var _this2 = this; var color = lineData.color || this.colorTable[i % this.colorTable.length]; var lighterColor = Color/* default.parse */.Z.parse(color + ''); var hsla = lighterColor.toHSLA(); hsla[1] += 0.2; hsla[2] += 0.2; if (hsla[1] > 0.8) hsla[1] = 0.8; if (hsla[2] > 1) hsla[2] = 1; lighterColor = Color/* default.fromHSLA */.Z.fromHSLA(hsla[0], hsla[1], hsla[2], 0.3); var values = lineData.values || []; var res = VCore_({ "class": 'vc-line', style: { '--color': color + '', '--lighter-color': lighterColor + '' }, child: [{ tag: 'path', "class": 'vc-line-path' }, { tag: 'path', "class": 'vc-line-hit-path' }] }); var plotEltArr = values.map(function (value, i) { var text = lineData.texts && lineData.texts[i]; var plotColor = null; if (lineData.plotColors && lineData.plotColors.length > 0) { plotColor = lineData.plotColors[i]; } var plotElt = VCore_({ tag: 'circle', "class": 'vc-plot', attr: { r: _this2.plotRadius, cy: 0, cx: 0 } }); if (text) plotElt.attr('title', text); if (plotColor) { plotElt.addStyle('--color', plotColor + ''); } return plotElt; }); res.addChild(plotEltArr); var linePathElt = VCore_$('.vc-line-path', res); var lineHitPathElt = VCore_$('.vc-line-hit-path', res); res.updatePosition = function () { var width = _this2.$body.box.width; var height = _this2.$body.box.height; var nCol = _this2.$keys.length; var turtle = new controller_Turtle(); var value; var x, y; var sm = _this2.cpData.sm; for (var i = 0; i < nCol; ++i) { if (i >= values.length) break; value = values[i]; x = map(i + 0.5, 0, nCol, 0, width); y = map(value, sm.minValue, sm.maxValue, 0, -height); if ((0,utils.isRealNumber)(value)) { plotEltArr[i].removeStyle('display', 'none'); plotEltArr[i].attr({ cx: x, cy: y }); if (i === 0) { turtle.moveTo(x, y); } else { turtle.lineTo(x, y); } } else { plotEltArr[i].addStyle('display', 'none'); } } linePathElt.attr('d', turtle.getPath()); lineHitPathElt.attr('d', turtle.getPath()); }; return res; // color = Color.parse(color); }; LineChart2.prototype.updateNotes = function () { var _this3 = this; var lines = this.lines || []; this.$keyNoteGroup.items = lines.map(function (line, i) { return { noteType: 'line', text: line.name || '', color: line.color || _this3.colorTable[i % _this3.colorTable.length] }; }); }; LineChart2.prototype.updateKeys = function () { var keys = this.keys || []; this.$keys = keys.map(function (key) { return VCore_({ tag: svg_GContainer, "class": 'vc-key', child: { tag: 'text', attr: { x: 0, y: 5, transform: 'rotate(45)' }, child: { text: key || '' } } }); }); this.$keyCtn.clearChild().addChild(this.$keys); }; LineChart2.prototype.updateLines = function () { var _this4 = this; this.$content.clearChild(); var lines = this.lines || []; this.$lines = lines.map(function (line, i) { return _this4.makeLine(line, i); }); this.$content.addChild(this.$lines); }; LineChart2.prototype.updateContent = function () { this.computeData(); this.updateNotes(); this.updateKeys(); this.updateLines(); }; LineChart2.prototype.updateAxisPosition = function () { var turtle = new controller_Turtle(); var width = this.$body.box.width; var height = this.$body.box.height; var cpData = this.cpData; var sm = calBeautySegment(Math.floor(height / 50), cpData.min, cpData.max, this.integerOnly); this.$valueName.attr({ x: -10, y: -height - 15 }); this.$keyName.attr({ x: width + 5 + cpData.keyNameWidth, y: -10 }); cpData.sm = sm; turtle.moveTo(0, -height - 10).vLineBy(height + 10).hLineBy(width + 10); var i; for (i = 1; i <= sm.segmentCount; ++i) { turtle.moveTo(-2, map(i, 0, sm.segmentCount, 0, -height)); turtle.hLineBy(4); } this.$oxy.attr('d', turtle.getPath()); turtle = new controller_Turtle(); turtle.moveTo(0, -height - 12).lineBy(-6, 6).hLineBy(12).closePath().moveTo(width + 12, 0).lineBy(-6, -6).vLineBy(12).closePath(); this.$oxyArrow.attr('d', turtle.getPath()); var nOyLb = sm.segmentCount + 1; while (this.$oyLabelCtn.childNodes.length > nOyLb) { this.$oyLabelCtn.lastChild.remove(); } while (this.$oyLabelCtn.childNodes.length < nOyLb) { this.$oyLabelCtn.addChild(VCore_({ tag: 'text', "class": 'vc-oy-value', attr: { x: -10, y: 0 }, child: { text: '' } })); } var elt; for (i = 0; i < nOyLb; ++i) { elt = this.$oyLabelCtn.childNodes[i]; elt.firstChild.data = this.numberToString(sm.minValue + sm.step * i); elt.attr('y', map(i, 0, sm.segmentCount, 0, -height) + 5); } }; LineChart2.prototype.updateKeysPosition = function () { var width = this.$body.box.width; this.$keys.forEach(function (elt, i, arr) { elt.box.x = map(i + 0.5, 0, arr.length, 0, width); }); }; LineChart2.prototype.updatePosition = function () { if (!this.box.width || !this.box.height) return; if (!this.isDescendantOf(document.body)) return; if (this.pendingUpdate) this.updateContent(); var width = this.box.width; var height = this.box.height; var cpData = this.cpData; this.$title.attr({ x: width / 2, y: this.paddingContent + 17 }); this.$keyNoteGroup.box.width = width - this.paddingContent * 2; this.$keyNoteGroup.updateSize(); this.$keyNoteGroup.box.x = width / 2 - this.$keyNoteGroup.getBBox().width / 2; this.$keyNoteGroup.box.y = height - this.paddingContent - (this.$keyNoteGroup.box.height || 0); this.$keyCtn.box.y = 20; var textYWidth = TextMeasure/* default.measureWidth */.Z.measureWidth('0'.repeat(cpData.oyLabelLength), TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14); if (this.valueName) { textYWidth = Math.max(textYWidth, cpData.valueNameWidth); } this.$body.box.x = textYWidth + this.paddingContent + 10; this.$body.box.width = width - this.$body.box.x - cpData.keyNameWidth - this.paddingContent - 12; if (this.$body.box.width / (this.$keys.length || 1) > 20) { this.removeClass('vc-small-col'); this.$keyCtn.box.height = this.$keyCtn.getBBox().height; } else { this.addClass('vc-small-col'); this.$keyCtn.box.height = 0; } this.$body.box.y = this.$keyNoteGroup.box.y - this.$keyCtn.box.height - 20; this.$body.box.height = this.$body.box.y - this.paddingContent - 20 - 10 - 20 - 10; this.updateAxisPosition(); this.updateKeysPosition(); this.$lines.forEach(function (lineElt) { lineElt.updatePosition(); }); }; LineChart2.property = {}; LineChart2.property.lines = { set: function set(lines) { lines = lines || []; this._lines = lines; this.requestUpdate(); }, get: function get() { return this._lines; } }; //adapt old LineChart2.property.canvasWidth = { set: function set(value) { if ((0,utils.isRealNumber)(value)) { this.addStyle('width', value + 'px'); } else if (typeof value === "string") { this.addStyle('width', value); } }, get: function get() { var value = this.style.width + ''; if (value.endsWith('px')) value = parseFloat(value.replace('px', '')); return value || 0; } }; LineChart2.property.canvasHeight = { set: function set(value) { if ((0,utils.isRealNumber)(value)) { this.addStyle('height', value + 'px'); } else if (typeof value === "string") { this.addStyle('height', value); } }, get: function get() { var value = this.style.height + ''; if (value.endsWith('px')) value = parseFloat(value.replace('px', '')); return value || 0; } }; LineChart2.property.title = { set: function set(value) { value = (value || '') + ''; this.$title.firstChild.data = value; }, get: function get() { return this.$title.firstChild.data; } }; LineChart2.property.valueName = { set: function set(value) { this.$valueName.firstChild.data = (value || '') + ''; }, get: function get() { return this.$valueName.firstChild.data; } }; LineChart2.property.keyName = { set: function set(value) { this.$keyName.firstChild.data = (value || '') + ''; }, get: function get() { return this.$keyName.firstChild.data; } }; src_VCore.install(LineChart2); ;// CONCATENATED MODULE: ./src/DualChart.js var DualChart_ = src_VCore._; var DualChart_$ = src_VCore.$; function DualChart() { this.titleCtrl = new ChartTitleController(this); } DualChart.tag = 'DualChart'.toLowerCase(); DualChart.render = function () { return DualChart_('basechart.dualchart', true); }; DualChart.prototype.processMinMax = function () { this.minValue = this.lines.reduce(function (minValue, line) { return line.values.reduce(function (minValue, value) { if (!isNumber(value)) return minValue; return Math.min(minValue, value); }, minValue); }, 1000000000); this.minValue = this.areas.reduce(function (minValue, area) { return area.values.reduce(function (minValue, value) { if (!isNumber(value)) return minValue; return Math.min(minValue, value); }, minValue); }, this.minValue); this.maxValue = this.lines.reduce(function (maxValue, line) { return line.values.reduce(function (maxValue, value) { if (!isNumber(value)) return maxValue; return Math.max(maxValue, value); }, maxValue); }, -1000000000); this.maxValue = this.areas.reduce(function (maxValue, area) { return area.values.reduce(function (maxValue, value) { if (!isNumber(value)) return maxValue; return Math.max(maxValue, value); }, maxValue); }, this.maxValue); if (this.minValue > this.maxValue) { this.minValue = 0; this.maxValue = this.minValue + 10; } }; DualChart.prototype._createArea = function (area, color) { var res = DualChart_({ tag: 'shape', "class": 'dualchart-area', style: { fill: color, stroke: color } }); return res; }; DualChart.prototype._createAreaNote = function (area, color) { var res = DualChart_({ tag: 'g' }); res.$rect = rect(0, -14, 14, 14, 'dualchart-note-rect').addTo(res); if (color) { res.$rect.addStyle('fill', color); } res.$name = helper_text(area.name, 17, 0, 'dualchart-note-text').addTo(res); return res; }; DualChart.prototype.initBackComp = function () { this["super"](); this.noteLineLength = 14; this.colors = this.lines.concat(this.areas).map(function (items, i, arr) { if (items.color) return items.color; return i < this.lines.length ? this.colorTable[Math.floor(this.colorTable.length * i / arr.length)] : this.colorTable[Math.floor(this.colorTable.length * i / arr.length)].replace(/#/, '#80'); }.bind(this)); this.$lineNotes = this.lines.map(function (line, i) { return this._createLineNote(line.name, this.colors[i]).addTo(this); }.bind(this)); this.$arealNotes = this.areas.map(function (area, i) { return this._createAreaNote(area, this.colors[i + this.lines.length]).addTo(this); }.bind(this)); this.$keyNames = this.keys.map(function (key) { return this._createKeyName(key).addTo(this.$content); }.bind(this)); }; DualChart.prototype.updateBackComp = function () { this["super"](); this.oxyBottom = this.canvasHeight - 5; var $notes = this.$lineNotes.concat(this.$arealNotes); var notesWidth = $notes.reduce(function (noteWidth, $lineNote) { return noteWidth + $lineNote.getBBox().width + 15; }.bind(this), 0); if (notesWidth >= this.canvasWidth) { var maxNoteWidth = $notes.reduce(function (maxNoteWidth, $lineNote) { return Math.max(maxNoteWidth, $lineNote.getBBox().width + 10); }.bind(this), 0); var notePerLine = Math.max(1, Math.floor(this.canvasWidth / maxNoteWidth)); var x0 = (this.canvasWidth - notePerLine * maxNoteWidth) / 2 + 5; var y0 = this.canvasHeight - 5; $notes.forEach(function ($note, i) { $note.attr('transform', translate(x0 + maxNoteWidth * (i % notePerLine), y0)); if (i % notePerLine == notePerLine - 1) y0 -= 20; this.oxyBottom -= 20; }.bind(this)); } else { $notes.reduce(function (x, $line) { $line.attr('transform', translate(x, this.canvasHeight - 5)); return x + $line.getBBox().width + 15; }.bind(this), (this.canvasWidth - notesWidth) / 2); this.oxyBottom -= 20; } var maxKeyNameWidth = this.$keyNames.reduce(function (w, $keyName) { return Math.max(w, $keyName.$text.getBBox().width); }, 0); this.oxSegmentLength = this.oxLength / this.keys.length; this.oxContentLength = this.oxLength; if (this.oxSegmentLength < maxKeyNameWidth + this.keyPaddingH * 2) { this.rotateText = true; } else if (this.minOXSegmentLength > this.oxSegmentLength) { this.oxSegmentLength = this.minOXSegmentLength; this.rotateText = true; this.oxContentLength = this.oxSegmentLength * this.keys.length; } if (this.rotateText) { this.$keyNames.forEach(function (e, i) { e.attr('transform', translate((i + 0.5) * this.oxSegmentLength - 5, 12)); e.$text.attr('transform', rotate(45)); }.bind(this)); this.oxyBottom -= maxKeyNameWidth / 1.4 + 12; } else { this.$keyNames.forEach(function (e, i) { e.attr('transform', translate((i + 0.5) * this.oxSegmentLength, 12)); e.$text.attr('text-anchor', 'middle'); }.bind(this)); this.oxyBottom -= 30; } //reupdate because update oxybottom this["super"](); }; DualChart.prototype.initComp = function () { this.$areas = this.areas.map(function (line, i) { return this._createArea(line, this.colors[i + this.lines.length]).addTo(this.$content); }.bind(this)); this.$lines = this.lines.map(function (line, i) { return this._createLine(line, this.colors[i]).addTo(this.$content); }.bind(this)); }; DualChart.prototype.updateComp = function () { this.updateLine(); this.updateArea(); }; DualChart.prototype.updateLine = function () { this.$lines.map(function ($line, i) { var line = this.lines[i]; var subLines = getSubNumberArray(line.values); $line.$path.begin(); subLines.forEach(function (subLine, j) { var start = subLine.start; var values = subLine.values; if (values.length > 1) { $line.$path.moveTo(this.oxSegmentLength * (start + 0.5), this.mapOYValue(values[0])); for (var xi = 1; xi < values.length; ++xi) { $line.$path.lineTo(this.oxSegmentLength * (start + xi + 0.5), this.mapOYValue(values[xi])); } } else { $line.$path.moveTo(this.oxSegmentLength * (start + 0.25), this.mapOYValue(values[0])); $line.$path.lineTo(this.oxSegmentLength * (start + 0.75), this.mapOYValue(values[0])); } }.bind(this)); $line.$path.end(); $line.$plots.forEach(function ($plot, j) { $plot.attr('display'); var value = line.values[j]; if (isNumber(value)) { $plot.attr({ display: undefined, cx: this.oxSegmentLength * (j + 0.5), cy: this.mapOYValue(value) }); } else $plot.attr('display', 'none'); }.bind(this)); $line.$path.end(); }.bind(this)); }; DualChart.prototype.updateArea = function () { this.$areas.map(function ($area, i) { var values = this.areas[i].values; var subAreas = getSubNumberArray(values); $area.begin(); subAreas.forEach(function (subArea) { var start = subArea.start; var values = subArea.values; if (values.length > 1) { $area.moveTo(this.oxSegmentLength * (start + 0.5), -1); for (var xi = 0; xi < values.length; ++xi) { $area.lineTo(this.oxSegmentLength * (start + xi + 0.5), this.mapOYValue(values[xi])); } $area.lineTo(this.oxSegmentLength * (start + values.length - 1 + 0.5), -1); $area.closePath(); } else { $area.moveTo(this.oxSegmentLength * (start + 0.25), -1); $area.lineTo(this.oxSegmentLength * (start + 0.25), this.mapOYValue(values[0])); $area.lineTo(this.oxSegmentLength * (start + 0.75), this.mapOYValue(values[0])); $area.lineTo(this.oxSegmentLength * (start + 0.75), -1); $area.closePath(); } }.bind(this)); // $area // .moveTo(this.oxSegmentLength * (values.length - (this.keys.length == 1 ? 0.25 : 0.5)), -1) // .lineTo(this.oxSegmentLength * (this.keys.length == 1 ? 0.25 : 0.5), -1); // if (this.keys.length == 1) { // $area.lineTo(this.oxSegmentLength * 0.25, isNumber(values[0]) ? this.mapOYValue(values[0]) : 0); // } // for (var i = 0; i < values.length; ++i) { // $area.lineTo(this.oxSegmentLength * (i + 0.5), isNumber(values[i]) ? this.mapOYValue(values[i]) : 0); // } // if (this.keys.length == 1) { // $area.lineTo(this.oxSegmentLength * 0.75, isNumber(values[0]) ? this.mapOYValue(values[0]) : 0); // } // $area.closePath().end(); $area.end(); }.bind(this)); }; Object.keys(src_LineChart.prototype).filter(function (key) { return !DualChart.prototype[key]; }).forEach(function (key) { DualChart.prototype[key] = src_LineChart.prototype[key]; }); src_VCore.creator.dualchart = DualChart; /* harmony default export */ const src_DualChart = (DualChart); ;// CONCATENATED MODULE: ./src/VerticalChart.js var VerticalChart_ = src_VCore._; var VerticalChart_$ = src_VCore.$; /** * @extends BChart * @constructor */ function VerticalChart() { src_BChart.call(this); this.oxColMargin = 10; this.oxColWidth = 17; this.computedData.min = 0; this.computedData.max = 10; this.computedData.paddingAxisBottom = 0; this.computedData.oyUpdated = false; this.computedData.oy = {}; this.computedData.numberToFixed = 0; this.integerOnly = false; this.zeroOY = false; this.valueName = ''; this.keyName = ''; this.numberToString = this.numberToString || null; /** * * @type {string[]} */ this.keys = []; this.$oxLabelCtn = VerticalChart_('gcontainer.vc-ox-label-ctn'); this.$oyValueCtn = VerticalChart_('gcontainer.vc-oy-value-ctn'); this.$axisCtn = VerticalChart_('gcontainer.vc-axis-ctn'); this.$whiteMask = VerticalChart_({ tag: 'path', "class": 'vc-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,0 0,200 200,200 200,0z' } }); /** * * @type {Axis} */ this.$axis = VerticalChart_('axis'); this.$oxySpace = VerticalChart_('gcontainer.vc-oxy-space'); /*** * * @type {HSC} */ this.$hscrollbar = VerticalChart_('hscrollbar').on('scroll', this.eventHandler.scrollOxySpace); this.$scrollArrow = VerticalChart_('scrollarrow').on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); this.$scrollArrow.box.x = 10; this.$hscrollbar.height = 12; this.$valueName = VerticalChart_({ tag: 'text', "class": 'vc-value-name', attr: { y: 14, x: 5 }, child: { text: '' } }); this.$keyName = VerticalChart_({ tag: 'text', "class": 'vc-key-name', attr: { y: 14, x: 5 }, child: { text: '' } }); this.$oxySpace.addChild(this.$oxLabelCtn); this.$axisCtn.addChild(this.$oxySpace); this.$axisCtn.addChild(this.$whiteMask); this.$axisCtn.addChild(this.$axis); this.$axisCtn.addChild(this.$hscrollbar); this.$axisCtn.addChild(this.$scrollArrow); this.$axisCtn.addChild(this.$valueName); this.$axisCtn.addChild(this.$keyName); this.$oxLabels = []; this.$oyValues = []; this.$body.addChild(this.$axisCtn); this.$body.addChild(this.$oyValueCtn); } OOP/* default.mixClass */.ZP.mixClass(VerticalChart, src_BChart); VerticalChart.property = Object.assign({}, src_BChart.property); VerticalChart.eventHandler = Object.assign({}, src_BChart.eventHandler); VerticalChart.tag = 'VerticalChart'.toLowerCase(); VerticalChart.prototype.dataKeys = src_BChart.prototype.dataKeys.concat(['keys', 'zeroOY']); VerticalChart.render = function () { return src_BChart.render(); }; VerticalChart.prototype.computeMinMax = function () { this.computedData.min = 0; this.computedData.max = 10; }; /*** * * @param {Number}number * @returns {string} */ VerticalChart.prototype.numberToText = function (number) { return this.numberToString ? this.numberToString(number) : number.toFixed(this.computedData.numberToFixed); }; VerticalChart.prototype.computeData = function () { src_BChart.prototype.computeData.call(this); this.computeMinMax(); if (this.computedData.min >= this.computedData.max) { this.computedData.min = 0; this.computedData.max = 10; } if (this.computedData.min === this.computedData.max) { this.computedData.max += 1; } if (this.zeroOY) this.computedData.min = Math.min(this.computedData.min, 0); }; VerticalChart.prototype.mapOYValue = function (val) { return map(val, this.computedData.oy.minValue, this.computedData.oy.maxValue, 0, this.computedData.oyLength); }; VerticalChart.prototype._computeOYSegment = function () { var oyLength = this.$body.box.height - 20 - 10 - this.computedData.paddingAxisBottom; var valueNameHeight = this.$valueName.getBBox().height; if (valueNameHeight > 0) { oyLength -= valueNameHeight + 5; } var segment = calBeautySegment(Math.floor(oyLength / 30), this.computedData.min, this.computedData.max, this.integerOnly); if (segment && segment.segmentCount < 30 && segment.segmentCount >= 1) { if (segment.step !== this.computedData.oy.step || segment.segmentCount !== this.computedData.oy.segmentCount || segment.maxValue !== this.computedData.oy.maxValue || segment.minValue !== this.computedData.oy.minValue) { this.computedData.oy = segment; this.computedData.oyUpdated = false; this.computedData.numberToFixed = 0; if (segment.step < 1) this.computedData.numberToFixed++; if (segment.step < 0.1) this.computedData.numberToFixed++; if (segment.step < 0.01) this.computedData.numberToFixed++; if (segment.step < 0.001) this.computedData.numberToFixed++; if (segment.step < 0.0001) this.computedData.numberToFixed++; } } this.computedData.oyLength = oyLength; this.computedData.oySegmentLength = oyLength / segment.segmentCount; }; VerticalChart.prototype._createOxLabel = function () { var thisC = this; this.$oxLabelCtn.clearChild(); this.$oxLabels = this.keys.map(function (key) { var labelElt = VerticalChart_({ tag: 'text', "class": 'vc-ox-label', attr: { y: 15 }, child: { text: key } }); thisC.$oxLabelCtn.addChild(labelElt); return labelElt; }); this.computedData.oxLabelMaxWidth = this.$oxLabels.reduce(function (ac, elt) { return Math.max(ac, elt.getBBox().width); }, 0); this.$valueName.firstChild.data = this.valueName || ''; this.$keyName.firstChild.data = this.keyName || ''; }; VerticalChart.prototype._createOyValue = function () { this.computedData.oyUpdated = true; var segment = this.computedData.oy; var textElt; while (this.$oyValues.length < segment.segmentCount + 1) { textElt = VerticalChart_({ tag: 'text', "class": 'vc-oy-value', child: { text: '0' } }); this.$oyValues.push(textElt); this.$oyValueCtn.addChild(textElt); } while (this.$oyValues.length > segment.segmentCount + 1) { textElt = this.$oyValues.pop(); textElt.remove(); } for (var i = 0; i < this.$oyValues.length; ++i) { this.$oyValues[i].firstChild.data = this.numberToText(segment.minValue + i * segment.step); } }; VerticalChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createOxLabel(); }; VerticalChart.prototype._updateLabelPosition = function () { this.$oxLabelCtn.box.y = this.$body.box.height = 15; }; VerticalChart.prototype._updateOYValuePosition = function () { this._computeOYSegment(); if (!this.computedData.oyUpdated) { this._createOyValue(); } var y = this.$body.box.height - 20 + 6 - this.computedData.paddingAxisBottom; var valueElt; for (var i = 0; i < this.$oyValues.length; ++i) { valueElt = this.$oyValues[i]; valueElt.attr({ y: y, x: -10 }); y -= this.computedData.oySegmentLength; } var box = this.$oyValueCtn.getBBox(); this.$oyValueCtn.box.x = Math.max(box.width + 10, this.$valueName.getBBox().width - 5); }; VerticalChart.prototype.updateAxis = function () { var valueNameBox = this.$valueName.getBBox(); var valueNameHeight = valueNameBox.height; var keyNameWidth = this.$keyName.getBBox().width; this.$axisCtn.box.setPosition(this.$oyValueCtn.box.x, 0); this.$axisCtn.box.setSize(this.$body.box.width - this.$oyValueCtn.box.x, this.$body.box.height - 20); this.$keyName.attr({ y: this.$axisCtn.box.height - 10, x: this.$axisCtn.box.width }); this.$whiteMask.attr('d', 'M-300 -300 H' + (this.$axisCtn.box.width + 100) + ' V' + (this.$axisCtn.box.height + 600) + 'H -300z' + 'M0 0 H ' + (this.$axisCtn.box.width - keyNameWidth) + ' V ' + (this.$axisCtn.box.height + 300) + ' H 0z'); this.$axis.box.setPosition(0, this.$axisCtn.box.height); this.$axis.resize(this.$axisCtn.box.width - 8, this.$axisCtn.box.height - 5 - (valueNameHeight > 0 ? valueNameHeight + 5 : 0)); this.$oxySpace.box.setPosition(0, this.$axisCtn.box.height); this.computedData.oxLength = this.$axisCtn.box.width - 1 - keyNameWidth; this.computedData.oyLength = this.$axisCtn.box.height - 15 - (valueNameHeight > 0 ? valueNameHeight + 5 : 0) - this.computedData.paddingAxisBottom; this.$hscrollbar.box.y = this.$axisCtn.box.height - this.$hscrollbar.height; if (!this.style.getPropertyValue('--vc-require-width')) { this.addStyle('--vc-require-width', this.$axisCtn.box.x + this.contentPadding + this.$keyName.getBBox().width + 50 + 'px'); this.addStyle('--vc-require-height', this.box.height - this.$axisCtn.box.height + this.contentPadding * 2 + +this.computedData.paddingAxisBottom + this.$title.getBBox().height + 60 + 'px'); } }; VerticalChart.prototype._updateOxLabelPosition = function () { this.computedData.oxSegmentLength = this.computedData.oxLength / this.$oxLabels.length; this.computedData.oxSegmentLength = Math.max(this.oxColMargin + Math.max(this.oxColWidth, this.computedData.oxLabelMaxWidth), this.computedData.oxSegmentLength); var dx = this.computedData.oxSegmentLength; var x = this.computedData.oxSegmentLength / 2; for (var i = 0; i < this.$oxLabels.length; ++i) { this.$oxLabels[i].attr('x', x); x += dx; } this.computedData.oxScrollWidth = dx * this.$oxLabels.length - 1; this.computedData.oxOverFlow = this.computedData.oxScrollWidth > this.computedData.oxLength; this.$hscrollbar.outterWidth = this.computedData.oxLength; this.$hscrollbar.innerWidth = this.computedData.oxScrollWidth; this.$hscrollbar.width = this.computedData.oxLength; this.$hscrollbar.scrollLeft = Math.max(0, Math.min(this.$hscrollbar.scrollLeft, this.computedData.oxScrollWidth - this.computedData.oxLength)); this.$oxySpace.box.x = -this.$hscrollbar.scrollLeft; if (this.computedData.oxOverFlow) { this.$scrollArrow.removeStyle('display'); this.$scrollArrow.box.y = this.computedData.oyLength / 2; this.$scrollArrow.width = this.computedData.oxLength - 20; this._updateScrollArrowBtb(); } else { this.$scrollArrow.addStyle('display', 'none'); } this.$axis.oyDivision = this.computedData.oySegmentLength; this.$axis.updateOyDivision(); }; VerticalChart.prototype._updateScrollArrowBtb = function () { if (this.$hscrollbar.scrollLeft <= 0) { this.$scrollArrow.$left.addStyle('display', 'none'); } else { this.$scrollArrow.$left.removeStyle('display'); } if (this.$hscrollbar.scrollLeft >= this.$hscrollbar.innerWidth - this.$hscrollbar.outterWidth) { this.$scrollArrow.$right.addStyle('display', 'none'); } else { this.$scrollArrow.$right.removeStyle('display'); } }; VerticalChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updateOYValuePosition(); this.updateAxis(); this._updateOxLabelPosition(); }; VerticalChart.eventHandler.scrollOxySpace = function () { this.$oxySpace.box.x = -this.$hscrollbar.scrollLeft; this._updateScrollArrowBtb(); }; VerticalChart.eventHandler.scrollArrowsPressLeft = function () { this.$hscrollbar.scrollLeft -= 10; this.eventHandler.scrollOxySpace(); }; VerticalChart.eventHandler.scrollArrowsPressRight = function () { this.$hscrollbar.scrollLeft += 10; this.eventHandler.scrollOxySpace(); }; src_VCore.install(VerticalChart); /* harmony default export */ const src_VerticalChart = (VerticalChart); ;// CONCATENATED MODULE: ./src/RangeChart.js var RangeChart_ = src_VCore._; var RangeChart_$ = src_VCore.$; /*** * @extends BChart * @constructor */ function RangeChart() { /** default config**/ this.valuePlotRadius = 10; this.minKeyWidth = 90; this.maxKeyWidthRatio = 1.5; this.limitLineLength = 40; this.lineHeight = 22; src_BChart.call(this); this.contentPadding = 0; /** data **/ this.integerOnly = false; this.zeroOY = false; this.ranges = []; this.valueName = ''; this.keyName = ''; this.maxText = 'Maximum'; this.minText = 'Minimum'; this.midText = 'Median'; this.normalText = 'Normal'; this.numberToString = this.numberToString || null; this.createStatic(); this.$oyValueCtn = RangeChart_$('gcontainer.vc-oy-value-ctn', this); this.$rangeCtn = RangeChart_$('.vc-range-ctn', this); this.$whiteMask = RangeChart_$('.vc-white-mask', this); this.$axisCtn = RangeChart_$('gcontainer.vc-axis-ctn', this); this.$axis = RangeChart_$('axis', this); this.$oxTable = RangeChart_$('gcontainer.vc-ox-table', this); this.$oxLabelCtn = RangeChart_$('gcontainer.vc-ox-label-ctn', this); this.$oxValueCtn = RangeChart_$('gcontainer.vc-ox-value-ctn', this); this.$valueName = RangeChart_$('text.vc-value-name', this); this.$keyName = RangeChart_$('text.vc-key-name', this); this.$oxySpace = RangeChart_$('.vc-oxy-space', this); this.$oyValues = []; /*** * * @type {ScrollArrow} */ this.$scrollArrow = RangeChart_$('scrollarrow', this).on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); this.$hscrollbar = RangeChart_$('hscrollbar', this).on('scroll', this.eventHandler.scrollOxySpace); this.$hscrollbar.height = 12; this.$hscrollbar.box.y = -11; this.sync = new Promise(function (resolve) { this.$attachhook.once('attached', resolve); }.bind(this)); } OOP/* default.mixClass */.ZP.mixClass(RangeChart, src_BChart); RangeChart.property = Object.assign({}, src_VerticalChart.property); RangeChart.eventHandler = Object.assign({}, src_VerticalChart.eventHandler); RangeChart.tag = 'RangeChart'.toLowerCase(); RangeChart.render = function () { return src_BChart.render().addClass('range-chart').addClass('vc-range-chart'); }; RangeChart.prototype.createStatic = function () { RangeChart_({ elt: this.$body, child: [{ tag: 'gcontainer', "class": 'vc-axis-ctn', child: [{ tag: 'gcontainer', "class": 'vc-oxy-space', child: [{ tag: 'gcontainer', "class": 'vc-ox-table', child: ['gcontainer.vc-ox-label-ctn', 'gcontainer.vc-ox-value-ctn'] }, { tag: 'gcontainer', "class": 'vc-range-ctn' }] }, { tag: 'path', "class": 'vc-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,0 0,200 200,200 200,0z' } }, 'gcontainer.vc-oy-value-ctn', 'axis', { tag: 'text', "class": 'vc-value-name', attr: { y: 14, x: 5 }, child: { text: '' } }, { tag: 'text', "class": 'vc-key-name', attr: { y: 14, x: 5 }, child: { text: '' } }, 'scrollarrow', 'hscrollbar'] }] }); }; RangeChart.prototype.normalizeData = function () { this.ranges.some(function (range) { if (isNumber(range.min) && isNumber(range.max)) { if (range.min > range.max) { console.error(range, "Violation: min > max"); return true; } else { if (isNumber(range.mid)) { if (range.mid < range.min || range.mid > range.max) { console.error(range, "Violation: mid < min or mid > max"); return true; } } } } return false; }); }; RangeChart.prototype.computeData = function () { // this.computedData this.computedData.hasMidValue = this.ranges.some(function (range) { return isNumber(range.mid); }); this.computedData.hasNormalValue = this.ranges.some(function (range) { return isNumber(range.normal); }); this.computedData.max = this.ranges.reduce(function (ac, range) { if (isNumber(range.max)) ac = Math.max(ac, range.max); if (isNumber(range.mid)) ac = Math.max(ac, range.mid); if (isNumber(range.min)) ac = Math.max(ac, range.min); if (isNumber(range.normal)) ac = Math.max(ac, range.normal); return ac; }, -Infinity); this.computedData.min = this.ranges.reduce(function (ac, range) { if (isNumber(range.max)) ac = Math.min(ac, range.max); if (isNumber(range.mid)) ac = Math.min(ac, range.mid); if (isNumber(range.min)) ac = Math.min(ac, range.min); if (isNumber(range.normal)) ac = Math.min(ac, range.normal); return ac; }, Infinity); if (this.computedData.min > this.computedData.max) { this.computedData.min = 0; this.computedData.max = 10; } if (this.zeroOY) { this.computedData.min = 0; } if (this.computedData.min === this.computedData.max) { this.computedData.max += 1; } }; RangeChart.prototype.mapOYValue = src_VerticalChart.prototype.mapOYValue; RangeChart.prototype._computeOYSegment = function () { var res = false; var segment = calBeautySegment(Math.floor(this.$axisCtn.box.height / 50), this.computedData.min, this.computedData.max, this.integerOnly); if (segment && segment.segmentCount < 30) { //error if (!this.computedData.oy || segment.step !== this.computedData.oy.step || segment.segmentCount !== this.computedData.oy.segmentCount || segment.maxValue !== this.computedData.oy.maxValue || segment.minValue !== this.computedData.oy.minValue) { this.computedData.oy = segment; this.computedData.oyUpdated = false; this.computedData.numberToFixed = 0; if (segment.step < 1) this.computedData.numberToFixed++; if (segment.step < 0.1) this.computedData.numberToFixed++; if (segment.step < 0.01) this.computedData.numberToFixed++; if (segment.step < 0.001) this.computedData.numberToFixed++; if (segment.step < 0.0001) this.computedData.numberToFixed++; res = true; } } this.computedData.oySegmentLength = this.$axisCtn.box.height / segment.segmentCount; return res; }; RangeChart.prototype._createNote = function () { var ctn = this.$noteCtn.clearChild(); var y0 = this.lineHeight / 2 + 1; var labelX = this.limitLineLength + 10; ctn.$maxLine = this._createLimitLine(0, y0, this.limitLineLength, 'max').addTo(ctn); ctn.$maxText = helper_text(this.maxText, labelX, y0 + 5).addTo(ctn); y0 += this.lineHeight; if (this.computedData.hasMidValue) { this._createLimitLine(0, y0, this.limitLineLength, 'mid').addTo(ctn); helper_text(this.midText, labelX, y0 + 5).addTo(ctn); y0 += this.lineHeight; } ctn.$minLine = this._createLimitLine(0, y0, this.limitLineLength, 'min').addTo(ctn); ctn.$minText = helper_text(this.minText, labelX, y0 + 5).addTo(ctn); if (this.computedData.hasNormalValue) { y0 += this.lineHeight; if (this.ranges[0].normal !== undefined) { circle(this.limitLineLength / 2, y0, this.valuePlotRadius, 'range-chart-value-plot').addTo(ctn); helper_text(this.normalText, labelX, y0 + 5).addTo(ctn); } } y0 += this.lineHeight / 2; ctn.box.setSize(ctn.getBBox().width + 7, y0); }; RangeChart.prototype._updateNotesPosition = function () { var box = this.$noteCtn.box; this.$noteCtn.box.setPosition(this.contentPadding, this.box.height - box.height - this.contentPadding); }; RangeChart.prototype.createOxTable = function () { var thisC = this; this.$oxValueCtn.clearChild(); var hasMidValue = this.computedData.hasMidValue; var hasNormalValue = this.computedData.hasNormalValue; var maxValueWidth = 0; this.$oxRangeCols = this.ranges.map(function (range, i, arr) { var ctn = RangeChart_({ tag: svg_GContainer.tag }); thisC.$oxValueCtn.addChild(ctn); var maxText = '"'; var midText = '"'; var minText = '"'; var normalText = '"'; var y0 = 17; if (isNumber(range.max)) maxText = thisC.numberToText(range.max); ctn.$maxText = RangeChart_({ tag: 'text', attr: { x: 0, y: y0 }, child: { text: maxText } }); ctn.addChild(ctn.$maxText); y0 += thisC.lineHeight; if (hasMidValue) { if (isNumber(range.mid)) midText = thisC.numberToText(range.mid); ctn.$midText = RangeChart_({ tag: 'text', attr: { x: 0, y: y0 }, child: { text: midText } }); ctn.addChild(ctn.$midText); y0 += thisC.lineHeight; } if (isNumber(range.min)) minText = thisC.numberToText(range.min); ctn.$minText = RangeChart_({ tag: 'text', attr: { x: 0, y: y0 }, child: { text: minText } }); ctn.addChild(ctn.$minText); if (hasNormalValue) { y0 += thisC.lineHeight; if (isNumber(range.normal)) normalText = thisC.numberToText(range.normal); ctn.$normalText = RangeChart_({ tag: 'text', attr: { x: 0, y: y0 }, child: { text: normalText } }); ctn.addChild(ctn.$normalText); } y0 += thisC.lineHeight / 2 - 5; var textWidth = ctn.getBBox().width; ctn.box.setSize(textWidth, y0); maxValueWidth = Math.max(maxValueWidth, textWidth); return ctn; }); this.computedData.maxValueWidth = maxValueWidth; if (this.$oxRangeCols.length > 0) this.$oxValueCtn.box.height = this.$oxRangeCols[0].box.height; }; RangeChart.prototype.createOxLabel = function () { var lineHeight = this.lineHeight; var ctn = this.$oxLabelCtn; var keyLimitWidth = Math.max(this.minKeyWidth, this.computedData.maxValueWidth * this.maxKeyWidthRatio); var keyMaxWidth = 0; ctn.clearChild(); this.$oxLabels = this.ranges.map(function (range) { var lines = wrapToLines(range.name, 14, keyLimitWidth); if (lines.length < 2) lines = [];else lines = lines.map(function (line, i) { return { tag: 'text', "class": 'vc-range-chart-label-line', attr: { x: '0', y: 17 + i * lineHeight + '' }, child: { text: line } }; }); var labelBlock = RangeChart_({ tag: svg_GContainer.tag, child: [{ tag: 'text', attr: { x: '0', y: 17 }, "class": lines.length >= 2 ? 'vc-range-chart-label-full' : 'vc-range-chart-label', child: { text: range.name } }].concat(lines) }).addTo(ctn); keyMaxWidth = Math.max(keyMaxWidth, labelBlock.getBBox().width); return labelBlock; }); this.computedData.keyMaxWidth = keyMaxWidth; }; RangeChart.prototype.createAxisName = function () { this.$valueName.firstChild.data = this.valueName; this.computedData.valueNameWidth = this.$valueName.getBBox().width; this.$keyName.firstChild.data = this.keyName; this.computedData.keyNameWidth = this.$keyName.getBBox().width; }; RangeChart.prototype.updateAxisX = function () { this.$axisCtn.box.x = Math.max(this.computedData.valueNameWidth, this.computedData.maxValueWidth + 5, this.$noteCtn.box.width); this.$axisCtn.box.width = this.$body.box.width - this.$axisCtn.box.x - 7 - this.computedData.keyNameWidth; this.$axis.resize(this.$axisCtn.box.width + this.computedData.keyNameWidth, 10); this.$keyName.attr('x', this.$axisCtn.box.width + 7 + this.computedData.keyNameWidth); this.$hscrollbar.width = this.$axisCtn.box.width; this.$hscrollbar.outterWidth = this.$axisCtn.box.width; }; RangeChart.prototype.updateOxTablePosition = function () { var requireMinWidth = (Math.max(this.computedData.keyMaxWidth, this.computedData.maxValueWidth) + 10) * this.ranges.length; var colWidth = Math.max(this.computedData.maxValueWidth + 10, this.$axisCtn.box.width / this.ranges.length); this.computedData.oxLabelWrap = requireMinWidth > this.$axisCtn.box.width; if (this.computedData.oxLabelWrap) { this.addClass('vc-ox-label-wrap'); } else { this.removeClass('vc-ox-label-wrap'); } colWidth = this.$oxLabels.reduce(function (ac, labelBlock) { return Math.max(ac, labelBlock.getBBox().width + 10); }, colWidth); this.$oxLabelCtn.box.height = this.$oxLabelCtn.getBBox().height + 5; this.$oxValueCtn.box.y = this.$oxLabelCtn.box.height; this.$oxValueCtn.box.height = this.$noteCtn.box.height; this.$oxLabels.forEach(function (labelBlock, i) { labelBlock.box.x = colWidth * (i + 0.5); }, 0); this.$oxRangeCols.forEach(function (colElt, i) { colElt.box.x = colWidth * (i + 0.5) + colElt.box.width / 2; }, 0); this.$oxTable.box.width = colWidth * this.ranges.length; this.$oxTable.box.height = this.$oxLabelCtn.box.height + this.$oxValueCtn.box.height; this.$axisCtn.box.y = this.$noteCtn.box.y - this.$body.box.y - this.$oxLabelCtn.box.height; this.$axisCtn.box.height = this.$axisCtn.box.y - 20; this.$scrollArrow.width = this.$axisCtn.box.width - 10; this.$scrollArrow.box.setPosition(5, -this.$axisCtn.box.height / 2); this.computedData.collWidth = colWidth; this.computedData.oyLength = this.$axisCtn.box.height; this.$hscrollbar.innerWidth = this.$oxTable.box.width; this._updateScrollArrowBtb(); if (!this.style.getPropertyValue('--vc-require-width')) { this.addStyle('--vc-require-width', this.$axisCtn.box.x + this.contentPadding + this.$keyName.getBBox().width + 50 + 'px'); this.addStyle('--vc-require-height', this.box.height - this.$axisCtn.box.height + this.contentPadding * 2 + this.$title.getBBox().height + 60 + 'px'); } ; }; RangeChart.prototype.updateAxisY = function () { this.$axis.resize(this.$axisCtn.box.width + this.computedData.keyNameWidth, this.$axisCtn.box.height + 10); this.$valueName.attr('y', -this.$axisCtn.box.height - 22); this.$whiteMask.attr('d', 'M' + (-this.$axisCtn.box.x - this.$body.box.x - 1) + ' ' + (-this.$axisCtn.box.y - this.$body.box.y) + ' h' + (this.box.width + 2) + 'v' + this.box.height + 'h' + (-this.box.width - 2) + 'z' + 'M0 ' + (-this.$axisCtn.box.height - 10) + 'h ' + this.$axisCtn.box.width + 'v' + (this.$axisCtn.box.height + this.$oxTable.box.height + 10) + ' H 0z'); }; RangeChart.prototype._updateScrollArrowBtb = src_VerticalChart.prototype._updateScrollArrowBtb; RangeChart.prototype._createOyValue = src_VerticalChart.prototype._createOyValue; RangeChart.prototype._updateOYValuePosition = function () { this._computeOYSegment(); if (!this.computedData.oyUpdated) { this._createOyValue(); } var y = 0; var valueElt; for (var i = 0; i < this.$oyValues.length; ++i) { valueElt = this.$oyValues[i]; valueElt.attr({ y: y + 5, x: -10 }); y -= this.computedData.oySegmentLength; } this.$axis.oyDivision = this.computedData.oySegmentLength; this.$axis.updateOyDivision(); }; RangeChart.prototype.createRanges = function () { var ctn = this.$rangeCtn; ctn.clearChild(); this.$ranges = this.ranges.map(function (range) { return this._createRange(range).addTo(ctn); }.bind(this)); }; RangeChart.prototype.updateRangesPosition = function () { var colWidth = this.computedData.collWidth; var thisC = this; this.$ranges.forEach(function (rangeElt, i) { var range = thisC.ranges[i]; rangeElt.box.x = colWidth * (i + 0.5); var yMin, yMax, yMid, yNormal; if (isNumber(range.min) && rangeElt.$minLine) { yMin = -thisC.mapOYValue(range.min); moveHLine(rangeElt.$minLine, -thisC.limitLineLength / 2, yMin, thisC.limitLineLength); } if (isNumber(range.max) && rangeElt.$maxLine) { yMax = -thisC.mapOYValue(range.max); moveHLine(rangeElt.$maxLine, -thisC.limitLineLength / 2, yMax, thisC.limitLineLength); } if (isNumber(range.mid) && rangeElt.$midLine) { yMid = -thisC.mapOYValue(range.mid); moveHLine(rangeElt.$midLine, -thisC.limitLineLength / 2, yMid, thisC.limitLineLength); } if (isNumber(range.normal) && rangeElt.$plot) { yNormal = -thisC.mapOYValue(range.normal); rangeElt.$plot.attr('cy', yNormal); } if (isNumber(range.min) && isNumber(range.max)) { rangeElt.$rect.attr({ x: -thisC.limitLineLength / 2, y: yMax, height: yMin - yMax, width: thisC.limitLineLength }); } }); }; RangeChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this.createOxTable(); this.createOxLabel(); this.createAxisName(); this.createRanges(); }; RangeChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this.updateAxisX(); this.updateOxTablePosition(); this.updateAxisY(); this._updateOYValuePosition(); this.updateRangesPosition(); }; RangeChart.prototype._createLimitLine = function (x, y, length, eClss) { return hline(x, y, length, ['range-chart-limit-line'].concat(eClss ? [eClss] : [])); }; RangeChart.prototype.numberToText = src_VerticalChart.prototype.numberToText; /*** * * @param range * @return {GContainer} * @private */ RangeChart.prototype._createRange = function (range) { var res = RangeChart_({ tag: svg_GContainer.tag }); if (isNumber(range.max) && isNumber(range.min)) res.$rect = RangeChart_('rect.vc-range-rect').addTo(res); if (isNumber(range.max)) res.$maxLine = this._createLimitLine(-this.limitLineLength / 2, 0, this.limitLineLength, 'max').addTo(res); if (isNumber(range.mid)) res.$midLine = this._createLimitLine(-this.limitLineLength / 2, 0, this.limitLineLength, 'mid').addTo(res); if (isNumber(range.min)) res.$minLine = this._createLimitLine(-this.limitLineLength / 2, 0, this.limitLineLength, 'min').addTo(res); if (isNumber(range.normal)) res.$plot = circle(0, 0, this.valuePlotRadius, 'range-chart-value-plot').addTo(res); return res; }; src_VCore.install(RangeChart); src_VCore.install('ostickchart', function () { return RangeChart_('rangechart.base-chart.o-stick-chart', true); }); ;// CONCATENATED MODULE: ./src/AssessmentChart.js var AssessmentChart_ = src_VCore._; var AssessmentChart_$ = src_VCore.$; /*** * or RadaChart * @extends BChart * @constructor */ function AssessmentChart() { src_BChart.call(this); this.rangePlotRadius = 5; //? not display this.rangeFillColor = null; this.rangeFillColor = null; this.rangeMaxStrokeColor = Color/* default.parse */.Z.parse('rgba(255, 150, 0, 0.3)'); this.rangeMinStrokeColor = Color/* default.parse */.Z.parse('rgba(200, 200, 0, 0.3)'); /** * * @type {{values:number[], name: string, stroke: Color|string, fill:Color|string, color:Color|string}[]} */ this.areas = []; this.ranges = []; /*** * * @type {string[]} */ this.keys = []; this.levels = []; /*** * * @type {null|[]} */ this.axisWeight = null; /*** * * @type {GContainer} */ this.$netCtn = AssessmentChart_('gcontainer.vc-assessment-net-ctn'); this.$netCtn = AssessmentChart_('gcontainer.vc-assessment-net-ctn'); this.$body.addChild(this.$netCtn); this.$netCtn.box.setPosition(200, 200); this.$axisCnt = AssessmentChart_('gcontainer.vc-assessment-axis-ctn'); this.$levelValueCnt = AssessmentChart_('gcontainer.vc-assessment-axis-level-ctn'); this.$levelCnt = AssessmentChart_('gcontainer.vc-assessment-level-ctn'); this.$areaCtn = AssessmentChart_('gcontainer.vc-assessment-area-ctn'); this.$rangeCtn = AssessmentChart_('gcontainer.vc-assessment-range-ctn'); this.$netCtn.addChild(this.$levelCnt); this.$netCtn.addChild(this.$axisCnt); this.$netCtn.addChild(this.$rangeCtn); this.$netCtn.addChild(this.$areaCtn); this.$netCtn.addChild(this.$levelValueCnt); } OOP/* default.mixClass */.ZP.mixClass(AssessmentChart, src_BChart); AssessmentChart.property = Object.assign({}, src_BChart.property); AssessmentChart.eventHandler = Object.assign({}, src_BChart.eventHandler); AssessmentChart.tag = 'AssessmentChart'.toLowerCase(); AssessmentChart.render = function () { return src_BChart.render().addClass('vc-assessment-chart'); }; AssessmentChart.prototype.dataKeys = ['title', 'simpleMode ', 'keys ', 'rangeFillColor']; AssessmentChart.prototype.normalizeData = function () { var thisC = this; // fill: area.fill || this.autoColor(i, 0.3), // stroke: area.stroke || this.autoColor(i, 0.8), this.areas.forEach(function (area, i) { var color = area.color || area.stroke || area.fill || thisC.autoColor(i); color = Color/* default.parse */.Z.parse(color + ''); color.rgba[3] = 1; var strokeColor = color.clone(); strokeColor.rgba[3] = 0.8; var filColor = color.clone(); filColor.rgba[3] = 0.3; if (area.color) { area.fill = area.fill || filColor; area.stroke = area.stroke || strokeColor; } else { if (area.stroke) { area.fill = area.fill || 'none'; } else if (area.fill) { area.stroke = area.stroke || 'none'; } else { area.fill = filColor; area.stroke = strokeColor; } area.color = color; } }); }; AssessmentChart.prototype.computeNotes = function () { return this.areas.map(function (area) { return { type: 'stroke', color: area.color, text: area.name }; }).filter(function (it) { return !!it.text; }); }; AssessmentChart.prototype._createAxis = function () { this.$axisCnt.clearChild(); this.$axisLines = this.keys.map(function (u, i) { var res = AssessmentChart_('hlinearrow'); res.resize(200); res.attr('transform', rotate(-90 + i * 360 / this.keys.length)); res.addTo(this.$axisCnt); return res; }.bind(this)); this.$axisNames = this.keys.map(function (key, i, arr) { var anchor = 'start'; if (i === 0 || i === arr.length / 2) anchor = 'middle';else if (i > arr.length / 2) anchor = 'end'; return AssessmentChart_({ tag: 'text', attr: { x: 0, y: 0 }, style: { textAnchor: anchor }, child: { text: key } }).addTo(this.$axisCnt); }.bind(this)); this.$levelCnt.clearChild(); this.$levels = this.levels.map(function (level, i, levels) { return AssessmentChart_('path.vc-assessment-chart-level' + (i + 1 == levels.length ? '.last' : '')).addTo(this.$levelCnt); }.bind(this)); this.computedData.axisNameSize = this.$axisNames.map(function (elt) { var box = elt.getBBox(); return { width: box.width, height: box.height }; }); this.$levelValueCnt.clearChild(); this.$levelValues = this.levels.map(function (level) { return this._createLevelValue(level).addTo(this.$levelValueCnt); }.bind(this)); }; AssessmentChart.prototype._createAreas = function () { this.$areaCtn.clearChild(); this.$areas = this.areas.map(function (area, i, arr) { return AssessmentChart_('path.vc-assessment-chart-area').addTo(this.$areaCtn).addStyle({ fill: area.fill, stroke: area.stroke }); }.bind(this)); }; AssessmentChart.prototype._createRanges = function () { this.$rangeCtn.clearChild(); if (this.ranges && this.ranges.length > 0) { this.$rangeArea = AssessmentChart_('shape.vc-assessment-chart-range-area').addStyle('fill-rule', "evenodd").addTo(this.$rangeCtn); if (this.rangeFillColor) { var rangeFillColor = Color/* default.parse */.Z.parse(this.rangeFillColor + ''); rangeFillColor.rgba[3] = 0.3; this.$rangeArea.addStyle({ fill: rangeFillColor.toString() }); } this.$ranges = this.ranges.map(function (range, i, arr) { return this._createRangeLine().addTo(this.$rangeCtn); }.bind(this)); this.$rangeMax = AssessmentChart_('shape.vc-assessment-chart-range-area-stroke').addTo(this.$rangeCtn).addStyle({ stroke: this.rangeMaxStrokeColor || 'rgba(255, 150, 0, 0.3)' }); this.$rangeMin = AssessmentChart_('shape.vc-assessment-chart-range-area-stroke').addTo(this.$rangeCtn).addStyle({ stroke: this.rangeMinStrokeColor || 'rgba(200, 200, 0, 0.3)' }); } }; AssessmentChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createAxis(); this._createRanges(); this._createAreas(); }; AssessmentChart.prototype._createLevelValue = function (value) { var res = AssessmentChart_('gcontainer.vc-assessment-chart-level-value'); res.$bound = rect(0, -6, 0, 13).attr({ rx: '4', ry: '4' }).addTo(res); res.$text = helper_text(value + '', 0, 4).attr({ 'text-anchor': 'middle' }).addTo(res); if (value === '' || value === undefined || value === null) res.addStyle('visibility', 'hidden'); return res; }; AssessmentChart.prototype.autoColor = function (index, alpha) { var hsla = [index / this.areas.length, 0.8, 0.5, alpha === undefined ? 1 : alpha]; var c = Color/* default.fromHSLA */.Z.fromHSLA(hsla[0], hsla[1], hsla[2], hsla[3]); return c.toString('rgba'); }; AssessmentChart.prototype.mapAngle = function (i, deg) { return (-90 + i * 360 / this.keys.length) * (deg ? 1 : Math.PI / 180); }; AssessmentChart.prototype.mapRadius = function (level) { return this.computedData.axisLength * (level / (this.levels.length - 1)); }; AssessmentChart.prototype.mapLevel = function (value) { if (this.isMappingLevel) { if (value < this.levelMappingArray[0]) return map(value, this.levelMappingArray[0], this.levelMappingArray[1], 0, 1); if (value > this.levelMappingArray[this.levels.length - 1]) return map(value, this.levelMappingArray[this.levels.length - 2], this.levelMappingArray[this.levels.length - 1], 0, 1); for (var i = 1; i < this.levels.length; ++i) { if (value >= this.levelMappingArray[i - 1] && value <= this.levelMappingArray[i]) return map(value, this.levelMappingArray[i - 1], this.levelMappingArray[i], i - 1, i); } } else { return value; } }; AssessmentChart.prototype._createRangeLine = function () { var res = AssessmentChart_({ tag: 'g', "class": 'vc-assessment-chart-range-segment' }); res.$min = circle(0, 0, this.rangePlotRadius, 'vc-assessment-chart-range-plot').addTo(res); res.$max = circle(0, 0, this.rangePlotRadius, 'vc-assessment-chart-range-plot').addTo(res); res.$line = AssessmentChart_('path.vc-assessment-chart-range-line').addTo(res); return res; }; /** * @param {Array<Rectangle>} rects * @returns {Rectangle} */ AssessmentChart.prototype._expectSize = function (rects, r) { var cr = new Math_Rectangle/* default */.Z(0, 0, 0, 0); var rect; for (var i = 0; i < rects.length; ++i) { var angle = Math.PI * 2 * i / rects.length - Math.PI / 2; rect = rects[i]; if (i == 0) { rect.x = rect.width / 2; rect.y = -rect.height - r - 7; } else if (rects.length % 4 == 0 && i == rects.length >> 2) { rect.x = r; rect.y = rect.height / 2; } else if (rects.length % 4 == 0 && i == (rects.length >> 2) * 3) { rect.x = -r - rect.width; rect.y = rect.height / 2; } else if (rects.length % 2 == 0 && i == rects.length >> 1) { rect.x = rect.width / 2; rect.y = r + 7; } else if (i < rects.length / 4) { rect.x = r * Math.cos(angle); rect.y = r * Math.sin(angle) - rect.height; } else if (i < rects.length / 2) { rect.x = r * Math.cos(angle); rect.y = r * Math.sin(angle); } else if (i < rects.length / 4 * 3) { rect.x = r * Math.cos(angle) - rect.width; rect.y = r * Math.sin(angle); } else { rect.x = r * Math.cos(angle) - rect.width; rect.y = r * Math.sin(angle) - rect.height; } cr = cr.merge(rect); } return cr; }; AssessmentChart.prototype._computedNetSize = function () { var rects = this.computedData.axisNameSize.map(function (box) { return new Math_Rectangle/* default */.Z(0, 0, box.width, box.height); }); var aWidth = this.$body.box.width; var aHeight = this.$body.box.height; var maxR = Math.min(aWidth, this.$body.box.height) / 2; var minR = 20; // while (maxR - minR > 3) { var midR = (minR + maxR) / 2; var size = this._expectSize(rects, midR); if (size.width < aWidth && size.height < aHeight) { minR = midR; } else { maxR = midR; } } this.computedData.expectedSize = this._expectSize(rects, minR); this.computedData.expectedRadius = minR; this.computedData.axisLength = this.computedData.expectedRadius - 30; }; AssessmentChart.prototype._updateAxisPosition = function () { var axisLength = this.computedData.axisLength; this.$axisLines.forEach(function ($axisLine) { $axisLine.resize(axisLength + 20); }.bind(this)); if (this.axisWeight && this.axisWeight.forEach) { this.axisWeight.forEach(function (value, i) { var axisLineElt = this.$axisLines[i]; if (axisLineElt) { if (value >= 0) { axisLineElt.addStyle('strokeWidth', value + ''); } else { axisLineElt.remove('strokeWidth'); } } }.bind(this)); } this.$axisNames.forEach(function ($axisName, i) { var angle = (-90 + i * 360 / this.keys.length) * Math.PI / 180; var x = (axisLength + 30) * Math.cos(angle); var y = (axisLength + 30) * Math.sin(angle) + 5; if (this.keys.length % 2 == 0 && i == this.keys.length >> 1) { y += 7; } else if (i == 0) { y -= 7; } $axisName.attr({ x: x, y: y }); }.bind(this)); this.$levels.forEach(function ($level, level) { var points = this.keys.reduce(function (ac, value, i) { var angle = this.mapAngle(i); var x = this.mapRadius(level) * Math.cos(angle); var y = this.mapRadius(level) * Math.sin(angle); ac.push(x + ' ' + y); return ac; }.bind(this), []); var d = 'M' + points.join('L') + 'Z'; $level.attr('d', d); }.bind(this)); var levelValueWidth = this.$levelValues.reduce(function (w, $levelValue) { return Math.max(w, $levelValue.$text.getBBox().width + 4); }, 0); if (this.mapRadius(1) - this.mapRadius(0) > 13) { this.$levelValues.forEach(function ($levelValue, i) { $levelValue.$bound.attr({ x: -levelValueWidth / 2, width: levelValueWidth }); $levelValue.attr('transform', translate(0, -this.mapRadius(i))); }.bind(this)); } else { this.$levelValues.forEach(function ($levelValue, i) { $levelValue.addStyle('display', 'none'); }.bind(this)); } var contentBound = new Math_Rectangle/* default */.Z(0, 0, this.$body.box.width, this.$body.box.height); var centerBound = contentBound.centerPoint(); this.$netCtn.box.setPosition(centerBound.x + (-this.computedData.expectedSize.x - this.computedData.expectedSize.width / 2), centerBound.y + (-this.computedData.expectedSize.y - this.computedData.expectedSize.height / 2)); }; AssessmentChart.prototype._updateAreaPosition = function () { this.$areas.forEach(function ($area, i) { var area = this.areas[i]; var points = area.values.reduce(function (ac, value, i) { var angle = this.mapAngle(i); var level = this.mapLevel(value); var x = this.mapRadius(level) * Math.cos(angle); var y = this.mapRadius(level) * Math.sin(angle); ac.push(x + ' ' + y); return ac; }.bind(this), []); var d = 'M' + points.join('L') + 'Z'; $area.attr('d', d); if (typeof area.strokeWidth == "number") { $area.addStyle('stroke-width', area.strokeWidth + ''); } }.bind(this)); }; AssessmentChart.prototype._updateRangePosition = function () { if (this.ranges && this.ranges.length > 0) { this.$ranges.forEach(function ($range, i) { var range = this.ranges[i]; var angle = this.mapAngle(i); var levelMax = this.mapLevel(range[1]); var xMax = this.mapRadius(levelMax) * Math.cos(angle); var yMax = this.mapRadius(levelMax) * Math.sin(angle); $range.$max.attr({ cx: xMax, cy: yMax }); var levelMin = this.mapLevel(range[0]); var xMin = this.mapRadius(levelMin) * Math.cos(angle); var yMin = this.mapRadius(levelMin) * Math.sin(angle); $range.$min.attr({ cx: xMin, cy: yMin }); $range.$line.attr('d', 'M' + xMin + ' ' + yMin + 'L' + xMax + ' ' + yMax); }.bind(this)); this.$rangeArea.begin(); this.$rangeMax.begin(); this.$rangeMin.begin(); this.ranges.forEach(function (range, i, arr) { var angle = this.mapAngle(i); var levelMax = this.mapLevel(range[1]); var xMax = this.mapRadius(levelMax) * Math.cos(angle); var yMax = this.mapRadius(levelMax) * Math.sin(angle); if (i == 0) { this.$rangeArea.moveTo(xMax, yMax); this.$rangeMax.moveTo(xMax, yMax); } else { this.$rangeArea.lineTo(xMax, yMax); this.$rangeMax.lineTo(xMax, yMax); } if (i + 1 == arr.length) { this.$rangeArea.closePath(); this.$rangeMax.closePath(); } }.bind(this)); this.ranges.forEach(function (range, i, arr) { var angle = this.mapAngle(i); var levelMax = this.mapLevel(range[0]); var xMin = this.mapRadius(levelMax) * Math.cos(angle); var yMin = this.mapRadius(levelMax) * Math.sin(angle); if (i == 0) { this.$rangeArea.moveTo(xMin, yMin); this.$rangeMin.moveTo(xMin, yMin); } else { this.$rangeArea.lineTo(xMin, yMin); this.$rangeMin.lineTo(xMin, yMin); } if (i + 1 == arr.length) { this.$rangeArea.closePath(); this.$rangeMin.closePath(); } }.bind(this)); this.$rangeMax.end(); this.$rangeMin.end(); this.$rangeArea.end(); } }; AssessmentChart.prototype._updatePrintViewport = function () { var children = Array.prototype.slice.call(this.childNodes); var bound = children.reduce(function (ac, cr) { var bbox = cr.getBBox(); if (bbox.width === 0 || bbox.height === 0) return ac; var rect = getGlobalBBox(cr); if (!ac) return rect; return ac.merge(rect); }, null); if (bound) { this.attr('data-print-view-box', Math.floor(bound.x) - 0.5 + ' ' + (Math.floor(bound.y) - 0.5) + ' ' + Math.ceil(bound.width + 1) + ' ' + Math.ceil(bound.height + 1)); } else this.attr('data-print-view-box', null); }; AssessmentChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._computedNetSize(); this._updateAxisPosition(); this._updateAreaPosition(); this._updateRangePosition(); this._updatePrintViewport(); }; AssessmentChart.prototype.updateContent = function () { this.prepareData(); src_BChart.prototype.updateContent.call(this); }; AssessmentChart.prototype.prepareData = function () { this.levelMappingArray = this.levels.map(function (value) { return parseFloat(value + ''); }); this.isMappingLevel = this.levelMappingArray.reduce(function (ac, cr) { return ac && !isNaN(cr); }, true); }; AssessmentChart.property.simpleMode = { set: function set(value) { if (value) this.addClass('simple-mode');else this.removeClass('simple-mode'); }, get: function get() { return this.containsClass('simple-mode'); } }; AssessmentChart.property.rangeSegment = { set: function set(value) { if (value) this.addClass('show-range-segment');else this.removeClass('show-range-segment'); }, get: function get() { return this.containsClass('show-range-segment'); } }; src_VCore.install(AssessmentChart); /* harmony default export */ const src_AssessmentChart = (AssessmentChart); ;// CONCATENATED MODULE: ./src/ColumnChart.js var ColumnChart_ = src_VCore._; var ColumnChart_$ = src_VCore.$; /*** * * @returns {VerticalChart} * @constructor */ function ColumnChart() { src_VerticalChart.call(this); this.values = []; this.$columnCtn = ColumnChart_('gcontainer.vc-column-ctn'); this.$oxySpace.addChild(this.$columnCtn); if (!this.numberToString) this.numberToString = function (value) { return numberToString.apply(this, arguments); }; } ColumnChart.property = Object.assign({}, src_VerticalChart.property); ColumnChart.eventHandler = Object.assign({}, src_VerticalChart.eventHandler); OOP/* default.mixClass */.ZP.mixClass(ColumnChart, src_VerticalChart); ColumnChart.tag = 'ColumnChart'.toLowerCase(); ColumnChart.render = function () { return src_VerticalChart.render().addClass('vc-column-chart'); }; ColumnChart.prototype.dataKeys = src_VerticalChart.prototype.dataKeys.concat(['values', 'oxColWidth']); ColumnChart.prototype.computeMinMax = function () { this.computedData.min = this.values.filter(isNumber).reduce(function (ac, cr) { return Math.min(ac, cr); }, 1000000000); this.computedData.max = this.values.filter(isNumber).reduce(function (ac, cr) { return Math.max(ac, cr); }, -1000000000); }; ColumnChart.prototype.createContent = function () { src_VerticalChart.prototype.createContent.call(this); this._createColumns(); }; ColumnChart.prototype._createColumn = function (value, i, color) { var res = ColumnChart_('gcontainer.vc-column'); res.$rect = rect(-this.oxColWidth / 2, 0, this.oxColWidth, 10).addTo(res); if (value === 0) { res.addClass('vc-value-zero'); } res.$value = helper_text(this.numberToString(value) + '', 0, 0).attr('text-anchor', 'middle').addTo(res); if (color) { res.$rect.addStyle('fill', color); } return res; }; ColumnChart.prototype._createColumns = function () { this.$columnCtn.clearChild(); this.$columnes = this.values.map(function (value, i) { return this._createColumn(value, i, this.columnColors && this.columnColors[i]).addTo(this.$columnCtn); }.bind(this)); }; ColumnChart.prototype.updateBodyPosition = function () { src_VerticalChart.prototype.updateBodyPosition.call(this); this._updateColumnPosition(); }; ColumnChart.prototype._updateColumnPosition = function () { this.$columnes.forEach(function ($column, i) { if (isNumber(this.values[i])) { $column.removeStyle('display'); var height = this.mapOYValue(this.values[i]); // x: (i + 0.5) * this.oxSegmentLength - this.columnWidth / 2 $column.$rect.attr({ height: height, y: -height }); $column.$value.attr('y', -height - 4); $column.attr({ transform: translate((i + 0.5) * this.computedData.oxSegmentLength, 0) }); } else { $column.addStyle('display', 'none'); } }.bind(this)); }; src_VCore.install(ColumnChart); /* harmony default export */ const src_ColumnChart = (ColumnChart); ;// CONCATENATED MODULE: ./src/ColumnAreaChart.js var ColumnAreaChart_ = src_VCore._; var ColumnAreaChart_$ = src_VCore.$; /*** * @extends ColumnChart * @constructor */ function ColumnAreaChart() { src_ColumnChart.call(this); this.$areaCtn = ColumnAreaChart_('gcontainer.vc-area-ctn'); this.$oxySpace.addChildBefore(this.$areaCtn, this.$columnCtn); this.areas = []; } OOP/* default.mixClass */.ZP.mixClass(ColumnAreaChart, src_ColumnChart); ColumnAreaChart.property = Object.assign({}, src_ColumnChart.property); ColumnAreaChart.eventHandler = Object.assign({}, src_ColumnChart.eventHandler); ColumnAreaChart.tag = 'ColumnAreaChart'.toLowerCase(); ColumnAreaChart.render = function () { return src_ColumnChart.render().addClass('vc-column-area-chart'); }; ColumnAreaChart.prototype.dataKeys = src_ColumnChart.prototype.dataKeys.concat(['areas']); ColumnAreaChart.prototype.computeMinMax = function () { src_ColumnChart.prototype.computeMinMax.call(this); this.computedData.min = this.areas.reduce(function (minValue, area) { return area.values.filter(isNumber).reduce(function (minValue, value) { if (!isNumber(value)) return minValue; return Math.min(minValue, value); }, minValue); }, this.computedData.min); this.computedData.max = this.areas.reduce(function (maxValue, area) { return area.values.filter(isNumber).reduce(function (maxValue, value) { if (!isNumber(value)) return maxValue; return Math.max(maxValue, value); }, maxValue); }, this.computedData.max); }; ColumnAreaChart.prototype.computeNotes = function () { return this.areas.map(function (area) { return { text: area.name, type: 'rect', color: area.color }; }); }; ColumnAreaChart.prototype._createArea = src_DualChart.prototype._createArea; ColumnAreaChart.prototype._createAreaNote = src_DualChart.prototype._createAreaNote; ColumnAreaChart.prototype._createAreas = function () { this.$areaCtn.clearChild(); this.$areas = this.areas.map(function (area, i) { return this._createArea(area, area.color).addTo(this.$areaCtn); }.bind(this)); }; ColumnAreaChart.prototype.createContent = function () { src_ColumnChart.prototype.createContent.call(this); this._createAreas(); }; ColumnAreaChart.prototype._updateAreaPosition = function () {}; ColumnAreaChart.prototype.updateBodyPosition = function () { src_ColumnChart.prototype.updateBodyPosition.call(this); this._updateAreaPosition(); this._updateAreaPosition(); }; ColumnAreaChart.prototype._updateAreaPosition = function () { var oxSegmentLength = this.computedData.oxSegmentLength; this.$areas.map(function ($area, i) { var values = this.areas[i].values; var subAreas = getSubNumberArray(values); $area.begin(); subAreas.forEach(function (subArea) { var start = subArea.start; var values = subArea.values; if (values.length > 1) { $area.moveTo(oxSegmentLength * (start + 0.5), -1); for (var xi = 0; xi < values.length; ++xi) { $area.lineTo(oxSegmentLength * (start + xi + 0.5), -this.mapOYValue(values[xi])); } $area.lineTo(oxSegmentLength * (start + values.length - 1 + 0.5), -1); $area.closePath(); } else { $area.moveTo(oxSegmentLength * (start + 0.25), -1); $area.lineTo(oxSegmentLength * (start + 0.25), -this.mapOYValue(values[0])); $area.lineTo(oxSegmentLength * (start + 0.75), -this.mapOYValue(values[0])); $area.lineTo(oxSegmentLength * (start + 0.75), -1); $area.closePath(); } }.bind(this)); $area.end(); }.bind(this)); }; svg_Core.install(ColumnAreaChart); /* harmony default export */ const src_ColumnAreaChart = (ColumnAreaChart); ;// CONCATENATED MODULE: ./src/RangeGroupChart.js var RangeGroupChart_ = src_VCore._; var RangeGroupChart_$ = src_VCore.$; function RangeGroupChart() { var res = RangeGroupChart_('basechart', true); return res; } ; RangeGroupChart.prototype._createNote = function () { var res = RangeGroupChart_('g'); res.$maxLine = hline(0, 7, 40, ['range-group-chart-limit-line', 'max']).addTo(res); res.$maxText = helper_text(this.maxText, 50, 12).addTo(res); res.$minLine = hline(200, 7, 40, ['range-group-chart-limit-line', 'min']).addTo(res); res.$minText = helper_text(this.minText, 250, 12).addTo(res); return res; }; RangeGroupChart.prototype._createMember = function (member) { var res = RangeGroupChart_('g'); res.$plot = circle(this.plotRadius, 0, this.plotRadius, 'range-group-chart-plot').addTo(res); res.$value = helper_text(this.numberToString(member.value), this.plotRadius * 2 + 8, 5).addTo(res); res.$nameContainer = RangeGroupChart_('g').addTo(res).attr('transform', 'rotate(45)'); res.$name = helper_text(member.name, this.plotRadius, 10).addTo(res.$nameContainer); return res; }; RangeGroupChart.prototype._createRange = function (range) { var res = RangeGroupChart_('g'); res.$lineLeft = hline(0, 0, 0, 'range-group-chart-range-line').addTo(res); res.$lineRight = hline(0, 0, 0, 'range-group-chart-range-line').addTo(res); res.$maxLine = hline(10, -this.paddingnAxisBottom, this.rangePaddingH * 2, ['range-group-chart-limit-line', 'max']).addTo(res); res.$minLine = hline(10, -this.paddingnAxisBottom, this.rangePaddingH * 2, ['range-group-chart-limit-line', 'min']).addTo(res); res.$max = helper_text(this.numberToString(range.max), 0, 0).attr('text-anchor', 'middle').addTo(res); res.$min = helper_text(this.numberToString(range.min), 0, 0).attr('text-anchor', 'middle').addTo(res); res.$members = range.members.map(function (member) { return this._createMember(member).addTo(res); }.bind(this)); res.$name = helper_text(range.name, 0, 0).attr('text-anchor', 'middle').addTo(res); return res; }; RangeGroupChart.prototype.processMinMax = function () { this["super"](); this.maxValue = this.ranges.reduce(function (max, range) { return range.members.reduce(function (max, member, i) { return Math.max(max, member.value); }.bind(this), Math.max(max, range.max, range.normal)); }.bind(this), -1000000000); this.minValue = this.ranges.reduce(function (min, range) { return range.members.reduce(function (min, member) { return Math.min(min, member.value); }.bind(this), Math.min(min, range.min, range.normal)); }.bind(this), 1000000000); }; RangeGroupChart.prototype.preInit = function () { this["super"](); this.paddingnAxisBottom = 40; this.rangePaddingH = 10; this.plotRadius = 6; this.rangeMarginH = 10; this.memberMarginH = 5; }; RangeGroupChart.prototype.initBackComp = function () { this["super"](); this.$note = this._createNote().addTo(this); }; RangeGroupChart.prototype.updateBackComp = function () { var noteBBox = this.$note.getBBox(); this.$note.attr('transform', translate(0, this.canvasHeight - noteBBox.height - 5)); var x = 50 + this.$note.$maxText.getBBox().width + 40; moveHLine(this.$note.$minLine, x, 7, 40); this.$note.$minText.attr('x', x + 50); this.oxyBottom = this.canvasHeight - noteBBox.height - 30; this.memberNameHeight = this.$ranges.reduce(function (memberHeight, $range) { return $range.$members.reduce(function (memberHeight, $member) { return Math.max(memberHeight, $member.$nameContainer.getBBox().width / 1.4); }, memberHeight); }, 0); this.oxyBottom -= this.memberNameHeight + 25; this["super"](); }; RangeGroupChart.prototype.initComp = function () { this.$ranges = this.ranges.map(function (range) { return this._createRange(range).addTo(this.$content); }.bind(this)); }; RangeGroupChart.prototype.updateComp = function () { var memberWidth = this.$ranges.reduce(function (memberWidth, $range) { return $range.$members.reduce(function (memberWidth, $member) { return Math.max(memberWidth, $member.getBBox().width); }, memberWidth); }, 0); this.oxContentLength = this.$ranges.reduce(function (oxContentLength, $range, rangeIndex) { oxContentLength += this.rangeMarginH; var range = this.ranges[rangeIndex]; $range.attr('transform', translate(oxContentLength, 0)); var rangeWidth = $range.$members.reduce(function (rangeWidth, $member, memberIndex) { rangeWidth += this.memberMarginH; var member = range.members[memberIndex]; $member.attr('transform', translate(rangeWidth, 0)); $member.$plot.attr('cy', this.mapOYValue(member.value)); $member.$value.attr('y', this.mapOYValue(member.value) + 5); rangeWidth += memberWidth; rangeWidth += this.memberMarginH; return rangeWidth; }.bind(this), this.rangePaddingH) + this.rangePaddingH; moveHLine($range.$maxLine, 0, this.mapOYValue(range.max), rangeWidth); moveHLine($range.$minLine, 0, this.mapOYValue(range.min), rangeWidth); var rangeHeight = this.mapOYValue(range.max) - this.mapOYValue(range.min); moveVLine($range.$lineLeft, 0, this.mapOYValue(range.min), rangeHeight); moveVLine($range.$lineRight, rangeWidth, this.mapOYValue(range.min), rangeHeight); $range.$name.attr({ x: rangeWidth / 2, y: this.memberNameHeight + 25 }); oxContentLength += rangeWidth; $range.$max.attr({ x: rangeWidth / 2, y: this.mapOYValue(range.max) - 5 }); $range.$min.attr({ x: rangeWidth / 2, y: this.mapOYValue(range.min) + 15 }); oxContentLength += this.rangeMarginH; return oxContentLength; }.bind(this), 0); }; src_VCore.creator.rangegroupchart = RangeGroupChart; /* harmony default export */ const src_RangeGroupChart = ((/* unused pure expression or super */ null && (RangeGroupChart))); ;// CONCATENATED MODULE: ./src/CurveChart.js /** * * @returns {LineChart} * @constructor */ function CurveChart() {} CurveChart.tag = 'CurveChart'.toLowerCase(); CurveChart.render = function () { return src_VCore._('linechart', true); }; CurveChart.prototype.updateComp = function () { this.$lines.map(function ($line, i) { var line = this.lines[i]; $line.$plots.forEach(function ($plot, j) { var value = line.values[j]; $plot.attr({ cx: this.oxSegmentLength * (j + 0.5), cy: this.mapOYValue(value) }); }.bind(this)); var points = line.values.map(function (value, j) { var y = this.mapOYValue(value); var x = this.oxSegmentLength * (j + 0.5); return [x, y]; }.bind(this)); var d = autoCurve(points, 0.5, 0.000001); $line.$path.attr('d', d); }.bind(this)); }; src_VCore.creator.curvechart = CurveChart; /* harmony default export */ const src_CurveChart = ((/* unused pure expression or super */ null && (CurveChart))); ;// CONCATENATED MODULE: ./src/RankChart.js var RankChart_ = src_VCore._; var RankChart_$ = src_VCore.$; /*** * @extends BChart * @constructor */ function RankChart() { src_BChart.call(this); OOP/* default.drillProperty */.ZP.drillProperty(this, this, 'numberToString', 'numberToText'); this.colors = ['transparent', 'rgb(201, 241, 253)', 'rgb(212, 227, 252)', 'rgb(218, 202, 251)', 'rgb(242, 201, 251)', 'rgb(255, 218, 216)', 'rgb(255, 236, 215)', 'rgb(254, 252, 224)', 'rgb(223, 237, 214)', 'rgb(77, 215, 250)', 'rgb(117, 169, 249)', 'rgb(139, 81, 245)', 'rgb(215, 87, 246)', 'rgb(255, 138, 132)', 'rgb(152, 165, 52)', 'rgb(254, 248, 160)', 'rgb(174, 221, 148)', 'rgb(0, 164, 221)', 'rgb(20, 100, 246)', 'rgb(156, 41, 183)']; this.computedData.oyUpdated = false; this.computedData.oy = {}; this.computedData.numberToFixed = 0; this.integerOnly = false; this.positions = []; this.valueName = ''; this.plotRadius = 9; this.zeroOY = true; this.extendOY = true; this.computedData.paddingAxisBottom = this.plotRadius + 30; this.$axisCtn = RankChart_({ tag: svg_GContainer.tag, "class": 'vc-axis-ctn', child: [{ tag: 'gcontainer', "class": 'vc-oxy-space', child: ['gcontainer.vc-ox-label-ctn', 'gcontainer.vc-rank-list-ctn'] }, { tag: 'path', "class": 'vc-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,0 0,200 200,200 200,0z' } }, 'axis', { tag: 'text', "class": 'vc-key-name', attr: { y: 14, x: 5 }, child: { text: '' } }, 'scrollarrow', 'hscrollbar', { tag: 'text', "class": 'vc-value-name', attr: { y: 14, x: 5 }, child: { text: '' } }] }); this.$body.addChild(this.$axisCtn); this.$hscrollbar = RankChart_$('hscrollbar', this.$axisCtn).on('scroll', this.eventHandler.scrollOxySpace); this.$hscrollbar.height = 10; this.$scrollArrow = RankChart_$('scrollarrow', this.$axisCtn).on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); this.$oxySpace = RankChart_$('gcontainer.vc-oxy-space', this.$axisCtn); this.$whiteMask = RankChart_$('.vc-white-mask', this.$axisCtn); this.$axis = RankChart_$('axis', this.$axisCtn); this.$keyName = RankChart_$('.vc-key-name', this.$axisCtn); this.$valueName = RankChart_$('.vc-value-name', this.$axisCtn); this.$oxLabelCtn = RankChart_$('gcontainer.vc-ox-label-ctn', this.$axisCtn); this.$oxLabels = []; this.$oyValueCtn = RankChart_('gcontainer.vc-oy-value-ctn').addTo(this.$body); this.$oyValues = []; this.$postion = []; this.$rankListCtn = RankChart_$('.vc-rank-list-ctn', this.$axisCtn); } RankChart.tag = 'RankChart'.toLowerCase(); RankChart.property = Object.assign({}, src_VerticalChart.property); RankChart.eventHandler = Object.assign({}, src_VerticalChart.eventHandler); OOP/* default.mixClass */.ZP.mixClass(RankChart, src_VerticalChart); RankChart.render = function () { return src_BChart.render().addClass('vc-rank-chart'); }; RankChart.prototype.updateBodyPosition = function () { this._isAutoWidth = this.style.width === 'auto'; if (this._isAutoWidth) this.addStyle('width', '450px'); src_VerticalChart.prototype.updateBodyPosition.call(this); this._updateOyDivision(); this._updatePosListPosition(); this._updateScrollerPosition(); if (this._isAutoWidth) { this._isAutoWidth = false; this.addStyle('width', this.contentPadding * 2 + this.$oyValueCtn.box.x + this.$hscrollbar.innerWidth + this.$keyName.getBBox().width + 10 + 'px'); this.updateBodyPosition(); } }; RankChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createOxLabel(); this._createPosList(); }; RankChart.prototype.computeData = src_VerticalChart.prototype.computeData; RankChart.prototype.computeMinMax = function () { var min = Infinity, max = -Infinity; this.positions.forEach(function (position) { position.ranks.forEach(function (rank) { min = Math.min(min, rank); max = Math.max(max, rank); }); }); this.computedData.min = min; this.computedData.max = max + 1; }; RankChart.prototype._createOxLabel = function () { this.$keyName.firstChild.data = this.valueName; this.$oxLabelCtn.clearChild(); this.$oxLabels = this.positions.map(function (position) { return RankChart_({ tag: 'text', "class": 'vc-ox-label', child: { text: position.name } }); }); this.$oxLabelCtn.addChild(this.$oxLabels); this.$valueName.firstChild.data = this.valueName || ''; }; RankChart.prototype._updateOxLabelPosition = function () { this.$oxLabelCtn.box.y = 20; }; RankChart.prototype._updateScrollerPosition = function () { this.computedData.oxOverFlow = this.computedData.oxScrollWidth > this.computedData.oxLength; this.$hscrollbar.outterWidth = this.computedData.oxLength; this.$hscrollbar.innerWidth = this.computedData.oxScrollWidth; this.$hscrollbar.width = Math.max(0, this.computedData.oxLength); // this.$hscrollbar.scrollLeft = Math.max(0, Math.min(this.$hscrollbar.scrollLeft, this.computedData.oxScrollWidth - this.computedData.oxLength)); this.$hscrollbar.scrollLeft = 0; if (this.computedData.oxOverFlow) { this.$scrollArrow.removeStyle('display'); this.$scrollArrow.box.y = this.computedData.oyLength / 2; this.$scrollArrow.width = this.computedData.oxLength - 20; this._updateScrollArrowBtb(); } else { this.$scrollArrow.addStyle('display', 'none'); } this.$axis.oyDivision = this.computedData.oySegmentLength; this.$axis.updateOyDivision(); }; RankChart.prototype._updateOyDivision = function (value) { this.$axis.oyDivision = this.computedData.oySegmentLength; this.$axis.oyPadding = this.computedData.paddingAxisBottom; this.$axis.updateOyDivision(); }; RankChart.prototype.mapOYValue = function (val) { return this.computedData.paddingAxisBottom + map(val, this.computedData.oy.minValue, this.computedData.oy.maxValue, 0, this.computedData.oyLength); }; RankChart.prototype._createRank = function (rank, value) { var res = RankChart_({ tag: 'g', "class": 'rank-chart-group', child: [{ tag: 'circle', "class": 'rank-chart-plot', attr: { cx: this.plotRadius, cy: 0, r: this.plotRadius }, style: { fill: this.colors[rank] } }, { tag: 'text', "class": 'rank-chart-plot-text', attr: { x: this.plotRadius, y: 5, 'text-anchor': 'middle' }, props: { innerHTML: rank + 1 + '' } }] }); res.attr('title', this.numberToString(value)); return res; }; RankChart.prototype.numberToString = function (num) { return num.toString(); }; RankChart.prototype._createPosition = function (position) { var res = RankChart_({ tag: svg_GContainer.tag }); res.$ranks = position.ranks.map(function (value, rank) { return this._createRank(rank, value); }.bind(this)); res.$rect = RankChart_({ tag: 'rect', "class": 'vc-rank-position-list-rect', attr: { x: '0', y: '0' } }); res.addChild(res.$rect).addChild(res.$ranks); return res; }; RankChart.prototype._createPosList = function () { this.$positions = this.positions.map(this._createPosition.bind(this)); this.$rankListCtn.clearChild().addChild(this.$positions); }; RankChart.prototype._updatePosListPosition = function () { var contentLength = this.$positions.reduce(function (contentLength, pe, positionIndex) { var position = this.positions[positionIndex]; contentLength = contentLength + 20; var maxDY = pe.$ranks.reduce(function (maxDY, meme, j) { var value = position.ranks[j]; var y = -this.mapOYValue(value); meme.attr('transform', translate(contentLength, y)); meme._tr_y = y; return Math.max(maxDY, -y); }.bind(this), 0); var valueElements = pe.$ranks.slice(); valueElements.sort(function (a, b) { return a._tr_y - b._tr_y; }); var ninf = -1000000; var messure = valueElements.reduce(function (ac, e) { var y = e._tr_y; var colIndex = 0; while (ac[colIndex].minY > y) { ++colIndex; } ac[colIndex].minY = y + 20; ac[colIndex].child.push(e); ac[colIndex].maxWidth = Math.max(ac[colIndex].maxWidth, e.getBBox().width); return ac; }, Array(200).fill(null).map(function () { return { minY: ninf, child: [], maxWidth: ninf }; })); messure.reduce(function (left, col) { if (col.child.length == 0) return; col.child.forEach(function (vale) { vale.attr('transform', translate(left, vale._tr_y)); }); return left + col.maxWidth + 9; }, 10); pe.$rect.addStyle('display', 'none'); var innerWidth = pe.getBBox().width; pe.$rect.removeStyle('display'); pe.$rect.attr({ width: innerWidth + 20, y: -maxDY - (this.plotRadius + 10), height: maxDY + this.plotRadius + 10 }); var columeWidth = Math.max(pe.getBBox().width + 20, this.$oxLabels[positionIndex].getBBox().width + 10); this.$oxLabels[positionIndex].attr('x', contentLength + columeWidth / 2); pe.box.x = contentLength + columeWidth / 2 - (innerWidth + 20) / 2; contentLength += columeWidth; return contentLength; }.bind(this), 9); this.computedData.oxScrollWidth = contentLength; }; src_VCore.install(RankChart); /* harmony default export */ const src_RankChart = ((/* unused pure expression or super */ null && (RankChart))); ;// CONCATENATED MODULE: ./src/SunburstChart.js var SunburstChart_ = src_VCore._; var SunburstChart_$ = src_VCore.$; /*** * @extends BChart * @constructor */ function SunburstChart() { src_BChart.call(this); this.$sunbirstCtn = SunburstChart_('gcontainer.vc-sunburst-ctn'); this.$body.addChild(this.$sunbirstCtn); this.root = {}; } SunburstChart.property = Object.assign({}, src_BChart.property); SunburstChart.eventHandler = Object.assign({}, src_BChart.eventHandler); OOP/* default.mixClass */.ZP.mixClass(SunburstChart, src_BChart); SunburstChart.tag = 'SunburstChart'.toLowerCase(); SunburstChart.render = function () { return src_BChart.render().addClass('vc-sunburst-chart'); }; SunburstChart.prototype._normalizeColorData = function () { var needAutoColor = []; this.acceptNode(this.root, function (node) { try { if (node.fillColor.rgba) return; var c = Color/* default.parse */.Z.parse(node.fillColor + ''); if (!node.fillColor.rgba) node.fillColor = c; } catch (error) { needAutoColor.push(node); } }); var aColors = generateBackgroundColors(needAutoColor.length); needAutoColor.forEach(function (node, i) { node.fillColor = aColors[i]; }); this.acceptNode(this.root, function (node) { try { if (node.textColor.rgba) return; var c = Color/* default.parse */.Z.parse(node.textColor + ''); if (!node.textColor.rgba) node.textColor = c; } catch (error) { node.textColor = node.fillColor.getContrastYIQ(); } }); }; SunburstChart.prototype.computeData = function () { this.computedData.depth = this.calDepth(this.root); }; SunburstChart.prototype._measureFan = function (r, R, as, ae) { var dn = 0; if (as < 0) { dn = Math.ceil(-as / (Math.PI * 2)); } else if (as >= Math.PI * 2) { dn = -Math.floor(as / (Math.PI * 2)); } as += Math.PI * 2 * dn; ae += Math.PI * 2 * dn; var cosS = Math.cos(as); var sinS = Math.sin(as); var cosE = Math.cos(ae); var sinE = Math.sin(ae); var A = new Math_Rectangle/* default */.Z(r * cosS, r * sinS, 0, 0); var B = new Math_Rectangle/* default */.Z(R * cosS, R * sinS, 0, 0); var C = new Math_Rectangle/* default */.Z(R * cosE, R * sinE, 0, 0); var D = new Math_Rectangle/* default */.Z(r * cosE, r * sinE, 0, 0); var points = [A, B, C, D]; var e90, cosE90, sinE90; for (var k = 0; k < 4; ++k) { e90 = k * Math.PI / 2; cosE90 = Math.cos(e90); sinE90 = Math.sin(e90); if (e90 > as && e90 < ae) { points.push(new Math_Rectangle/* default */.Z(r * cosE90, r * sinE90, 0, 0)); points.push(new Math_Rectangle/* default */.Z(R * cosE90, R * sinE90, 0, 0)); } } return points.reduce(function (ac, cr) { return ac.merge(cr); }); }; SunburstChart.prototype._measureSunburst = function (rFan) { var r0 = this.computedData.rootR; var rects = [new Math_Rectangle/* default */.Z(-r0, -r0, 2 * r0, 2 * r0)]; function visit($node) { var level = $node.level; var r = r0 + rFan * (level - 1); var R = r + rFan * $node.span; var fanRect = this._measureFan(r, R, $node.chartAngle[0], $node.chartAngle[1]); rects.push(fanRect); if ($node.$child) $node.$child.forEach(visit.bind(this)); } if (this.$root.$child) this.$root.$child.forEach(visit.bind(this)); return rects.reduce(function (ac, cr) { return ac.merge(cr); }); }; SunburstChart.prototype._findBestFanRadius = function () { var mid; var bound; var exi = 1; var aWidth = this.$body.box.width - 4; var aHeight = this.$body.box.height - 4; var h = (Math.max(aWidth, aHeight) - this.computedData.rootR - 2) / this.computedData.depth; var l = (Math.min(aWidth, aHeight) - this.computedData.rootR - 2) / this.computedData.depth / 2; mid = (l + h) / 2; while (l + exi < h) { bound = this._measureSunburst(mid); if (bound.width > aWidth || bound.height > aHeight) { h = mid; } else { l = mid; } mid = (l + h) / 2; } this.computedData.fanR = mid; }; SunburstChart.prototype.normalizeData = function () { src_BChart.prototype.normalizeData.call(this); this._normalizeColorData(); }; // SunburstChart.prototype.updateSize = BaseChart.prototype.updateSize; SunburstChart.prototype.acceptNode = function (node, visitFunction, content) { visitFunction(node, content); if (node.child) { node.child.forEach(function (cNode) { this.acceptNode(cNode, visitFunction, content); }.bind(this)); } }; SunburstChart.prototype._updateNodePosition = function () { var rootR = this.computedData.rootR; var fanR = this.computedData.fanR; function visit($node) { var r0 = rootR + ($node.level - 1) * fanR; var r1 = r0 + fanR * $node.span; var isLeftPath = ($node.chartAngle[1] + $node.chartAngle[0]) / 2 > Math.PI / 2; $node.$nameCtn.attr('transform', rotate(($node.chartAngle[1] + $node.chartAngle[0]) / 2 / Math.PI * 180 + (isLeftPath ? 180 : 0))); var textX = (isLeftPath ? -1 : 1) * (r0 + r1) / 2; if ((r0 + r1) / 2 * Math.abs($node.chartAngle[1] - $node.chartAngle[0]) < 15) { $node.$nameCtn.addStyle('visibility', 'hidden'); } else { // //todo: var nodeText = $node.data.name; var textColor = $node.textColor; // var words = nodeText.trim().split(/\s+/); var updateNodeSession = this.updateNodeSession; var tryText = function (nLine) { $node.$nameCtn.clearChild(); var wordPerLine = Math.ceil(words.length / nLine); var lines = words.reduce(function (ac, cr) { if (ac.top.length == 0) { ac.result.push(ac.top); } ac.top.push(cr); if (ac.top.length >= wordPerLine) ac.top = []; return ac; }, { result: [], top: [] }).result; lines.reduce(function (y, line) { var lineText = line.join(' '); $node.$nameCtn.addChild(helper_text(lineText, textX, y, 'vc-sunburst-node-name').attr('text-anchor', 'middle').addStyle('fill', textColor)); return y + 20; }, 5 - (nLine - 1) * 20 / 2); var box = $node.$nameCtn.getBBox(); var out = box.width + 8 > r1 - r0 || box.height > (r0 + r1) / 2 * Math.abs($node.chartAngle[1] - $node.chartAngle[0]); if (nLine < words.length && out) { tryText(nLine + 1); } else if (out) { $node.$nameCtn.addStyle('visibility', 'hidden'); } else { $node.$nameCtn.removeStyle('visibility', 'hidden'); } }.bind(this); tryText(1); } $node.$shape.begin().moveTo(r0 * Math.cos($node.chartAngle[0]), r0 * Math.sin($node.chartAngle[0])).arcTo(r0 * Math.cos($node.chartAngle[1]), r0 * Math.sin($node.chartAngle[1]), r0, r0, $node.chartAngle[1] - $node.chartAngle[0] > Math.PI ? 1 : 0, 1).lineTo(r1 * Math.cos($node.chartAngle[1]), r1 * Math.sin($node.chartAngle[1])).arcTo(r1 * Math.cos($node.chartAngle[0]), r1 * Math.sin($node.chartAngle[0]), r1, r1, $node.chartAngle[1] - $node.chartAngle[0] > Math.PI ? 1 : 0, 0).closePath().end(); if ($node.$child && $node.$child.length > 0) { $node.$child.forEach(visit.bind(this)); } } if (this.$root.$child && this.$root.$child.length > 0) { this.$root.$child.forEach(visit.bind(this)); } }; SunburstChart.prototype._updateSunburstPosition = function () { var ctnBox = this.$sunbirstCtn.getBBox(); var rootBox = this.$root.getBBox(); var x = this.$body.box.width / 2; var y = this.$body.box.height / 2; x -= ctnBox.x + ctnBox.width / 2 - (rootBox.x + rootBox.width / 2); y -= ctnBox.y + ctnBox.height / 2 - (rootBox.y + rootBox.height / 2); this.$sunbirstCtn.box.setPosition(x, y); }; SunburstChart.prototype._updatePrintViewport = function () { var children = Array.prototype.slice.call(this.childNodes); var bound = children.reduce(function (ac, cr) { var bbox = cr.getBBox(); if (bbox.width === 0 || bbox.height === 0) return ac; var rect = getGlobalBBox(cr); if (!ac) return rect; return ac.merge(rect); }, null); if (bound) { this.attr('data-print-view-box', Math.floor(bound.x) - 0.5 + ' ' + (Math.floor(bound.y) - 0.5) + ' ' + Math.ceil(bound.width + 1) + ' ' + Math.ceil(bound.height + 1)); } else this.attr('data-print-view-box', null); }; SunburstChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._findBestFanRadius(); this._updateNodePosition(); this._updateSunburstPosition(); this._updatePrintViewport(); }; SunburstChart.prototype._createRoot = function () { var rootWords = this.root.name.trim().split(/\s+/); var rectsPerLine = Math.ceil(Math.sqrt(rootWords.length) * Math.log10(7)); var lines = rootWords.reduce(function (ac, cr) { if (ac.top.length === 0) { ac.result.push(ac.top); } ac.top.push(cr); if (ac.top.length >= rectsPerLine) ac.top = []; return ac; }, { result: [], top: [] }).result; this.$root = SunburstChart_('g.vc-title').addTo(this.$sunbirstCtn); this.$root.$circle = circle(0, 0, 1).addTo(this.$root); this.$root.$circle.addStyle('fill', this.root.fillColor.toString('hex8')); this.$root.$lines = lines.map(function (line, i, arr) { return helper_text(line.join(' '), 0, -(arr.length * 15) / 2 + 12 + 15 * i).attr('text-anchor', 'middle').addTo(this.$root); }.bind(this)); var rootBox = this.$root.getBBox(); this.computedData.rootR = Math.sqrt(rootBox.width * rootBox.width + rootBox.height * rootBox.height) / 2 + 5; this.$root.$circle.attr('r', this.computedData.rootR); this.$root.data = this.root; this.$root.level = 0; this.$root.span = 1; this.$root.chartAngle = [-Math.PI / 2, -Math.PI / 2 + Math.PI * 2]; }; SunburstChart.prototype._createChild = function (fromElt) { var sum = fromElt.data.value; if (!fromElt.data.child || !(fromElt.data.child.length > 0)) return; fromElt.$child = fromElt.data.child.map(function (childData) { var fillColor = childData.fillColor; var res = SunburstChart_({ tag: 'g', "class": 'sunburst-chart-node', props: { data: childData, level: fromElt.level + (fromElt.data.span || 1), span: childData.span || 1, textColor: Color/* default.parse */.Z.parse(fillColor).getContrastYIQ().toString('rgb') } }); res.$title = SunburstChart_('<title>' + childData.name + ': ' + childData.value + '</title>').addTo(res); res.$shape = SunburstChart_({ tag: 'shape', "class": 'sunburst-chart-node-shape', style: { fill: fillColor } }).addTo(res); res.$nameCtn = SunburstChart_('g').addTo(res); return res.addTo(this.$sunbirstCtn); }.bind(this)); fromElt.$child.reduce(function (offset, $childNode) { $childNode.chartAngle = [map(offset, 0, sum, fromElt.chartAngle[0], fromElt.chartAngle[1]), map(offset + $childNode.data.value, 0, sum, fromElt.chartAngle[0], fromElt.chartAngle[1])]; this._createChild($childNode); return offset += $childNode.data.value; }.bind(this), 0); }; SunburstChart.prototype._createSunburst = function () { this.$sunbirstCtn.clearChild(); this._createRoot(); this._createChild(this.$root); }; SunburstChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createSunburst(); }; SunburstChart.prototype.calDepth = function (node) { if (node.child && node.child.length > 0) { return (node.span || 1) + Math.max.apply(Math, node.child.map(this.calDepth.bind(this))); } else return node.span || 1; }; src_VCore.creator.sunburstchart = SunburstChart; /* harmony default export */ const src_SunburstChart = ((/* unused pure expression or super */ null && (SunburstChart))); ;// CONCATENATED MODULE: ./src/SquareChart.js // vchart.creator.correlationchart = function () { // var _ = _; // var $ = vchart.$; // var res = _({ // tag: 'svg', // class: 'base-chart', // child: 'axis' // }, true); // res.$axis = $('axis', res); // res.sync = res.afterAttached(); // return res; // }; // vchart.creator.correlationchart.prototype.updateSize = vchart.creator.basechart.prototype.updateSize; // vchart.creator.correlationchart.prototype.update = function () { // this.updateSize(); // this.updateBackComp(); // this.updateAxis(); // this.updateComp(); // }; // vchart.creator.correlationchart.prototype.mapOXColumn = function (index) { // return this.oxyLeft + (index + 0.5) * this.oxSegmentLength; // }; // vchart.creator.correlationchart.prototype.mapOYValue = function (value) { // return this.oxyBottom - this.oyLength * value; // }; // vchart.creator.correlationchart.prototype.updateAxis = function () { // this.$axis.moveTo(this.oxyLeft, this.oxyBottom); // this.$axis.resize(this.canvasWidth - this.oxyLeft - 10, this.oxyBottom - 43); // this.$oyName.attr({ x: 3, y: 30 }); // this.$oxName.attr({ x: this.canvasWidth - 4, y: this.oxyBottom + 20 }); // }; // vchart.creator.correlationchart.prototype.initBackComp = function () { // this.$title = text(this.title, 0, 0, 'base-chart-title').attr('text-anchor', 'middle').addTo(this); // this.$oyName = text(this.valueName, 0, 0, 'base-chart-oxy-text').addTo(this); // this.$oxName = text(this.keyName, 0, 100, 'base-chart-oxy-text').attr('text-anchor', 'end').addTo(this); // this.$keyNames = this.keys.map(function (key) { // return text(key, 100, 100).attr('text-anchor', 'middle').addTo(this); // }.bind(this)); // }; // vchart.creator.correlationchart.prototype.updateBackComp = function () { // this.$title.attr({ x: this.canvasWidth / 2, y: 20 }); // this.oxyLeft = Math.max(20, this.$oyName.getBBox().width); // this.oxyBottom = this.canvasHeight - 10; // this.oxLength = this.canvasWidth - this.oxyLeft - 12 - this.$oxName.getBBox().width; // this.oxSegmentLength = this.oxLength / this.keys.length; // var oyNameHeight = this.$keyNames.reduce(function (ac, $keyName) { // return Math.max($keyName.getBBox().height); // }.bind(this), 0); // this.oxyBottom -= oyNameHeight; // this.oyLength = this.oxyBottom - 50; // this.$keyNames.forEach(function ($keyName, i) { // $keyName.attr({ x: this.mapOXColumn(i), y: this.oxyBottom + 20 }); // }.bind(this), 0); // }; // vchart.creator.correlationchart.prototype.initComp = function () { // this.$staticVLines = this.staticValues.map(function (value, i) { // return vline(0, 0, 0, ['correlation-chart-normal-line', 'static']).addTo(this); // }.bind(this)); // this.$staticHLines = this.staticValues.map(function (value, i) { // return hline(0, 0, 0, ['correlation-chart-normal-line', 'static']).addTo(this); // }.bind(this)); // this.$dynamicVLines = this.dynamicValues.map(function (value, i) { // return vline(0, 0, 0, ['correlation-chart-normal-line', 'dynamic']).addTo(this); // }.bind(this)); // this.$dynamicHLines = this.dynamicValues.map(function (value, i) { // return hline(0, 0, 0, ['correlation-chart-normal-line', 'dynamic']).addTo(this); // }.bind(this)); // this.$staticPlots = this.staticValues.map(function (value, i) { // return circle(50 + i * 30, 100, this.plotRadius, ['correlation-chart-plot', 'static']).addTo(this); // }.bind(this)); // this.$staticLine = _('path.correlation-chart-line.static').addTo(this); // this.$dynamicPlots = this.dynamicValues.map(function (value, i) { // return circle(50 + i * 30, 200, this.plotRadius, ['correlation-chart-plot', 'dynamic']).addTo(this); // }.bind(this)); // this.$dynamicLine = _('path.correlation-chart-line.dynamic').addTo(this); // }; // vchart.creator.correlationchart.prototype.updateComp = function () { // this.$staticVLines.forEach(function ($staticVLine, i) { // moveVLine($staticVLine, this.mapOXColumn(i), this.oxyBottom, this.mapOYValue(this.staticValues[i]) - this.oxyBottom); // }.bind(this)); // this.$staticHLines.forEach(function ($staticHLine, i) { // moveHLine($staticHLine, this.oxyLeft, this.mapOYValue(this.staticValues[i]), this.mapOXColumn(i) - this.oxyLeft); // }.bind(this)); // this.$dynamicVLines.forEach(function ($dynamicVLine, i) { // moveVLine($dynamicVLine, this.mapOXColumn(i), this.oxyBottom, this.mapOYValue(this.dynamicValues[i]) - this.oxyBottom); // }.bind(this)); // this.$dynamicHLines.forEach(function ($dynamicHLine, i) { // moveHLine($dynamicHLine, this.oxyLeft, this.mapOYValue(this.dynamicValues[i]), this.mapOXColumn(i) - this.oxyLeft); // }.bind(this)); // this.$staticPlots.forEach(function ($plot, i) { // $plot.attr({ cx: this.mapOXColumn(i), cy: this.mapOYValue(this.staticValues[i]) }); // }.bind(this)); // var staticPoints = this.staticValues.map(function (value, i) { // return [this.mapOXColumn(i), this.mapOYValue(value)]; // }.bind(this)); // this.$staticLine.attr('d', vchart.autoCurve(staticPoints, 0.7, 0.01));// // this.$dynamicPlots.forEach(function ($plot, i) { // $plot.attr({ cx: this.mapOXColumn(i), cy: this.mapOYValue(this.dynamicValues[i]) }); // }.bind(this)); // var dynamicPoints = this.dynamicValues.map(function (value, i) { // return [this.mapOXColumn(i), this.mapOYValue(value)]; // }.bind(this)); // this.$dynamicLine.attr('d', vchart.autoCurve(dynamicPoints, 0.7, 0.01));// // }; // vchart.creator.correlationchart.prototype.preInit = function (props) { // this.plotRadius = 6; // }; // vchart.creator.correlationchart.prototype.init = function (props) { // this.super(props); // this.preInit(); // this.initBackComp(); // this.initComp(); // this.sync = this.sync.then(this.update.bind(this)); // }; var SquareChart_ = src_VCore._; var SquareChart_$ = src_VCore.$; function SquareChart() { var res = SquareChart_({ tag: 'svg', "class": 'base-chart', child: 'axis' }, true); res.$axis = SquareChart_$('axis', res); res.sync = res.afterAttached(); return res; } ; SquareChart.prototype.updateSize = src_BaseChart.prototype.updateSize; SquareChart.prototype.getY = function (k, y0, x) { var a = k * k / 64; return map(a * x * x * x * x + a * x * x + x, 0, 1 + 2 * a, y0, 1); }; SquareChart.prototype.staticY = function (x) { return this.getY(this["static"].k, this["static"].y0, x); }; SquareChart.prototype.dynamicY = function (x) { return this.getY(this.dynamic.k, this.dynamic.y0, x); }; SquareChart.prototype.getX = function (index) { return index / (this.keys.length - 1); }; SquareChart.prototype.update = function () { this.updateSize(); this.updateBackComp(); this.updateAxis(); this.updateComp(); }; SquareChart.prototype.mapOXColumn = function (index) { return this.oxyLeft + (index + 0.5) * this.oxSegmentLength; }; SquareChart.prototype.mapOYValue = function (value) { return this.oxyBottom - this.oyLength * value; }; SquareChart.prototype.updateAxis = function () { this.$axis.moveTo(this.oxyLeft, this.oxyBottom); this.$axis.resize(this.canvasWidth - this.oxyLeft - 10, this.oxyBottom - 43); this.$oyName.attr({ x: this.oxyLeft - 5, y: 30 }); this.$oxName.attr({ x: this.canvasWidth - 4, y: this.oxyBottom + 20 }); }; SquareChart.prototype.initBackComp = function () { this.$title = helper_text(this.title || '', 0, 0, 'base-chart-title').attr('text-anchor', 'middle').addTo(this); this.$oyName = helper_text(this.valueName, 0, 0, 'base-chart-oxy-text').attr('text-anchor', 'end').addTo(this); this.$oxName = helper_text(this.keyName, 0, 100, 'base-chart-oxy-text').attr('text-anchor', 'end').addTo(this); this.$keyNames = this.keys.map(function (key) { return helper_text(key, 100, 100).attr('text-anchor', 'middle').addTo(this); }.bind(this)); this.$testText = helper_text('0'.repeat(10), 0, 18).addStyle('visibility', 'hidden').addTo(this); }; SquareChart.prototype.updateBackComp = function () { // update value text if (this.minValueText !== null && this.minValueText !== undefined) this.$minValueText.innerHTML = this.minValueText;else this.$minValueText.innerHTML = ''; if (this.maxValueText !== null && this.maxValueText !== undefined) this.$maxValueText.innerHTML = this.maxValueText;else this.$maxValueText.innerHTML = ''; this.$title.attr({ x: this.canvasWidth / 2, y: 20 }); this.oxyLeft = Math.max(20, this.$oyName.getBBox().width + 10, this.$maxValueText.getBBox().width + 10, this.$minValueText.getBBox().width + 10, this.$testText.getBBox().width / 10 * this.minValueTextLength + 10); this.oxyBottom = this.canvasHeight - 10; this.oxLength = this.canvasWidth - this.oxyLeft - 12 - this.$oxName.getBBox().width; this.oxSegmentLength = this.oxLength / this.keys.length; var oyNameHeight = this.$keyNames.reduce(function (ac, $keyName) { return Math.max($keyName.getBBox().height); }.bind(this), 0); this.oxyBottom -= oyNameHeight; this.oyLength = this.oxyBottom - 50; this.$keyNames.forEach(function ($keyName, i) { $keyName.attr({ x: this.mapOXColumn(i), y: this.oxyBottom + 20 }); }.bind(this), 0); }; SquareChart.prototype.initComp = function () { this.$staticVLines = this.keys.map(function (value, i) { return vline(0, 0, 0, ['correlation-chart-normal-line', 'static']).addTo(this); }.bind(this)); this.$staticHLines = this.keys.map(function (value, i) { return hline(0, 0, 0, ['correlation-chart-normal-line', 'static']).addTo(this); }.bind(this)); this.$dynamicVLines = this.keys.map(function (value, i) { return vline(0, 0, 0, ['correlation-chart-normal-line', 'dynamic']).addTo(this); }.bind(this)); this.$dynamicHLines = this.keys.map(function (value, i) { return hline(0, 0, 0, ['correlation-chart-normal-line', 'dynamic']).addTo(this); }.bind(this)); this.$staticPlots = this.keys.map(function (value, i) { return circle(50 + i * 30, 100, this.plotRadius, ['correlation-chart-plot', 'static']).addTo(this); }.bind(this)); this.$staticLine = SquareChart_('path.correlation-chart-line.static').addTo(this); this.$dynamicPlots = this.keys.map(function (value, i) { return circle(50 + i * 30, 200, this.plotRadius, ['correlation-chart-plot', 'dynamic']).addTo(this); }.bind(this)); this.$dynamicLine = SquareChart_('path.correlation-chart-line.dynamic').addTo(this); // (this.minValueText !== undefined && this.minValueText === null) this.$minValueText = helper_text('test', 10, 100).attr('text-anchor', 'end').addTo(this); this.$maxValueText = helper_text('test 2 ', 100, 100).attr('text-anchor', 'end').addTo(this); }; SquareChart.prototype.updateComp = function () { this.$staticVLines.forEach(function ($staticVLine, i) { moveVLine($staticVLine, this.mapOXColumn(i), this.oxyBottom, this.mapOYValue(this.staticY(this.getX(i))) - this.oxyBottom); }.bind(this)); this.$staticHLines.forEach(function ($staticHLine, i) { moveHLine($staticHLine, this.oxyLeft, this.mapOYValue(this.staticY(this.getX(i))), this.mapOXColumn(i) - this.oxyLeft); }.bind(this)); this.$dynamicVLines.forEach(function ($dynamicVLine, i) { moveVLine($dynamicVLine, this.mapOXColumn(i), this.oxyBottom, this.mapOYValue(this.dynamicY(this.getX(i))) - this.oxyBottom); }.bind(this)); this.$dynamicHLines.forEach(function ($dynamicHLine, i) { moveHLine($dynamicHLine, this.oxyLeft, this.mapOYValue(this.dynamicY(this.getX(i))), this.mapOXColumn(i) - this.oxyLeft); }.bind(this)); this.$staticPlots.forEach(function ($plot, i) { $plot.attr({ cx: this.mapOXColumn(i), cy: this.mapOYValue(this.staticY(this.getX(i))) }); }.bind(this)); var staticPoints = Array(101).fill(0).map(function (value, i) { return [this.mapOXColumn(i * (this.keys.length - 1) / 100), this.mapOYValue(this.staticY(i / 100))]; }.bind(this)); this.$staticLine.attr('d', vchart.autoCurve(staticPoints, 0.7, 0.01)); // this.$dynamicPlots.forEach(function ($plot, i) { $plot.attr({ cx: this.mapOXColumn(i), cy: this.mapOYValue(this.dynamicY(this.getX(i))) }); }.bind(this)); var dynamicPoints = Array(101).fill(0).map(function (value, i) { return [this.mapOXColumn(i * (this.keys.length - 1) / 100), this.mapOYValue(this.dynamicY(i / 100))]; }.bind(this)); this.$dynamicLine.attr('d', vchart.autoCurve(dynamicPoints, 0.7, 0.01)); // this.$minValueText.attr({ x: this.oxyLeft - 5, y: this.mapOYValue(this.dynamicY(this.getX(0))) + 6 }); this.$maxValueText.attr({ x: this.oxyLeft - 5, y: this.mapOYValue(this.dynamicY(this.getX(this.keys.length - 1))) + 6 }); }; SquareChart.prototype.preInit = function (props) { this.plotRadius = 6; this.minValueTextLength = 0; }; SquareChart.prototype.init = function (props) { this.preInit(); this["super"](props); this.initBackComp(); this.initComp(); this.sync = this.sync.then(this.update.bind(this)); }; src_VCore.creator.squarechart = SquareChart; /* harmony default export */ const src_SquareChart = ((/* unused pure expression or super */ null && (SquareChart))); ;// CONCATENATED MODULE: ./src/GroupRankChart.js var GroupRankChart_ = src_VCore._; var GroupRankChart_$ = src_VCore.$; function GroupRankChart() { var suffix = (Math.random() + '').replace(/\./g, ''); var res = GroupRankChart_({ tag: 'svg', "class": 'grank-chart', child: [{ tag: 'g', attr: { id: 'contentBox' }, child: 'g#content' }, { tag: 'path', "class": 'base-chart-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,0 0,200 200,200 200,0z' } }, 'axis', 'hscrollbar'] }); res.sync = res.afterAttached(); res.$axis = GroupRankChart_$('axis', res); res.$whiteBoxMask = GroupRankChart_$('.base-chart-white-mask', res); res.$content = GroupRankChart_$('g#content', res); res.eventHandler = OOP/* default.bindFunctions */.ZP.bindFunctions(res, GroupRankChart.eventHandler); // res.on('wheel', res.eventHandler.wheel); res.$hscrollbar = GroupRankChart_$('hscrollbar', res).on('scroll', res.eventHandler.scrollbarscroll); return res; } ; GroupRankChart.eventHandler = {}; GroupRankChart.eventHandler.wheel = function (event) { var d = this.scrollBy(event.deltaY); if (d != 0) { event.preventDefault(); } }; GroupRankChart.eventHandler.scrollArrowsPressLeft = function (event) { this.scrollBy(-60); }; GroupRankChart.eventHandler.scrollArrowsPressRight = function (event) { this.scrollBy(60); }; GroupRankChart.eventHandler.scrollbarscroll = function (event) { this.scrollLeft = this.$hscrollbar.scrollLeft; event.preventDefault(); }; GroupRankChart.prototype.scrollBy = function (dX) { var scrollLeft = this.scrollLeft + dX / 5; var scrollLeft = Math.max(0, Math.min(this.oxContentLength - this.oxLength, scrollLeft)); var deltaX = scrollLeft - this.scrollLeft; if (deltaX != 0) { this.scrollLeft = scrollLeft; this.$hscrollbar.scrollLeft = scrollLeft; } return deltaX; }; GroupRankChart.prototype.numberToString = function (value) { return value.toString(); }; GroupRankChart.prototype._createMember = function (member) { var res = GroupRankChart_('g'); res.$plot = circle(this.plotRadius, 0, this.plotRadius, 'grank-chart-plot').addTo(res); res.$name = helper_text(member.name, this.plotRadius * 2 + 9, -3).addTo(res); res.$value = helper_text('' + this.numberToString(member.value) + '', this.plotRadius * 2 + 9, 16).addTo(res); return res; }; GroupRankChart.prototype._createOyValues = function (minValue, step, segmentCount, extendOY) { var child = Array(segmentCount + 1 + (extendOY ? 1 : 0)).fill(0).map(function (u, i) { var value; if (extendOY) { if (i == 0) { value = 0; } else { value = minValue + (i - 1) * step; } } else { value = minValue + i * step; } return { tag: 'text', attr: { x: '-14', y: '0', 'text-anchor': 'end' }, props: { innerHTML: this.numberToString(value) } }; }.bind(this)); return GroupRankChart_({ tag: 'g', child: child }); }; GroupRankChart.prototype._createOYSegmentLines = function (n) { var res = GroupRankChart_({ tag: 'g', child: Array(n).fill('path.vchart-segment-line') }); return res; }; GroupRankChart.prototype._createGroup = function (group) { return GroupRankChart_({ tag: 'g', child: group.members.map(this._createMember.bind(this)) }); }; GroupRankChart.prototype._callOYValue = function (val) { return -this.paddingnAxisBottom + (this.extendOY ? -this.oySegmentLength : 0) - map(val, this.oyMinValue, this.oyMaxValue, 0, this.oyLength - (this.extendOY ? this.oySegmentLength : 0)); }; GroupRankChart.prototype.updateSize = function () { this.attr({ width: this.canvasWidth + '', height: this.canvasHeight + '', viewBox: [0, 0, this.canvasWidth, this.canvasHeight].join(' ') }); this.$title.attr('x', this.canvasWidth / 2); }; GroupRankChart.prototype.updateOyValues = function () { this.oyLength = this.oxyBottom - 70 - this.paddingnAxisBottom; this.oySegmentLength = this.oyLength / (this.oySegmentCount + (this.extendOY ? 1 : 0)); Array.prototype.forEach.call(this.$oyValues.childNodes, function (e, i) { e.attr({ y: -i * this.oySegmentLength + 5 - this.paddingnAxisBottom, x: -10 }); }.bind(this)); var oyValuesBox = this.$oyValues.getBBox(); this.oxyLeft = Math.max(this.oxyLeft, oyValuesBox.width + 14, this.$oyName.getBBox().width); this.oxLength = this.canvasWidth - this.oxyLeft - 24; this.$oyValues.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); }; GroupRankChart.prototype.updateAxis = function () { this.$axis.attr('transform', translate(this.oxyLeft, this.oxyBottom)); this.$axis.resize(this.canvasWidth - this.oxyLeft - 10, this.oxyBottom - 50); this.$oyName.attr({ x: this.oxyLeft, y: 30, 'text-anchor': 'end' }); this.$whiteBoxMask.attr('d', 'M0,0 0,cvh cvw,cvh cvw,0zMleft,top left,bottom right,bottom right,topz'.replace(/cvh/g, this.canvasHeight).replace(/cvw/g, this.canvasWidth).replace(/left/g, this.oxyLeft).replace(/top/g, 1).replace(/bottom/g, this.canvasHeight).replace(/right/g, this.canvasWidth - 10)); this.$content.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); this.$oxName.attr({ x: this.canvasWidth - this.$oxName.getBBox().width - 3, y: this.oxyBottom - 9 }); }; GroupRankChart.prototype.updateOYSegmentLines = function () { this.$oySegmentLines.attr('transform', 'translate(' + this.oxyLeft + ',' + this.oxyBottom + ')'); Array.prototype.forEach.call(this.$oySegmentLines.childNodes, function (e, i) { moveHLine(e, -2, -i * this.oySegmentLength - this.paddingnAxisBottom, 4); }.bind(this)); }; GroupRankChart.prototype.updateGroups = function () { this.oxContentLength = this.$groups.reduce(function (contentLength, ge, groupIndex) { var group = this.groups[groupIndex]; contentLength = contentLength + 20; var maxDY = Array.prototype.reduce.call(ge.childNodes, function (maxDY, meme, j) { var member = group.members[j]; var y = this._callOYValue(member.value); meme.attr('transform', translate(contentLength, y)); meme._tr_y = y; return Math.max(maxDY, -y); }.bind(this), 0); //todo:auto x var memberElements = Array.apply(null, ge.childNodes); memberElements.sort(function (a, b) { return a._tr_y - b._tr_y; }); var ninf = -1000000; var messure = memberElements.reduce(function (ac, e) { var y = e._tr_y; var colIndex = 0; while (ac[colIndex].minY > y) { ++colIndex; } ac[colIndex].minY = y + 40; ac[colIndex].child.push(e); ac[colIndex].maxWidth = Math.max(ac[colIndex].maxWidth, e.getBBox().width); return ac; }, Array(200).fill(null).map(function () { return { minY: ninf, child: [], maxWidth: ninf }; })); messure.reduce(function (left, col) { if (col.child.length == 0) return; col.child.forEach(function (meme) { meme.attr('transform', translate(left, meme._tr_y)); }); return left + col.maxWidth + 9; }, contentLength); var innerWidth = ge.getBBox().width; this.$groupBoxes[groupIndex].attr({ x: contentLength - 10, width: innerWidth + 20, y: -maxDY - (this.plotRadius + 20), height: maxDY + this.plotRadius + 20 }); var columeWidth = Math.max(ge.getBBox().width + 20, this.$groupNames[groupIndex].getBBox().width + 10); this.$groupNames[groupIndex].attr('x', contentLength + columeWidth / 2); contentLength += columeWidth; return contentLength; }.bind(this), 0); }; GroupRankChart.prototype.updateScrollArrows = function () { this.$scrollArrows.attr('transform', 'translate(' + (this.oxyLeft + 7) + ', ' + (this.oxyBottom - this.oyLength / 2) + ')'); this.$scrollArrows.$rightArrow.attr('transform', 'translate(' + (this.oxLength - 15) + ', 0)'); this.scrollLeft = this.scrollLeft; //update this.$hscrollbar.resize(this.oxLength, 10); this.$hscrollbar.moveTo(this.oxyLeft, this.oxyBottom - 10); this.$hscrollbar.outterWidth = this.oxLength; this.$hscrollbar.innerWidth = this.oxContentLength; }; GroupRankChart.prototype.update = function () { if (!this.groups || this.groups.length <= 0) return; if (typeof this.canvasWidth != 'number') { this.canvasWidth = 300; this.autoWidth = true; } this.updateSize(); this.updateOyValues(); this.updateAxis(); this.updateOYSegmentLines(); this.updateGroups(); this.updateScrollArrows(); requestAnimationFrame(function () { if (this.autoWidth) { var requireWidth = this.canvasWidth + this.overflowOX; var proviceWidth = this.parentElement.getBoundingClientRect().width; this.canvasWidth = Math.max(Math.min(requireWidth, proviceWidth), 300); this.autoWidth = false; this.update(); } }.bind(this)); }; GroupRankChart.prototype.initComp = function () { this.maxValue = this.groups.reduce(function (ac, group) { return group.members.reduce(function (ac, member) { return Math.max(ac, member.value); }, ac); }, -10000000000); this.minValue = this.groups.reduce(function (ac, group) { return group.members.reduce(function (ac, member) { return Math.min(ac, member.value); }, ac); }, 10000000000); if (this.maxValue == this.minValue) this.maxValue += this.maxSegment; this.oxyBottom = this.canvasHeight - 40; //fix size, not need update this.oxyLeft = 0; var btSgmt = calBeautySegment(this.maxSegment, this.minValue, this.maxValue); this.oySegmentCount = btSgmt.segmentCount; this.oyMinValue = btSgmt.minValue; this.oyMaxValue = btSgmt.maxValue; this.extendOY = !!(this.zeroOY && this.oyMinValue > 0); this.oyStep = btSgmt.step; this.$oyValues = this._createOyValues(this.oyMinValue, this.oyStep, this.oySegmentCount, this.extendOY).addTo(this); this.$oySegmentLines = this._createOYSegmentLines(this.oySegmentCount + 1 + (this.extendOY ? 1 : 0)).addTo(this); this.$title = vchart.text(this.title || '', 0, 19, 'base-chart-title').attr('text-anchor', 'middle').addTo(this); this.$oyName = vchart.text(this.valueName || '', 0, 0, 'base-chart-oxy-text').addTo(this); this.$oxName = vchart.text(this.keyName || '', 0, 0, 'base-chart-oxy-text').addTo(this); this.$groups = this.groups.map(function (group) { return this._createGroup(group).addTo(this.$content); }.bind(this)); this.$groupNames = this.groups.map(function (group) { return vchart.text(group.name, 0, 18).attr('text-anchor', 'middle').addTo(this.$content); }.bind(this)); this.$groupBoxes = this.groups.map(function (group) { return vchart.rect(0, 0, 0, 0, 'grank-chart-group-rect').addTo(this.$content); }.bind(this)); this.$scrollArrows = GroupRankChart_('scrollarrow').addTo(this).on('pressleft', this.eventHandler.scrollArrowsPressLeft).on('pressright', this.eventHandler.scrollArrowsPressRight); }; GroupRankChart.prototype.init = function (props) { this.plotRadius = 6; this.canvasWidth = 400; this.canvasHeight = 300; this.maxSegment = 9; this.paddingnAxisBottom = this.plotRadius + 30; this.valueName = ''; this["super"](props); if (!this.groups || this.groups.length <= 0) { console.log('Empty data!'); return; } this.initComp(); this.sync = this.sync.then(this.update.bind(this)); }; GroupRankChart.property = {}; GroupRankChart.property.scrollLeft = { set: function set(value) { this._scrollLeft = value || 0; this.$content.attr('transform', 'translate(' + (this.oxyLeft - this.scrollLeft) + ',' + this.oxyBottom + ')'); if (this.scrollLeft > 0.001) { this.$scrollArrows.$leftArrow.removeStyle('display'); } else { this.$scrollArrows.$leftArrow.addStyle('display', 'none'); } if (this.oxContentLength - this.oxLength > this.scrollLeft + 0.001) { this.$scrollArrows.$rightArrow.removeStyle('display'); } else { this.$scrollArrows.$rightArrow.addStyle('display', 'none'); } }, get: function get() { return this._scrollLeft || 0; } }; GroupRankChart.property.overflowOX = { get: function get() { return Math.max(0, this.oxContentLength - this.oxLength); } }; src_VCore.creator.grouprankchart = GroupRankChart; /* harmony default export */ const src_GroupRankChart = ((/* unused pure expression or super */ null && (GroupRankChart))); ;// CONCATENATED MODULE: ./src/MappingChart.js var MappingChart_ = src_VCore._; var MappingChart_$ = src_VCore.$; var STATE_READY = 0; var STATE_MODIFY = 1; function MappingChart() { var res = MappingChart_({ tag: 'svg', attr: { tabindex: '1' }, "class": 'mapping-chart', extendEvent: ['add', 'addmakertop', 'addmarkerbot', 'clicktop', 'clickbot', 'addline', 'removeline', 'editline'], child: ['g.background', 'g.middleground', 'g.forceground'] }); res.$background = MappingChart_$('g.background', res); res.$middleground = MappingChart_$('g.middleground', res); res.$forceground = MappingChart_$('g.forceground', res); res.sync = res.afterAttached(); return res; } ; MappingChart.prototype.generateValue = function (number) { return Math.round(Math.round(number * this.precision) / this.precision); }; MappingChart.prototype.preInit = function () { this.canvasWidth = 300; this.canvasHeight = 300; this.rangePlotRadius = 6; this.axisTop = 70; this.hitboxHeight = 20; this.tempValue = 0; this.markerHitboxWidth = 1; }; MappingChart.prototype.numberToString = function (number) { return number + ''; }; MappingChart.prototype.updateSize = src_BaseChart.prototype.updateSize; MappingChart.prototype.numberToString = src_BaseChart.prototype.numberToString; MappingChart.prototype.initAxis = function () { this.$topMinPlot = MappingChart_('shape.mapping-chart-range-plot').addTo(this.$background); this.$topMaxPlot = MappingChart_('shape.mapping-chart-range-plot').addTo(this.$background); this.$botMinPlot = MappingChart_('shape.mapping-chart-range-plot').addTo(this.$background); this.$botMaxPlot = MappingChart_('shape.mapping-chart-range-plot').addTo(this.$background); this.$topLine = hline(50, 50, 500, 'mapping-chart-range-line').addTo(this.$background); this.$botLine = hline(50, 50, 500, 'mapping-chart-range-line').addTo(this.$background); this.$topMinText = helper_text(this.numberToString(this.min), 20, 20, 'mapping-chart-range-text').addTo(this.$background); this.$topMaxText = helper_text(this.numberToString(this.max), 30, 20, 'mapping-chart-range-text').addTo(this.$background); this.$botMinText = helper_text(this.numberToString(this.min), 20, 50, 'mapping-chart-range-text').addTo(this.$background); this.$botMaxText = helper_text(this.numberToString(this.max), 30, 50, 'mapping-chart-range-text').addTo(this.$background); this.$title = helper_text(this.title || '', 0, 25, 'mapping-chart-title').addTo(this.$background).attr('text-anchor', 'middle'); }; MappingChart.prototype.updateAxis = function () { this.axisLeft = 10 + this.$topMinText.getBBox().width + 10; var maxTextWidth = this.$botMaxText.getBBox().width; this.axisRight = this.canvasWidth - 10 - maxTextWidth - 10; this.axisBottom = this.canvasHeight - 50; this.$topMinText.attr({ x: '10', y: this.axisTop - 4 + '' }); this.$topMaxText.attr({ x: this.canvasWidth - 10 - maxTextWidth, y: this.axisTop - 4 + '' }); this.$botMinText.attr({ x: '10', y: this.axisBottom + 4 + 14 }); this.$botMaxText.attr({ x: this.canvasWidth - 10 - maxTextWidth, y: this.axisBottom + 4 + 14 }); this.$topMinPlot.begin().moveTo(this.axisLeft, this.axisTop - 5).lineTo(this.axisLeft, this.axisTop + 5).end(); this.$topMaxPlot.begin().moveTo(this.axisRight, this.axisTop - 5).lineTo(this.axisRight, this.axisTop + 5).end(); moveHLine(this.$topLine, this.axisLeft, this.axisTop, this.axisRight - this.axisLeft); this.$botMinPlot.begin().moveTo(this.axisLeft, this.axisBottom - 5).lineTo(this.axisLeft, this.axisBottom + 5).end(); this.$botMaxPlot.begin().moveTo(this.axisRight, this.axisBottom - 5).lineTo(this.axisRight, this.axisBottom + 5).end(); moveHLine(this.$botLine, this.axisLeft, this.axisBottom, this.axisRight - this.axisLeft); this.$title.attr({ x: this.canvasWidth / 2, y: 10 + 20 }); }; MappingChart.prototype.initHitbox = function () { this.$topHitbox = rect(20, 20, 300, 20, 'vchart-hitbox').on({ mouseenter: this.eventEnterHitboxHandler.bind(this), mouseleave: this.eventLeaveHitboxHandler.bind(this), click: this.eventClickHitboxHandler.bind(this) }).addTo(this.$forceground); this.$botHitbox = rect(20, 80, 300, 20, 'vchart-hitbox').on({ mouseenter: this.eventEnterHitboxHandler.bind(this), mouseleave: this.eventLeaveHitboxHandler.bind(this), click: this.eventClickHitboxHandler.bind(this) }).addTo(this.$forceground); }; MappingChart.prototype.updateHitbox = function () { this.$topHitbox.attr({ x: this.axisLeft, y: this.axisTop - this.hitboxHeight / 2, height: this.hitboxHeight, width: this.axisRight - this.axisLeft }); this.$botHitbox.attr({ x: this.axisLeft, y: this.axisBottom - this.hitboxHeight / 2, height: this.hitboxHeight, width: this.axisRight - this.axisLeft }); }; MappingChart.prototype.initTempmarker = function () { this.$tempTopMarker = MappingChart_('mappingchartmarker.top').addTo(this.$forceground); this.$tempBotMarker = MappingChart_('mappingchartmarker.bot').addTo(this.$forceground); this.$tempTopMarker.rotate180 = true; this.$tempTopMarker.text = this.numberToString(this.min); this.$tempBotMarker.text = this.numberToString(this.min); }; MappingChart.prototype.updateTempMarker = function () { //todo if (isNumber(this.collision)) { this.markerHitboxWidth = Math.max(1, map(this.collision, 0, this.max - this.min, 0, this.axisRight - this.axisLeft)); } this.$tempTopMarker.moveTo(this.axisLeft, this.axisTop); this.$tempBotMarker.moveTo(this.axisLeft, this.axisBottom); this.$tempTopMarker.hitboxWidth = this.markerHitboxWidth; this.$tempBotMarker.hitboxWidth = this.markerHitboxWidth; }; MappingChart.prototype.initComp = function () { this.initAxis(); this.initTempmarker(); this.initHitbox(); }; MappingChart.prototype.updateComp = function () { this.updateAxis(); this.updateHitbox(); this.updateTempMarker(); }; MappingChart.prototype.update = function () { this.updateSize(); this.updateComp(); }; MappingChart.prototype.addMarkerTop = function (value) { var value = this.generateValue(this.tempValue); var cLine; if (!this._tempLine) { this._tempLine = { value: 0, //default $line: MappingChart_('shape.mapping-chart-map-line').addTo(this.$background), $line_hitbox: MappingChart_('shape.mapping-chart-map-line-hitbox.vchart-hitbox').addTo(this.$middleground), $topMarker: MappingChart_({ tag: 'mappingchartmarker' }).addTo(this.$forceground), $topPlot: circle(20, 20, 5, 'mapping-chart-line-plot').addTo(this.$forceground) }; } this._tempLine.value = value; var x0 = map(value, this.min, this.max, this.axisLeft, this.axisRight); var y0 = this.axisTop; this._tempLine.x0 = x0; this._tempLine.y0 = y0; this._tempLine.$topMarker.moveTo(x0, y0); this._tempLine.$topPlot.attr({ cx: x0, cy: y0 }); this._tempLine.$topMarker.text = this.numberToString(this.generateValue(value)); var self = this; var lineElt = this._tempLine.$line; function mouseMoveHandler(event) { lineElt.begin().moveTo(x0, y0).lineTo(self.mouseX, self.mouseY).end(); } this.on('mousemove', mouseMoveHandler); this.once('addmarkerbot', function () { this.off('mousemove', mouseMoveHandler); }); }; MappingChart.prototype.addMarkerBottom = function (mapValue) { if (!this._tempLine) return; //must click top first var mapValue = this.generateValue(this.tempValue); var isCross = this._checkLineIsCross(this._tempLine.value, mapValue); if (isCross) return; var x1 = map(mapValue, this.min, this.max, this.axisLeft, this.axisRight); var y1 = this.axisBottom; this._tempLine.mapValue = mapValue; this._tempLine.$botMarker = MappingChart_({ tag: 'mappingchartmarker', props: { text: this.numberToString(this.generateValue(mapValue)), rotate180: true } }).moveTo(x1, y1).addTo(this.$forceground); this._tempLine.x1 = x1; this._tempLine.y1 = y1; this._tempLine.$botPlot = circle(20, 80, 5, 'mapping-chart-line-plot').addTo(this.$forceground); this._tempLine.$botPlot.attr({ cx: x1, cy: y1 }); this._tempLine.$line.begin().moveTo(this._tempLine.x0, this._tempLine.y0).lineTo(x1, y1).end(); this._tempLine.$line_hitbox.attr('d', this._tempLine.$line.attr('d')); var tempLine = this._tempLine; this.settupEvent(tempLine); this._lineList.push(this._tempLine); this._tempLine = undefined; this.emit('addmarkerbot', { target: this, data: tempLine }, this); this.emit('addline', this.content, this); }; MappingChart.prototype._checkLineIsCross = function (value, mapValue) { return this._lineList.some(function (element) { return (element.value - value) * (element.mapValue - mapValue) < 0; }); }; MappingChart.prototype.eventEnterHitboxHandler = function (event) { if (this.__removeClassTimeOutTop) { clearTimeout(this.__removeClassTimeOutTop); self.__removeClassTimeOutTop = false; } if (this.__removeClassTimeOutBot) { clearTimeout(this.__removeClassTimeOutBot); self.__removeClassTimeOutBot = false; } if (event.target == this.$topHitbox) { this.addClass('mapping-chart-hover-top'); } else if (event.target == this.$botHitbox) { this.addClass('mapping-chart-hover-bot'); } }; MappingChart.prototype.eventLeaveHitboxHandler = function (event) { var target = event.target; var self = this; if (target == self.$topHitbox) { if (this.__removeClassTimeOutTop) { clearTimeout(this.__removeClassTimeOutTop); self.__removeClassTimeOutTop = false; } this.__removeClassTimeOutTop = setTimeout(function () { self.removeClass('mapping-chart-hover-top'); self.__removeClassTimeOutTop = false; }, 100); } else if (target == self.$botHitbox) { if (this.__removeClassTimeOutBot) { clearTimeout(this.__removeClassTimeOutBot); self.__removeClassTimeOutBot = false; } self.__removeClassTimeOutBot = setTimeout(function () { self.removeClass('mapping-chart-hover-bot'); self.__removeClassTimeOutBot = false; }, 100); } }; MappingChart.prototype.eventClickHitboxHandler = function (event) { var target = event.target; if (target == this.$topHitbox) { if (this.state == STATE_READY) { this.addMarkerTop(this.tempValue); } this.emit('clicktop', {}, this); } else if (target == this.$botHitbox) { if (this.state == STATE_READY) { this.addMarkerBottom(this.tempValue); } this.emit('clickbot', {}, this); } }; MappingChart.prototype.eventMoveHandler = function (event) { var hitboxBound = this.$botHitbox.getBoundingClientRect(); var eventX = event.clientX; var tempValue = map(eventX, hitboxBound.left, hitboxBound.right, this.min, this.max); tempValue = Math.round(tempValue); this.tempValue = Math.min(this.max, Math.max(this.min, tempValue)); var newX = map(this.tempValue, this.min, this.max, this.axisLeft, this.axisRight); this.$tempTopMarker.moveTo(newX, this.axisTop); this.$tempBotMarker.moveTo(newX, this.axisBottom); var markerText = this.numberToString(this.generateValue(this.tempValue)); this.$tempTopMarker.text = markerText; this.$tempBotMarker.text = markerText; var bound = this.getBoundingClientRect(); this.mouseX = map(event.clientX, bound.left, bound.right, 0, this.canvasWidth); this.mouseY = map(event.clientY, bound.top, bound.bottom, 0, this.canvasHeight); }; MappingChart.prototype.cancelCMD = function () { if (this._tempLine) { this.removeElementInObject(this._tempLine); this._tempLine = undefined; } else {} }; MappingChart.prototype.deleteCMD = function () { if (this._tempLine) { this.removeElementInObject(this._tempLine); this._tempLine = undefined; } else { if (this._selectedLine !== undefined) { var tempLine = this._selectedLine; this.removeElementInObject(tempLine); this._lineList = this._lineList.filter(function (elt) { return elt.value != tempLine.value && elt.mapValue != tempLine.mapValue; }); this._selectedLine = undefined; this.emit('removeline', this.content, this); } } }; MappingChart.prototype.eventKeyDownHandler = function (event) { if (event.key == "Escape") { this.cancelCMD(); event.preventDefault(); } else if (event.key == "Delete") { this.deleteCMD(); event.preventDefault(); } }; MappingChart.prototype.settupEvent = function (tempLine) { var self = this; function clickLineHandler(event) { if (self._selectedLine !== undefined) { self._selectedLine.$line.removeClass('selected-line'); self._selectedLine = undefined; } self._selectedLine = tempLine; tempLine.$line.addClass('selected-line'); function unSelectLine() { tempLine.$line.removeClass('selected-line'); if (self._selectedLine !== undefined) if (self._selectedLine.$line == tempLine.$line) self._selectedLine = undefined; self.off('click', clickOutHandler); self.off('keydown', cancelFocusHandler); } function clickOutHandler(event) { if (event.target != tempLine.$line) { unSelectLine(); } } function cancelFocusHandler(event) { if (event.key == "Escape") { unSelectLine(); } } setTimeout(function () { self.on('click', clickOutHandler); }, 1); setTimeout(function () { self.on('keydown', cancelFocusHandler); }, 1); } var lineElt = tempLine.$line; var line_hitboxElt = tempLine.$line_hitbox; function clickTopPlotHandler(event) { self.state = STATE_MODIFY; tempLine.$topMarker.addStyle('visibility', 'hidden'); tempLine.$topPlot.addStyle('visibility', 'hidden'); function mouseMoveHandler(event) { lineElt.begin().moveTo(self.mouseX, self.mouseY).lineTo(tempLine.x1, tempLine.y1).end(); } function clickTopBarHandler(event, sender) { var newValue = self.tempValue; if (self._checkLineIsCross(newValue, tempLine.mapValue)) {} else { var newX0 = map(newValue, this.min, this.max, this.axisLeft, this.axisRight); lineElt.begin().moveTo(newX0, tempLine.y0).lineTo(tempLine.x1, tempLine.y1).end(); line_hitboxElt.attr('d', lineElt.attr('d')); tempLine.$topMarker.moveTo(newX0, tempLine.y0); tempLine.$topMarker.text = this.numberToString(this.generateValue(newValue)); tempLine.$topPlot.attr({ cx: newX0, cy: tempLine.y0 }); tempLine.x0 = newX0; tempLine.value = newValue; tempLine.$topMarker.removeStyle('visibility', 'hidden'); tempLine.$topPlot.removeStyle('visibility', 'hidden'); self.off('clicktop', clickTopBarHandler); self.off('mousemove', mouseMoveHandler); self.off('keydown', KeyDownHandler); self.state = STATE_READY; this.emit('editline', this.content, this); } } function cancel() { lineElt.begin().moveTo(tempLine.x0, tempLine.y0).lineTo(tempLine.x1, tempLine.y1).end(); line_hitboxElt.attr('d', lineElt.attr('d')); } ; function deleteElt() { self.removeElementInObject(tempLine); self._lineList = self._lineList.filter(function (elt) { return elt.value != tempLine.value && elt.mapValue != tempLine.mapValue; }); this.emit('removeline', this.content, this); } ; function KeyDownHandler(event) { tempLine.$topMarker.removeStyle('visibility', 'hidden'); tempLine.$topPlot.removeStyle('visibility', 'hidden'); if (event.key == "Escape") { cancel(); event.preventDefault(); } else if (event.key == "Delete") { deleteElt(); event.preventDefault(); } self.off('clicktop', clickTopBarHandler); self.off('mousemove', mouseMoveHandler); self.off('keydown', KeyDownHandler); self.state = STATE_READY; } ; self.on('clicktop', clickTopBarHandler); self.on('mousemove', mouseMoveHandler); self.on('keydown', KeyDownHandler); } function clickBotPlotHandler(event) { self.state = STATE_MODIFY; tempLine.$botMarker.addStyle('visibility', 'hidden'); tempLine.$botPlot.addStyle('visibility', 'hidden'); function mouseMoveHandler(event) { lineElt.begin().moveTo(tempLine.x0, tempLine.y0).lineTo(self.mouseX, self.mouseY).end(); } function clickBotBarHandler(event, sender) { var newValue = self.tempValue; if (self._checkLineIsCross(tempLine.value, newValue)) {} else { var newX1 = map(newValue, this.min, this.max, this.axisLeft, this.axisRight); lineElt.begin().moveTo(tempLine.x0, tempLine.y0).lineTo(newX1, tempLine.y1).end(); line_hitboxElt.attr('d', lineElt.attr('d')); tempLine.$botMarker.moveTo(newX1, tempLine.y1); tempLine.$botMarker.text = this.numberToString(this.generateValue(newValue)); tempLine.$botPlot.attr({ cx: newX1, cy: tempLine.y1 }); tempLine.x1 = newX1; tempLine.mapValue = newValue; tempLine.$botMarker.removeStyle('visibility', 'hidden'); tempLine.$botPlot.removeStyle('visibility', 'hidden'); self.off('clickbot', clickBotBarHandler); self.off('mousemove', mouseMoveHandler); self.off('keydown', KeyDownHandler); self.state = STATE_READY; this.emit('editline', this.content, this); } } function cancel() { lineElt.begin().moveTo(tempLine.x0, tempLine.y0).lineTo(tempLine.x1, tempLine.y1).end(); line_hitboxElt.attr('d', lineElt.attr('d')); } ; function deleteElt() { self.removeElementInObject(tempLine); self._lineList = self._lineList.filter(function (elt) { return elt.value != tempLine.value && elt.mapValue != tempLine.mapValue; }); } ; function KeyDownHandler(event) { tempLine.$botMarker.removeStyle('visibility', 'hidden'); tempLine.$botPlot.removeStyle('visibility', 'hidden'); if (event.key == "Escape") { cancel(); event.preventDefault(); } else if (event.key == "Delete") { deleteElt(); event.preventDefault(); } self.off('clickbot', clickBotBarHandler); self.off('mousemove', mouseMoveHandler); self.off('keydown', KeyDownHandler); self.state = STATE_READY; } ; self.on('clickbot', clickBotBarHandler); self.on('mousemove', mouseMoveHandler); self.on('keydown', KeyDownHandler); } tempLine.$line_hitbox.on("click", clickLineHandler); tempLine.$topPlot.on("click", clickTopPlotHandler); tempLine.$botPlot.on("click", clickBotPlotHandler); }; MappingChart.prototype.setLineElt = function (value, mapValue) { value = this.generateValue(value); mapValue = this.generateValue(mapValue); var x0 = map(value, this.min, this.max, this.axisLeft, this.axisRight); var y0 = this.axisTop; var x1 = map(mapValue, this.min, this.max, this.axisLeft, this.axisRight); var y1 = this.axisBottom; var tempLine; var cLine; tempLine = { value: value, mapValue: mapValue, $line: MappingChart_('shape.mapping-chart-map-line').addTo(this.$background), $line_hitbox: MappingChart_('shape.mapping-chart-map-line-hitbox.vchart-hitbox').addTo(this.$middleground), $topMarker: MappingChart_({ tag: 'mappingchartmarker' }).addTo(this.$forceground), $topPlot: circle(20, 20, 5, 'mapping-chart-line-plot').addTo(this.$forceground), $botMarker: MappingChart_({ tag: 'mappingchartmarker', props: { rotate180: true } }).addTo(this.$forceground), $botPlot: circle(20, 20, 5, 'mapping-chart-line-plot').addTo(this.$forceground), x0: x0, x1: x1, y0: y0, y1: y1 }; tempLine.x0 = x0; tempLine.y0 = y0; tempLine.x1 = x1; tempLine.y1 = y1; tempLine.$topMarker.moveTo(x0, y0); tempLine.$topPlot.attr({ cx: x0, cy: y0 }); tempLine.$botMarker.moveTo(x1, y1); tempLine.$botPlot.attr({ cx: x1, cy: y1 }); tempLine.$topMarker.text = this.numberToString(value); tempLine.$botMarker.text = this.numberToString(mapValue); tempLine.$line.begin().moveTo(x0, y0).lineTo(x1, y1).end(); tempLine.$line_hitbox.attr('d', tempLine.$line.attr('d')); ///todo this.settupEvent(tempLine); this._lineList.push(tempLine); }; MappingChart.prototype.removeElementInObject = function (object) { Object.keys(object).forEach(function (key) { if (typeof object[key].remove == 'function') object[key].remove(); }); }; MappingChart.property = {}; MappingChart.property.content = { set: function set(content) { this._lineList.forEach(function (lineData) { this.removeElementInObject(lineData); }.bind(this)); this._lineList = []; this.sync.then(function () { for (var i = 0; i < content.length; i++) { this.setLineElt(content[i].value, content[i].mapValue); } }.bind(this)); // }, get: function get() { var ret = this._lineList.map(function (lineData) { return { value: lineData.value, mapValue: lineData.mapValue }; }); ret.sort(function (a, b) { return a.value - b.value; }); return ret; } }; /** * @typedef MapLine * @property {Number} value * @property {Number} mapValue * @property {Path} $line * @property {MappingChartMarker} $topMarker * @property {MappingChartMarker} $botMarker * @property {circle} $botPlot * @property {circle} $botPlot */ MappingChart.prototype.init = function (props) { this.on('mousemove', this.eventMoveHandler.bind(this)); this.on('keydown', this.eventKeyDownHandler.bind(this)); this.preInit(); this._lineList = []; this.sync = this.sync.then(this.update.bind(this)); this["super"](props); this.state = STATE_READY; /** * @type {Array<MapLine>} */ this.initComp(); }; function MappingChartMarker() { var res = MappingChart_({ // tag:'g', "class": 'mapping-chart-marker', attr: { transform: translate(200, 200) } }); res.$box = MappingChart_('shape.mapping-chart-marker-box').addTo(res); res.$text = helper_text('', 0, -10, 'mapping-chart-marker-text').attr('text-anchor', 'middle').addTo(res); res.sync = res.afterAttached(); return res; } MappingChartMarker.prototype.updateBox = function () { var textBBox = this.$text.getBBox(); if (this.rotate180) { this.$box.begin().moveTo(0, 0).lineTo(-2, 5).lineTo(-textBBox.width / 2 - 5, 5).lineTo(-textBBox.width / 2 - 5, textBBox.height + 2 + 5).lineTo(textBBox.width / 2 + 5, +textBBox.height + 2 + 5).lineTo(textBBox.width / 2 + 5, 5).lineTo(2, 5).end(); this.$text.attr('y', 3 + textBBox.height); } else { this.$box.begin().moveTo(0, 0).lineTo(-2, -5).lineTo(-textBBox.width / 2 - 5, -5).lineTo(-textBBox.width / 2 - 5, -textBBox.height - 2 - 5).lineTo(textBBox.width / 2 + 5, -textBBox.height - 2 - 5).lineTo(textBBox.width / 2 + 5, -5).lineTo(2, -5).end(); this.$text.attr('y', -10); } }; MappingChartMarker.prototype.moveTo = function (x, y) { this.attr('transform', translate(x, y)); return this; }; MappingChartMarker.property = {}; MappingChartMarker.property.text = { set: function set(value) { this._text = value + ''; this.$text.innerHTML = this._text; this.updateBox(); }, get: function get() { return this._text || ''; } }; MappingChartMarker.property.rotate180 = { set: function set(value) { this._rotate180 = !!value; this.updateBox(); }, get: function get() { return !!this._rotate180; } }; MappingChartMarker.attribute = {}; MappingChartMarker.attribute.rotate180 = { set: function set(value) { this.rotate180 = value == 'true' || value === true; }, get: function get() { return this.rotate180 ? 'true' : 'false'; }, remove: function remove() { this.rotate180 = false; } }; MappingChartMarker.attribute.rotate180 = { set: function set(value) { value = parseFloat(value + ''); if (isNumber(value)) { this.hitboxWidth = value; } }, get: function get() { return this.hitboxWidth + ''; }, remove: function remove() { this.hitboxWidth = 6; } }; MappingChartMarker.prototype.init = function (props) { this["super"](props); this.sync.then(this.updateBox.bind(this)); }; src_VCore.creator.mappingchartmarker = MappingChartMarker; src_VCore.creator.mappingchart = MappingChart; /* harmony default export */ const src_MappingChart = ((/* unused pure expression or super */ null && (MappingChart))); ;// CONCATENATED MODULE: ./template/salaryimgchart.svg /* harmony default export */ const salaryimgchart = ("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!-- Created with Inkscape (http://www.inkscape.org/) -->\n<svg width=\"560\" height=\"320\" version=\"1.1\" viewBox=\"0 0 560 320\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n <defs>\n <marker id=\"Arrow1Send\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"scale(.2) rotate(180) translate(6)\" d=\"m0 0 5-5-17.5 5 17.5 5-5-5z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-width=\"1pt\"/>\n </marker>\n <marker id=\"Arrow1Sstart\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"scale(.2) translate(6)\" d=\"m0 0 5-5-17.5 5 17.5 5-5-5z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-width=\"1pt\"/>\n </marker>\n <marker id=\"Arrow2Mend\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"scale(-.6)\" d=\"m8.7186 4.0337-10.926-4.0177 10.926-4.0177c-1.7455 2.3721-1.7354 5.6175-6e-7 8.0354z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-linejoin=\"round\" stroke-width=\".625\"/>\n </marker>\n <marker id=\"Arrow2Mstart\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"scale(.6)\" d=\"m8.7186 4.0337-10.926-4.0177 10.926-4.0177c-1.7455 2.3721-1.7354 5.6175-6e-7 8.0354z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-linejoin=\"round\" stroke-width=\".625\"/>\n </marker>\n <marker id=\"Arrow1Sstart-8\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"matrix(.2 0 0 .2 1.2 0)\" d=\"m0 0 5-5-17.5 5 17.5 5z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-width=\"1pt\"/>\n </marker>\n <marker id=\"Arrow1Send-3\" overflow=\"visible\" orient=\"auto\">\n <path transform=\"matrix(-.2 0 0 -.2 -1.2 0)\" d=\"m0 0 5-5-17.5 5 17.5 5z\" fill-rule=\"evenodd\" stroke=\"#000\" stroke-width=\"1pt\"/>\n </marker>\n </defs>\n <metadata>\n <rdf:RDF>\n <cc:Work rdf:about=\"\">\n <dc:format>image/svg+xml</dc:format>\n <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n <dc:title/>\n </cc:Work>\n </rdf:RDF>\n </metadata>\n </g>\n</svg>\n"); ;// CONCATENATED MODULE: ./src/ImagesChart.js var ImagesChart_ = src_VCore._; var ImagesChart_$ = src_VCore.$; /** * @deprecated * @constructor */ function SalaryImgChart() {} SalaryImgChart.tag = 'SalaryImgChart'.toLowerCase(); SalaryImgChart.render = function () { return ImagesChart_(salaryimgchart.replace(/(.|[\r\n])+\<svg/, '<svg')).addClass('image-chart').addClass('base-chart'); }; SalaryImgChart.property = {}; SalaryImgChart.prototype.preInit = function () { //this is defaul and can not be change this.bonus = 20; this.distance = 400; this.minDistance = 10; this.colTexts = ['Bậc 1', 'Bậc n -1', 'Bậc n']; this.distText = 'Khoảng cách lương'; this.minDistText = 'Khoảng cách tối thiểu'; this.bonusText = 'Hệ số ưu đãi (20%)'; }; SalaryImgChart.prototype.initComp = function () { this.$ox = ImagesChart_('shape.image-chart-ox').addTo(this); this.$oxDash = ImagesChart_('shape.image-chart-ox[stroke-dasharray="4, 2"]').addTo(this); this.$bases = [ImagesChart_('rect.image-chart-base').addTo(this), ImagesChart_('rect.image-chart-base').addTo(this), ImagesChart_('rect.image-chart-base').addTo(this)]; this.$bonuses = [ImagesChart_('rect.image-chart-bonus').addTo(this), ImagesChart_('rect.image-chart-bonus').addTo(this), ImagesChart_('rect.image-chart-bonus').addTo(this)]; this.$distRange = ImagesChart_('shape.image-chart-range[marker-end="url(#Arrow2Mend)"][marker-start="url(#Arrow2Mstart)"]').addTo(this); this.$minDistRange = ImagesChart_('shape.image-chart-range[marker-end="url(#Arrow1Send)"][marker-start="url(#Arrow1Sstart)"]').addTo(this); this.$bonusRange = ImagesChart_('shape.image-chart-range[marker-end="url(#Arrow1Send)"][marker-start="url(#Arrow1Sstart)"]').addTo(this); this.$distTop = ImagesChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); this.$distBot = ImagesChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); this.$minDistBot = ImagesChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); this.$bonusTop = ImagesChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); this.$bonusBot = ImagesChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); this.$distText = helper_text('', 0, 0).addTo(this); this.$minDistText = helper_text('', 0, 0).attr('text-anchor', 'end').addTo(this); this.$bonusText = helper_text('', 0, 0).addTo(this); this.$lvTexts = [null, null, null].map(function () { return helper_text('', 0, 0).attr('text-anchor', 'middle').addTo(this); }.bind(this)); }; SalaryImgChart.prototype.updateComp = function () { var width = 560; var height = 320; var maxColHeight = 288; var _this = this; this.oxY = height - 20; this.colWidth = 40; this.oxSeg = [10, 100, 260, 500]; this.xCols = [37, 272, 373]; this.heightCols = [maxColHeight / (1 + this.distance / 100), maxColHeight / (1 + this.minDistance / 100), maxColHeight]; //<path d="m2.9298 290.03h21.626m43.891 0h51.013" fill="none" stroke="#4472c4" stroke-width=".26458px"/> this.$ox.begin().moveTo(this.oxSeg[0], this.oxY + 1).lineTo(this.oxSeg[1], this.oxY + 1).moveTo(this.oxSeg[2], this.oxY + 1).lineTo(this.oxSeg[3], this.oxY + 1).end(); // <path d="m24.555 290.03h43.891" fill="none" stroke="#4372c4" stroke-dasharray="1.05999993, 0.52999997" stroke-width=".265"/> this.$oxDash.begin().moveTo(this.oxSeg[1], this.oxY + 1).lineTo(this.oxSeg[2], this.oxY + 1).end(); this.heightBase = this.heightCols.map(function (hc) { return map(100, 0, 100 + _this.bonus, 0, hc); }); this.heightBonus = this.heightCols.map(function (hc) { return map(_this.bonus, 0, 100 + _this.bonus, 0, hc); }); this.$bases.forEach(function (e, i) { var x = _this.xCols[i]; var height = _this.heightBase[i]; e.attr({ x: x, y: _this.oxY - height, width: _this.colWidth, height: height }); }); this.$bonuses.forEach(function (e, i) { var x = _this.xCols[i]; var height = _this.heightBonus[i]; e.attr({ x: x, y: _this.oxY - _this.heightCols[i], width: _this.colWidth, height: height }); }); this.$distRange.begin().moveTo(this.xCols[0] - 13, this.oxY - this.heightBase[2] + 2).lineTo(this.xCols[0] - 13, this.oxY - this.heightBase[0] - 2).end(); this.$minDistRange.begin().moveTo(this.xCols[1] - 38, this.oxY - this.heightBase[2] + 1).lineTo(this.xCols[1] - 38, this.oxY - this.heightBase[1] - 1).end(); this.$bonusRange.begin().moveTo(this.xCols[2] + 13 + this.colWidth, this.oxY - this.heightBase[2] - this.heightBonus[2] + 1).lineTo(this.xCols[2] + 13 + this.colWidth, this.oxY - this.heightBase[2] - 1).end(); this.$distTop.begin().moveTo(this.xCols[0] - 13, this.oxY - this.heightBase[2]).lineTo(this.xCols[2], this.oxY - this.heightBase[2]).end(); this.$distBot.begin().moveTo(this.xCols[0] - 13, this.oxY - this.heightBase[0]).lineTo(this.xCols[0], this.oxY - this.heightBase[0]).end(); this.$minDistBot.begin().moveTo(this.xCols[1] - 38, this.oxY - this.heightBase[1]).lineTo(this.xCols[1], this.oxY - this.heightBase[1]).end(); this.$bonusBot.begin().moveTo(this.xCols[2] + this.colWidth, this.oxY - this.heightBase[2]).lineTo(this.xCols[2] + 13 + this.colWidth, this.oxY - this.heightBase[2]).end(); this.$bonusTop.begin().moveTo(this.xCols[2] + this.colWidth, this.oxY - this.heightBase[2] - this.heightBonus[2]).lineTo(this.xCols[2] + 13 + this.colWidth, this.oxY - this.heightBase[2] - this.heightBonus[2]).end(); this.$distText.innerHTML = this.distText; this.$distText.attr({ x: this.xCols[0] - 7, y: this.oxY - (this.heightBase[2] + this.heightBase[0]) / 2 + 5 }); this.$minDistText.innerHTML = this.minDistText; this.$minDistText.attr({ x: this.xCols[1] - 38 - 6, y: this.oxY - (this.heightBase[2] + this.heightBase[1]) / 2 + 5 }); this.$bonusText.innerHTML = this.bonusText; this.$bonusText.attr({ x: this.xCols[2] + 13 + this.colWidth + 6, y: this.oxY - this.heightBase[2] - this.heightBonus[2] / 2 + 5 }); this.$lvTexts.forEach(function (e, i) { e.innerHTML = _this.colTexts[i]; e.attr({ x: _this.xCols[i] + _this.colWidth / 2, y: _this.oxY + 15 }); }); }; SalaryImgChart.prototype.init = function (props) { this.preInit(); this["super"](props); this.initComp(); this.updateComp(); }; src_VCore.install(SalaryImgChart); /* harmony default export */ const ImagesChart = ((/* unused pure expression or super */ null && (SalaryImgChart))); ;// CONCATENATED MODULE: ./src/SalaryScaleChart.js var SalaryScaleChart_ = src_VCore._; var SalaryScaleChart_$ = src_VCore.$; /** * * @constructor */ function SalaryScaleChart() { this.resizeCtrl = new ChartResizeController(this); } SalaryScaleChart.tag = 'SalaryScaleChart'.toLowerCase(); SalaryScaleChart.render = function () { var svg = SalaryScaleChart_(salaryimgchart.replace(/(.|[\r\n])+<svg/, '<svg')).addClass('image-chart').addClass('vc-image-chart').addClass('vc-chart'); svg.$attachhook = SalaryScaleChart_('sattachhook').addTo(svg); return SalaryScaleChart_({ tag: svg_SvgCanvas.tag, elt: svg }); }; // SalaryScaleChart.prototype.updateSize = function () { // // this.attr({ // // width: this.canvasWidth, // // height: this.canvasHeight, // // viewBox: [0, 0, this.canvasWidth, this.canvasHeight].join(' ') // // }) // }; SalaryScaleChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.update(); }; SalaryScaleChart.prototype.initComp = function () { this.$colTexts = this.colTexts.map(function () { return helper_text('', 100, 100).attr('text-anchor', 'middle').addTo(this); }.bind(this)); this.$bases = this.colTexts.map(function () { return SalaryScaleChart_('rect.image-chart-base').addTo(this); }.bind(this)); this.$bonuses = this.colTexts.map(function () { return SalaryScaleChart_('rect.image-chart-bonus').addTo(this); }.bind(this)); this.$oxLine = SalaryScaleChart_('shape.image-chart-ox').addTo(this); this.$oxDash = SalaryScaleChart_('shape.image-chart-ox[stroke-dasharray="4, 2"]').addTo(this); this.$sizeTexts = this.sizeTexts.map(function () { return helper_text('', 100, 100).addTo(this); }.bind(this)); this.$ranges = this.sizeTexts.map(function () { return SalaryScaleChart_('shape.image-chart-range[marker-end="url(#Arrow2Mend)"][marker-start="url(#Arrow2Mstart)"]', 100, 100).addTo(this); }.bind(this)); this.$hLine = Array(5).fill(0).map(function () { return SalaryScaleChart_('shape.image-chart-range-limit[stroke-dasharray="2, 1"]').addTo(this); }.bind(this)); }; SalaryScaleChart.prototype.updateText = function () { var self = this; this.$colTexts.forEach(function (elt, i) { var text = self.colTexts[i]; elt.innerHTML = text; elt.attr('y', self.oy); }); this.oy -= getMaxHeightBox.apply(null, this.$colTexts); this.oy -= this.textMargin; this.$sizeTexts.forEach(function (elt, i) { var text = self.sizeTexts[i]; elt.innerHTML = text; }); this.oxLength -= getMaxWidthBox(this.$sizeTexts[0], this.$sizeTexts[1]); this.oxLength -= this.textMargin; }; SalaryScaleChart.prototype.updateAxis = function () { var self = this; var leftCol = this.ox + this.axisPadding; var rightCol = this.ox + this.oxLength - this.axisPadding - this.rangeMargin - this.colWidth; this.colXs = [leftCol, leftCol / 3 + rightCol * 2 / 3, rightCol]; this.$oxLine.begin().moveTo(this.ox, this.oy).lineTo(this.ox + this.oxLength / 4, this.oy).moveTo(this.ox + this.oxLength / 2, this.oy).lineTo(this.ox + this.oxLength, this.oy).end(); this.$oxDash.begin().moveTo(this.ox + this.oxLength / 4, this.oy).lineTo(this.ox + this.oxLength / 2, this.oy).end(); this.$colTexts.forEach(function (elt, i) { elt.attr('x', self.colXs[i] + self.colWidth / 2); }); this.maxColHeight = this.oy - this.paddingContent; }; SalaryScaleChart.prototype.updateCols = function () { var self = this; this.heightCols = [this.maxColHeight / (1 + this.distance / 100), this.maxColHeight / (1 + this.minDistance / 100), this.maxColHeight]; if (this.bonus < 0) { this.heightCols = this.heightCols.map(function (x) { return x * (100 + self.bonus) / 100; }); } if (this.bonus < 0) { this.addClass('as-bonus-under-100-percent'); } else { this.removeClass('as-bonus-under-100-percent'); } this.baseHeight = this.heightCols.map(function (h) { return h / (100 + self.bonus) * 100; }); this.bonusHeight = this.heightCols.map(function (h) { return h / (100 + self.bonus) * self.bonus; }); this.$bases.forEach(function (e, i) { var height = self.baseHeight[i]; e.attr({ x: self.colXs[i], y: self.oy - height, width: self.colWidth, height: height }); }); if (this.bonus >= 0) { this.$bonuses.forEach(function (e, i) { var height = self.bonusHeight[i]; e.attr({ x: self.colXs[i], y: self.oy - self.heightCols[i], width: self.colWidth, height: height }); }); } else { this.$bonuses.forEach(function (e, i) { var height = self.bonusHeight[i]; e.attr({ x: self.colXs[i], y: self.oy - self.heightCols[i] + height, width: self.colWidth, height: -height }); }); } }; SalaryScaleChart.prototype.updateRange = function () { var self = this; var rangeX = this.colXs.map(function (x) { return x + self.colWidth + self.rangeMargin; }); this.$ranges[0].begin().moveTo(rangeX[2], this.oy - this.baseHeight[2] + this.arrowPadding).lineTo(rangeX[2], this.oy - this.baseHeight[0] - this.arrowPadding).end(); this.$ranges[1].begin().moveTo(rangeX[2], this.oy - this.baseHeight[0] + this.arrowPadding).lineTo(rangeX[2], this.oy - this.arrowPadding).end(); this.$ranges[2].begin().moveTo(rangeX[1], this.oy - this.baseHeight[2] + this.arrowPadding).lineTo(rangeX[1], this.oy - this.baseHeight[1] - this.arrowPadding).end(); this.$ranges[3].begin().moveTo(rangeX[1], this.oy - this.baseHeight[1] + this.arrowPadding).lineTo(rangeX[1], this.oy - this.arrowPadding).end(); this.$ranges[4].begin().moveTo(rangeX[0], this.oy - this.heightCols[0] + this.arrowPadding).lineTo(rangeX[0], this.oy - this.arrowPadding).end(); this.$hLine[0].begin().moveTo(this.colXs[2] + this.colWidth, this.oy - this.baseHeight[2]).lineTo(rangeX[2], this.oy - this.baseHeight[2]).end(); this.$hLine[1].begin().moveTo(this.colXs[2], this.oy - this.baseHeight[2]).lineTo(rangeX[1], this.oy - this.baseHeight[2]).end(); this.$hLine[2].begin().moveTo(this.colXs[1] + this.colWidth, this.oy - this.baseHeight[1]).lineTo(rangeX[1], this.oy - this.baseHeight[1]).end(); this.$hLine[3].begin().moveTo(this.colXs[0] + this.colWidth, this.oy - this.heightCols[0]).lineTo(rangeX[0], this.oy - this.heightCols[0]).end(); this.$hLine[4].begin().moveTo(this.colXs[0] + this.colWidth, this.oy - this.baseHeight[0]).lineTo(rangeX[2], this.oy - this.baseHeight[0]).end(); //a this.$sizeTexts[0].attr({ x: rangeX[2] + this.textMargin, y: this.oy - (this.baseHeight[2] + this.baseHeight[0]) / 2 + 4 }); //b this.$sizeTexts[1].attr({ x: rangeX[2] + this.textMargin, y: this.oy - this.baseHeight[0] / 2 + 4 }); //c this.$sizeTexts[2].attr({ x: rangeX[1] + this.textMargin, y: this.oy - (this.baseHeight[2] + this.baseHeight[1]) / 2 + 4 }); //d this.$sizeTexts[3].attr({ x: rangeX[1] + this.textMargin, y: this.oy - this.baseHeight[1] / 2 + 4 }); //e this.$sizeTexts[4].attr({ x: rangeX[0] + this.textMargin, y: this.oy - this.heightCols[0] / 2 + 4 }); }; SalaryScaleChart.prototype.update = function () { this.oy = this.canvasHeight - this.paddingContent; this.oxLength = this.canvasWidth - 2 * this.paddingContent; this.ox = this.paddingContent; this.updateText(); this.updateAxis(); this.updateCols(); this.updateRange(); }; SalaryScaleChart.prototype.preInit = function () { this.canvasWidth = 560; this.canvasHeight = 320; this.paddingContent = 10; this.colTexts = ['Bậc 1', 'Bậc n -1', 'Bậc n']; this.sizeTexts = ['a', 'b', 'c', 'd', 'e']; this.bonus = 20; this.distance = 80; this.minDistance = 10; // this.sizeTexts = ['Lương tối đa', 'b', 'c', 'd', 'e']; this.colWidth = 40; this.textMargin = 5; this.axisPadding = 30; this.rangeMargin = 20; this.arrowPadding = 2.5; }; SalaryScaleChart.prototype.init = function (props) { this.preInit(); this["super"](props); this.initComp(); this.$attachhook.once('attached', this.update.bind(this)); }; SalaryScaleChart.property = {}; SalaryScaleChart.property.canvasHeight = { set: function set(value) { this.addStyle('height', value + 'px'); this.box.height = value; }, get: function get() { return this.box.height; } }; SalaryScaleChart.property.canvasWidth = { set: function set(value) { this.addStyle('width', value + 'px'); this.box.width = value; }, get: function get() { return this.box.width; } }; src_VCore.install('SalaryScaleChart'.toLowerCase(), SalaryScaleChart); ;// CONCATENATED MODULE: ./src/HorizontalBarChart.js var HorizontalBarChart_ = src_VCore._; var HorizontalBarChart_$ = src_VCore.$; function HorizontalBarChart() { var self = this; this.resizeCtrl = new ChartResizeController(this); this._bars = []; this._vLines = []; this._title = ''; this._ranges = []; this._includeValues = []; this._dataUpdateTimeout = -1; this._padding = 5; this._ox = 0; this._oy = 0; this._oxLength = 0; this._oyLength = 0; this._oyTop = 25; this._oxRight = this._padding; this._barWidth = 35; this._rangeWidth = 15; this._minValue = 0; this._maxValue = 10; this._keys = []; this._keyColors = []; this._barMargin = 5; this._zeroOY = true; this._maxSegment = 10; this._minRangeText = "Min"; this._maxRangeText = "Max"; /** * @type {import('./Axis').default} */ this.$axis = HorizontalBarChart_$('axis', this); this.$title = HorizontalBarChart_$('text.vc-horizontal-bar-title', this); this.$whiteBoxMask = HorizontalBarChart_$('.base-chart-white-mask', this); this.$content = HorizontalBarChart_$('.vc-horizontal-bar-chart-content', this); this.$noteContainer = HorizontalBarChart_$('g.vc-horizontal-bar-note-container', this); this.$noteBox = HorizontalBarChart_$('.vc-horizontal-bar-vline-note-box', this); this.$oneBarNoteContainer = HorizontalBarChart_$('g.vc-horizontal-bar-one-bar-note-container', this); // this.$keysNoteContainer = $('g.vc-horizontal-bar-keys-note-container', this); this.$vLinesNoteContainer = HorizontalBarChart_$('g.vc-horizontal-bar-vline-note-container', this); this.$segmentTextContainer = HorizontalBarChart_$('g.vc-horizontal-bar-segment-text-container', this); this.$vLineContainer = HorizontalBarChart_$('g.vc-horizontal-bar-vline-container', this); this.$valueLineContainer = HorizontalBarChart_$('.vc-horizontal-bar-chart-value-line-container', this); this.$keys = []; this.$segmentTexts = []; this.$valueLines = []; this.$bars = []; this.$ranges = []; this.$vLines = []; this.$attachhook = HorizontalBarChart_$("sattachhook", this).on('error', function (error) { this.updateSize = this.updateSize || self.updatePosition.bind(self); Dom/* default.addToResizeSystem */.ZP.addToResizeSystem(this); }); this.sync = new Promise(function (rs) { self.$attachhook.on('error', rs); }); this.sync.then(this.notifyDataChange.bind(this)); } HorizontalBarChart.tag = 'HorizontalBarChart'.toLowerCase(); HorizontalBarChart.prototype._createKeyNote = function (color, keyName) { return HorizontalBarChart_({ "class": 'vc-horizontal-bar-key-note', child: [rect(0, 0, 14, 14).addStyle('fill', color), helper_text(keyName, 17, 12)] }); }; HorizontalBarChart.prototype._createVLineNote = function (color, keyName) { return HorizontalBarChart_({ "class": 'vc-horizontal-bar-vline-note', child: [hline(0, 7, 20).addStyle('stroke', color), helper_text(keyName, 25, 12)] }); }; HorizontalBarChart.prototype.processData = function () { this._minValue = this._bars.concat(this._includeValues).reduce(function (ac, cr) { return Math.min(ac, cr); }, 10000000); this._minValue = this._ranges.reduce(function (ac, cr) { return Math.min(ac, cr[0], cr[1]); }, this._minValue); this._maxValue = this._bars.concat(this._includeValues).reduce(function (ac, cr) { return Math.max(ac, cr); }, -10000000); this._maxValue = this._ranges.reduce(function (ac, cr) { return Math.max(ac, cr[1], cr[0]); }, this._maxValue); if (this._zeroOY) this._minValue = Math.min(0, this._minValue); this._beautiSegment = calBeautySegment(this._maxSegment, this._minValue, this._maxValue); }; HorizontalBarChart.prototype.initBarNote = function () { this.$oneBarNoteContainer.$minText = helper_text(this._minRangeText, 0, 14).addTo(this.$oneBarNoteContainer); this.$oneBarNoteContainer.$maxText = helper_text(this._maxRangeText, 0, 14 + 10 + this._barWidth + 10 + 14).addTo(this.$oneBarNoteContainer); this.$oneBarNoteContainer.$bar = this.$oneBarNoteContainer.$bar || rect(0.5, 14 + 10 + 0.5, 100, this._barWidth - 1, 'vc-horizontal-bar-chart-bar').addTo(this.$oneBarNoteContainer); this.$oneBarNoteContainer.$range = this.$oneBarNoteContainer.$range || rect(80.5, 14 + 10 + Math.floor((this._barWidth - this._rangeWidth) / 2) + 0.5, 30, this._rangeWidth - 1, 'vc-horizontal-bar-chart-range').addTo(this.$oneBarNoteContainer); this.$oneBarNoteContainer.$minLine = vline(80.5, 14 + 10 + Math.floor((this._barWidth - this._rangeWidth) / 3), -Math.floor((this._barWidth - this._rangeWidth) / 3) - 5, 'vc-horizontal-bar-chart-range-min-line').addTo(this.$oneBarNoteContainer); this.$oneBarNoteContainer.$maxLine = vline(80.5 + 30, 14 + 10 + this._barWidth - Math.floor((this._barWidth - this._rangeWidth) / 2), Math.floor((this._barWidth - this._rangeWidth) / 2) + 8, 'vc-horizontal-bar-chart-range-max-line').addTo(this.$oneBarNoteContainer); }; HorizontalBarChart.prototype.updateOneBarNotePosition = function () { var minTextBox = this.$oneBarNoteContainer.$minText.getBBox(); var maxTextBox = this.$oneBarNoteContainer.$maxText.getBBox(); var maxTextLength = Math.max(minTextBox.width, maxTextBox.width); if (minTextBox.width / 2 > 80.5) { this.$oneBarNoteContainer.$bar.attr('x', Math.floor(maxTextLength / 2 - 80.5) + 0.5 + ''); this.$oneBarNoteContainer.$range.attr('x', Math.floor(maxTextLength / 2 - 80.5) + 0.5 + 80 + ''); moveVLine(this.$oneBarNoteContainer.$minLine, Math.floor(minTextBox.width / 2 - 80.5) + 0.5 + 80, 14 + 10 + Math.floor((this._barWidth - this._rangeWidth) / 3), -Math.floor((this._barWidth - this._rangeWidth) / 3) - 5); moveVLine(this.$oneBarNoteContainer.$maxLine, Math.floor(minTextBox.width / 2 - 80.5) + 0.5 + 80 + 30, 14 + 10 + this._barWidth - Math.floor((this._barWidth - this._rangeWidth) / 2), Math.floor((this._barWidth - this._rangeWidth) / 2) + 8); } else { this.$oneBarNoteContainer.$minText.attr('x', 80.5 - minTextBox.width / 2); this.$oneBarNoteContainer.$maxText.attr('x', 80.5 + 30 - maxTextBox.width / 2); } }; HorizontalBarChart.prototype.generateColor = function () { var colorLength = Math.max(this._keys.length, this._bars.length) + this._vLines.length; if (this._keyColors.length < colorLength) { this._keyColors = generateBackgroundColors(colorLength).map(function (c) { return fresherColor(c); }); } }; HorizontalBarChart.prototype.initKeysNote = function () { var self = this; this.$keysNoteContainer.clearChild(); this.$keyNotes = this._keys.map(function (text, i) { var color = self._keyColors[i]; return self._createKeyNote(color, text).addTo(self.$keysNoteContainer); }); }; HorizontalBarChart.prototype.initVLinesNote = function () { var self = this; this.$vLinesNoteContainer.clearChild(); this.$vLineNotes = this._vLines.map(function (vline, i) { return self._createVLineNote(vline.color || lighterColor(self._keyColors[self._keys.length + i], -0.2), vline.name + '').addTo(self.$vLinesNoteContainer).attr('transform', translate(0, i * 20)); }); }; HorizontalBarChart.prototype.initNote = function () { this.initVLinesNote(); this.initBarNote(); }; HorizontalBarChart.prototype.updateNotePosition = function () { this.updateOneBarNotePosition(); var y = this._padding; var x = this._padding; this.$vLinesNoteContainer.attr('transform', translate(x, y)); y += this.$vLinesNoteContainer.getBBox().height + 5 + this._padding; this.$oneBarNoteContainer.attr('transform', translate(this._padding, y)); this.$noteBox.attr({ width: '1', height: '1' }); //align right var box = this.$noteContainer.getBBox(); this.$noteBox.attr({ width: box.width + this._padding - 1 + '', height: box.height + this._padding - 1 + '' }); this.$noteContainer.attr('transform', translate(this._canvasWidth - this._padding - box.width - this._padding, this._canvasHeight / 3 - (box.height + this._padding) / 2)); this._oxRight = this._canvasWidth - box.width - this._padding * 2; }; HorizontalBarChart.prototype.initAxisText = function () { while (this.$keys.length < this._keys.length) { this.$keys.push(helper_text('', 0, 0, 'vc-horizontal-bar-chart-key').addTo(this.$content)); } while (this.$keys.length > this._keys.length) { this.$keys.pop().remove(); } for (var i = 0; i < this._keys.length; ++i) { this.$keys[i].innerHTML = this._keys[i]; } while (this.$segmentTexts.length > this._beautiSegment.segmentCount + 1) { this.$segmentTexts.pop().remove(); } while (this.$segmentTexts.length < this._beautiSegment.segmentCount + 1) { this.$segmentTexts.push(helper_text('', 0, 0, 'vc-horizontal-bar-chart-segment-text').addTo(this.$segmentTextContainer)); } for (var i = 0; i < this.$segmentTexts.length; ++i) { this.$segmentTexts[i].innerHTML = this._beautiSegment.minValue + this._beautiSegment.step * i + ''; } this.$valueLineContainer.clearChild(); this.$valueLines = Array(this.$segmentTexts.length - 1).fill(0).map(function () { return vline(0, 0, 0, 'vc-horizontal-bar-chart-value-line').addTo(this.$valueLineContainer); }.bind(this)); }; HorizontalBarChart.prototype.initBars = function () { while (this.$bars.length < this._bars.length) { this.$bars.push(rect(0, 0, 0, this._barWidth, 'vc-horizontal-bar-chart-bar').addTo(this.$content)); } while (this.$bars.length > this._bars.length) { this.$bars.pop().remove(); } for (var i = 0; i < this.$bars.length; ++i) { this.$bars[i].addStyle('fill', this._keyColors[i]); } }; HorizontalBarChart.prototype.initRanges = function () { while (this.$ranges.length < this._ranges.length) { this.$ranges.push(rect(0, 0, 0, this._rangeWidth, 'vc-horizontal-bar-chart-range').addTo(this.$content)); } while (this.$ranges.length > this._ranges.length) { this.$ranges.pop().remove(); } for (var i = 0; i < this.$ranges.length; ++i) { this.$ranges[i].addStyle('fill', lighterColor(this._keyColors[i], 0.3)); } }; HorizontalBarChart.prototype.initVLines = function () { var self = this; this.$vLineContainer.clearChild(); this.$vLines = this._vLines.map(function (vLineData, i) { return vline(0, 0, 0, 'vc-horizontal-bar-vline').addStyle('stroke', vLineData.color || lighterColor(self._keyColors[self._keys.length + i], -0.2)).addTo(self.$vLineContainer); }); }; HorizontalBarChart.prototype.notifyDataChange = function () { if (this._dataUpdateTimeout >= 0) return; var self = this; this._dataUpdateTimeout = setTimeout(function () { self.update(); self._dataUpdateTimeout = -1; }); }; HorizontalBarChart.prototype.updateCanvasSize = function () { var bound = this.getBoundingClientRect(); this._canvasHeight = this.__canvasHeight; this._canvasWidth = this.__canvasWidth; if (!(this._canvasWidth > 0)) { this._canvasWidth = bound.width; } if (!(this._canvasHeight > 0)) { this._canvasHeight = bound.height; } this.attr('width', this._canvasWidth + ''); this.attr('height', this._canvasHeight + ''); this._oyTop = 25 + this.$title.getBBox().height * 1.5; this._ox = this._padding; this._oy = this._canvasHeight - this._padding; this._oxLength = this._oxRight - this._padding - this._ox; this._oyLength = this._oy - this._padding - this._oyTop; }; HorizontalBarChart.prototype.updateAxisPosition = function () { this.$axis.moveTo(this._ox - 0.5, this._oy - 0.5); this.$axis.resize(this._oxLength + 15, this._oyLength + 10); this.$whiteBoxMask.attr('d', 'M0,0 0,cvh cvw,cvh cvw,0zMleft,top left,bottom right,bottom right,topz'.replace(/cvh/g, this._canvasHeight).replace(/cvw/g, this._canvasWidth).replace(/left/g, this._padding).replace(/top/g, 10).replace(/bottom/g, this._oy).replace(/right/g, this._canvasWidth - 10)); this.$title.attr('x', (this._oxRight + this._ox) / 2 + ''); }; HorizontalBarChart.prototype.updateAxisTextPosition = function () { var maxWidthKey = getMaxWidthBox.apply(null, this.$keys); this._ox = Math.ceil(maxWidthKey) + 0.5 + this._padding + 5; this._oxLength = this._oxRight - this._padding - this._ox; this._oy -= 21; this._oyLength = this._oy - this._padding - this._oyTop; var barMargin = Math.max(this._barMargin, (this._oyLength / this._keys.length - this._barWidth) / 2); var i; for (i = 0; i < this.$keys.length; ++i) { this.$keys[i].attr({ x: -5, y: -(i + 0.5) * (barMargin * 2 + this._barWidth) + 7 }); this.$bars[i].attr('y', -i * (barMargin * 2 + this._barWidth) - barMargin - this._barWidth); this.$ranges[i].attr('y', -i * (barMargin * 2 + this._barWidth) - barMargin - this._barWidth + Math.floor((this._barWidth - this._rangeWidth) / 2)); } this._segmentLength = this._oxLength / this._beautiSegment.segmentCount; for (i = 0; i < this.$segmentTexts.length; ++i) { this.$segmentTexts[i].attr({ x: this._ox + this._segmentLength * i, y: this._oy + 18 }); } for (i = 0; i < this.$valueLines.length; ++i) { moveVLine(this.$valueLines[i], this._ox + this._segmentLength * (i + 1), this._oy - this._oyLength, this._oyLength); } this.$content.attr('transform', translate(this._ox, this._oy)); }; HorizontalBarChart.prototype.updateBarsPosition = function () { for (var i = 0; i < this.$bars.length; ++i) { this.$bars[i].attr('width', map(this._bars[i], this._beautiSegment.minValue, this._beautiSegment.maxValue, 0, this._oxLength)); } }; HorizontalBarChart.prototype.updateRangesPosition = function () { var left, right, range; for (var i = 0; i < this.$bars.length; ++i) { range = this._ranges[i]; left = map(range[0], this._beautiSegment.minValue, this._beautiSegment.maxValue, 0, this._oxLength); right = map(range[1], this._beautiSegment.minValue, this._beautiSegment.maxValue, 0, this._oxLength); this.$ranges[i].attr({ width: right - left + '', x: left + '' }); } }; HorizontalBarChart.prototype.updateVLinesPosition = function () { for (var i = 0; i < this.$vLines.length; ++i) { moveVLine(this.$vLines[i], this._ox + map(this._vLines[i].value, this._beautiSegment.minValue, this._beautiSegment.maxValue, 0, this._oxLength), this._oy - this._oyLength, this._oyLength); } }; HorizontalBarChart.prototype.updatePosition = function () { this.updateCanvasSize(); this.updateNotePosition(); this.updateAxisTextPosition(); this.updateBarsPosition(); this.updateRangesPosition(); this.updateVLinesPosition(); this.updateAxisPosition(); }; HorizontalBarChart.prototype.update = function () { this.generateColor(); this.processData(); this.initNote(); this.initAxisText(); this.initBars(); this.initRanges(); this.initVLines(); this.updatePosition(); }; HorizontalBarChart.property = {}; HorizontalBarChart.property.canvasWidth = { set: function set(value) { if (value >= 0) { this.attr('width', undefined); this.__canvasWidth = value; } else { this._canvasWidth = -1; } this.notifyDataChange(); }, get: function get() { return this.__canvasWidth; } }; HorizontalBarChart.property.canvasHeight = { set: function set(value) { if (value >= 0) { this.attr('height', undefined); this.__canvasHeight = value; } else { this.__canvasHeight = -1; } this.notifyDataChange(); }, get: function get() { return this.__canvasHeight; } }; HorizontalBarChart.property.keys = { set: function set(value) { this._keys = value || []; this.notifyDataChange(); }, get: function get() { return this._keys; } }; HorizontalBarChart.property.bars = { set: function set(value) { this._bars = value || []; this.notifyDataChange(); }, get: function get() { return this._bars; } }; HorizontalBarChart.property.ranges = { set: function set(value) { this._ranges = value || []; this.notifyDataChange(); }, get: function get() { return this._ranges; } }; HorizontalBarChart.property.vLines = { set: function set(value) { this._vLines = value || []; this.notifyDataChange(); }, get: function get() { return this._vLines; } }; HorizontalBarChart.property.includeValues = { set: function set(value) { this._includeValues = value || []; this.notifyDataChange(); }, get: function get() { return this._includeValues; } }; HorizontalBarChart.property.maxSegment = { set: function set(value) { this._maxSegment = value || 10; }, get: function get() { return this._maxSegment; } }; HorizontalBarChart.property.title = { set: function set(value) { this._title = value || ''; this.$title.innerHTML = this._title; this.notifyDataChange(); }, get: function get() { return this._title; } }; HorizontalBarChart.property.minRangeText = { set: function set(value) { this._minRangeText = value || ''; this.notifyDataChange(); }, get: function get() { return this._minRangeText; } }; HorizontalBarChart.property.maxRangeText = { set: function set(value) { this._maxRangeText = value || ''; this.notifyDataChange(); }, get: function get() { return this._maxRangeText; } }; HorizontalBarChart.property.title = { set: function set(value) { this._title = value || ''; this.$title.innerHTML = this._title; this.notifyDataChange(); }, get: function get() { return this._title; } }; HorizontalBarChart.render = function () { return HorizontalBarChart_({ tag: 'svg', "class": ['vc-horizontal-bar-chart', 'base-chart'], child: ['.vc-horizontal-bar-chart-value-line-container', '.vc-horizontal-bar-chart-content', { tag: 'path', "class": 'base-chart-white-mask', attr: { fill: 'white', stroke: 'white', 'fill-rule': 'evenodd', d: 'M0,0 0,2000 2000,2000 2000,0zM100,100 100,200 200,200 200,100z' } }, 'axis', 'g.vc-horizontal-bar-segment-text-container', 'g.vc-horizontal-bar-vline-container', { "class": 'vc-horizontal-bar-note-container', child: [rect(0.5, 0.5, 1, 1, 'vc-horizontal-bar-vline-note-box'), 'g.vc-horizontal-bar-vline-note-container', 'g.vc-horizontal-bar-one-bar-note-container'] }, 'text.vc-horizontal-bar-title[y="20"]', 'sattachhook'] }); }; src_VCore.install('HorizontalBarChart'.toLowerCase(), HorizontalBarChart); /* harmony default export */ const src_HorizontalBarChart = ((/* unused pure expression or super */ null && (HorizontalBarChart))); // EXTERNAL MODULE: ./src/style/spiderchart.css var spiderchart = __webpack_require__(9563); ;// CONCATENATED MODULE: ./src/NoteGrid.js var NoteGrid_ = src_VCore._; var NoteGrid_$ = src_VCore.$; function NoteGrid() { this._width = NaN; this._height = NaN; this._itemMargin = 0; this._padding = 0; this.$content = NoteGrid_$('.vchart-node-grid-content', this); this.$box = NoteGrid_$('rect.vchart-node-grid-box', this); this.boxWidth = 0; this.boxHeight = 0; } NoteGrid.tag = 'NoteGrid'.toLowerCase(); NoteGrid.prototype.updateSize = function () { // this. var children = Array.prototype.slice.call(this.$content.children); var bBoxes = children.map(function (e) { return e.getBBox(); }); var maxWidth = bBoxes.reduce(function (ac, cr) { return Math.max(ac, cr.width); }, 0); var maxHeight = bBoxes.reduce(function (ac, cr) { return Math.max(ac, cr.height); }, 0); var availableWidth; if (this._width > 0) availableWidth = this._width;else availableWidth = this._padding * 2 + (children.length - 1) * this._itemMargin + children.length * maxWidth; var itemPerRow = Math.floor((availableWidth - this._padding * 2 + this._itemMargin + 0.1) / (maxWidth + this._itemMargin)); var marginRight = (availableWidth - this._padding * 2 - itemPerRow * maxWidth) / (itemPerRow - 1); //in view var availableHeight; var itemPerCol = Math.ceil(children.length / itemPerRow); if (this._height > 0) availableHeight = this._height;else availableHeight = this._padding * 2 + (itemPerCol - 1) * this._itemMargin + itemPerCol * maxHeight; var marginBottom = (availableHeight - this._padding * 2 - itemPerCol * maxHeight) / (itemPerCol - 1); //in view this.boxWidth = availableWidth; this.boxHeight = availableHeight; this.$box.attr({ x: 0, y: 0, width: availableWidth, height: availableHeight }); var i = 0; var x, y; if (isNaN(marginBottom)) marginBottom = 0; if (isNaN(marginRight)) marginRight = 0; for (var rIndex = 0; rIndex < itemPerCol && i < children.length; ++rIndex) { for (var cIndex = 0; cIndex < itemPerRow && i < children.length; ++cIndex) { x = this._padding + cIndex * (maxWidth + marginRight); y = this._padding + rIndex * (maxHeight + marginBottom); children[i].attr('transform', translate(x, y)); ++i; } } }; ['addChild', 'clearChild', 'removeChild', 'addChildBefore', 'findChildBefore', 'findChildAfter'].forEach(function (name) { NoteGrid.prototype[name] = function () { return this.$content[name].apply(this.$content, arguments); }; }); NoteGrid.render = function () { return NoteGrid_({ "class": 'vchart-node-grid', child: ['rect.vchart-node-grid-box', '.vchart-node-grid-content'] }); }; NoteGrid.attribute = {}; NoteGrid.attribute.width = { set: function set(value) { value = parseFloat(value); this._width = value; }, get: function get() { return this._width; }, remove: function remove() { this._width = NaN; } }; NoteGrid.attribute.height = { set: function set(value) { value = parseFloat(value); this._height = value; }, get: function get() { return this._height; }, remove: function remove() { this._height = NaN; } }; NoteGrid.attribute.itemMargin = { set: function set(value) { value = parseFloat(value); this._itemMargin = value; }, get: function get() { return this._itemMargin; }, remove: function remove() { this._itemMargin = NaN; } }; NoteGrid.attribute.padding = { set: function set(value) { value = parseFloat(value); this._padding = value; }, get: function get() { return this._padding; }, remove: function remove() { this._padding = NaN; } }; src_VCore.install('NoteGrid'.toLowerCase(), NoteGrid); /* harmony default export */ const src_NoteGrid = ((/* unused pure expression or super */ null && (NoteGrid))); ;// CONCATENATED MODULE: ./src/SpiderChart.js var SpiderChart_ = src_VCore._; var SpiderChart_$ = src_VCore.$; function SpiderChart() { this.$attachhook = SpiderChart_('attachhook').addTo(this).on('attached', this.eventHandler.attached); this.$background = SpiderChart_$('.vchart-spider-chart-background', this); this.$axisCtn = SpiderChart_$('.vchart-spider-chart-axis-ctn', this.$background); this.$forceground = SpiderChart_$('.vchart-spider-chart-forceground', this); this.$title = SpiderChart_$('.base-chart-title', this.$forceground); this.$noteCtn = SpiderChart_$('.vchart-spider-chart-note-ctn', this); this._canvasWidth = 'auto'; this._canvasHeight = 'auto'; this._viewCanvasHeight = 0; this._viewCanvasWidth = 0; this._resizeCallback = []; this._drew = false; this.ctitle = { text: 'This is title', $elt: this.$title }; this._viewExpected = {}; this._viewOption = {// noteLineLength: 15, // noteBoxHight: 14 }; this.$noteGrid = SpiderChart_$('notegrid', this); } SpiderChart.tag = 'SpiderChart'.toLowerCase(); SpiderChart.render = function () { return SpiderChart_({ tag: 'svg', "class": 'vchart-base', child: [{ "class": 'vchart-spider-chart-background', child: ['.vchart-spider-chart-axis-ctn'] }, { "class": 'vchart-spider-chart-content' }, { "class": 'vchart-spider-chart-forceground', child: ['text.base-chart-title', '.vchart-spider-chart-note-ctn'] }, { tag: 'notegrid', attr: { itemMargin: 20, padding: 5 }, child: [{ tag: src_KeyNote, attr: { transform: translate(10, 20) }, props: { type: 'line', text: 'Long long text', color: 'red' } }, { tag: src_KeyNote, attr: { transform: translate(10, 40) }, props: { type: 'rect', text: 'Long long text', color: 'red' } }] }] }); }; /** * @param {Array<Rectangle>} rects * @returns {Rectangle} */ SpiderChart.prototype._expectSize = function (rects, r) { var cr = new Rectangle(0, 0, 0, 0); var rect; for (var i = 0; i < rects.length; ++i) { var angle = Math.PI * 2 * i / rects.length - Math.PI / 2; rect = rects[i]; if (i == 0) { rect.x = rect.width / 2; rect.y = -rect.height - r; } else if (rects.length % 4 == 0 && i == rects.length >> 2) { rect.x = r; rect.y = rect.height / 2; } else if (rects.length % 4 == 0 && i == (rects.length >> 2) * 3) { rect.x = -r - rect.width; rect.y = rect.height / 2; } else if (rects.length % 2 == 0 && i == rects.length >> 1) { rect.x = rect.width / 2; rect.y = r; } else if (i < rects.length / 4) { rect.x = r * Math.cos(angle); rect.y = r * Math.sin(angle) - rect.height; } else if (i < rects.length / 2) { rect.x = r * Math.cos(angle); rect.y = r * Math.sin(angle); } else if (i < rects.length / 4 * 3) { rect.x = r * Math.cos(angle) - rect.width; rect.y = r * Math.sin(angle); } else { rect.x = r * Math.cos(angle) - rect.width; rect.y = r * Math.sin(angle) - rect.height; } cr = cr.merge(rect); } return cr; }; SpiderChart.prototype.estimateSize = function () { var axisNameBBoxs = this.$axisNames.map(function (elt) { return elt.getBBox(); }); var rects = axisNameBBoxs.map(function (box) { return new Rectangle(box.x, box.y, box.width, box.height); }); var titleBox = this.$title.getBBox(); var noteGroupBox = this.$noteGroup.getBBox(); var maxR = Math.min(this.canvasWidth, this.canvasHeight) / 2; var minR = 20; // var aWidth = this.canvasWidth - this.paddingContent * 2; var aHeight = this.canvasHeight - this.paddingContent * 2 - titleBox.height * 3 + noteGroupBox.height * 1.5; while (maxR - minR > 3) { var midR = (minR + maxR) / 2; var size = this._expectSize(rects, midR); if (size.width < aWidth && size.height < aHeight) { minR = midR; } else { maxR = midR; } } return { expectedSize: this._expectSize(rects, minR, true), expectedRadius: minR, axisLenth: minR - 30 }; }; SpiderChart.prototype.updateCanvasSize = function () { var bound = this.getBoundingClientRect(); var newHeight = this._canvasHeight; var newWidth = this._canvasWidth; if (!(newHeight > 0)) newHeight = bound.height; if (!(newWidth > 0)) newWidth = bound.witdh; if (newHeight == this._viewCanvasHeight && newWidth == this._viewCanvasWidth) return false; this.attr({ width: newWidth + '', height: newWidth + '' }); return true; }; SpiderChart.prototype.recreate = function () { this._resizeCallback = []; this.recreateTitle(); this.recreateAxis(); this.recreateNotes(); this._resizeCallback.sort(function (a, b) { return a.order - b.order; }); }; SpiderChart.prototype.recreateAxis = function () { var thisChart = this; var oyAxisElts = this.axis.oyAxises.map(function (oyAxis, i, arr) { var lineArrowElt = SpiderChart_('hlinearrow'); lineArrowElt.resize(200); lineArrowElt.attr('transform', rotate(-90 + i * 360 / arr.length)); lineArrowElt.addTo(thisChart.$axisCtn); oyAxis.lineArrowElt = lineArrowElt; return lineArrowElt; }); this.$oyAxises = oyAxisElts; }; SpiderChart.prototype._createLineNote = function (obj) { var res = SpiderChart_('g.vchart-spinder-chart-note'); res.$line = hline(0, 9, 15, 'vc-assessment-chart-area').addStyle('stroke', obj.stroke).addTo(res); res.$name = helper_text(obj.name, 15 + 5, 14).addTo(res); return res; }; SpiderChart.prototype._createBoxNote = function (obj) { var res = SpiderChart_('g.vchart-spinder-chart-note'); res.$line = hline(0, 9, 15, 'vc-assessment-chart-area').addStyle('stroke', obj.stroke).addTo(res); res.$name = helper_text(obj.name, 15 + 5, 14).addTo(res); return res; }; //todo more SpiderChart.prototype.recreateNotes = function () { var thisChart = this; this.$noteCtn.clearChild(); this.$notes = this.objects.map(function (obj) { var noteElt = thisChart._createLineNote(obj); noteElt.addTo(thisChart.$noteCtn); }); }; SpiderChart.prototype.recreateTitle = function () { this.ctitle.elt = this.$title; this.$title.clearChild().addChild(SpiderChart_({ text: this.ctitle.text || '' })); }; SpiderChart.prototype.updateSize = function (force) { if (!force && !this.updateCanvasSize()) return; // nothing change this.$noteGrid.updateSize(); }; SpiderChart.prototype.redraw = function () { this.recreate(); this.updateSize(true); }; /** * @type {SpiderChart} */ SpiderChart.eventHandler = {}; SpiderChart.eventHandler.attached = function () { if (!this._drew) { this._drew = true; this.redraw(); } else { this.updateSize(); } }; SpiderChart.property = {}; src_VCore.install('spiderchart', SpiderChart); /* harmony default export */ const src_SpiderChart = ((/* unused pure expression or super */ null && (SpiderChart))); // EXTERNAL MODULE: ./src/style/funnelchart.css var funnelchart = __webpack_require__(8901); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/AElement.js var AElement = __webpack_require__(7951); ;// CONCATENATED MODULE: ./src/FunnelChart.js var FunnelChart_ = src_VCore._; var FunnelChart_$ = src_VCore.$; /*** * @extends AElement * @constructor */ function FunnelChart() { this.resizeCtrl = new ChartResizeController(this); this.$attachhook = FunnelChart_$('sattachhook.av-hook', this); this.$attachhook.on('attached', this.eventHandler.attached); this.$attachhook.requestUpdateSize = this.updateSize.bind(this); this.domSignal = new DomSignal/* default */.ZP(FunnelChart_$('sattachhook.av-signal', this)).on('_createContent', this.createContent.bind(this)).on('_alignContent', this._alignContent.bind(this)).on('_updateContent', this._updateContent.bind(this)); this.$content = FunnelChart_$('.av-funnel-content', this); this.$funnelCtn = FunnelChart_$('.av-funnel-ctn', this); this.$noteCtn = FunnelChart_$('.av-funnel-note-ctn', this); this.$notes = []; this._contentMargin = 5; this._contentWidth = 0; this._contentHeight = 0; this.$title = FunnelChart_$('.vc-title', this); this.$blocks = []; this.blocks = []; this._cavasWidth = 0; this._canvasHeight = 0; this.domSignal.emit('_updateContent'); } FunnelChart.tag = 'FunnelChart'.toLowerCase(); FunnelChart.render = function () { return FunnelChart_({ tag: 'svg', "class": ['vc-chart', 'av-funnel-chart'], child: [{ tag: 'text', "class": 'vc-title', child: { text: '' } }, { "class": 'av-funnel-content', child: [{ "class": 'av-funnel-ctn', child: { "class": 'av-funnel' } }, { "class": 'av-funnel-note-ctn', child: [] }] }, 'sattachhook.av-hook', 'sattachhook.av-signal'] }); }; FunnelChart.prototype._updateCanvasSize = function () { var bound = this.getBoundingClientRect(); var width = bound.width; var height = bound.height; this._canvasHeight = height; this._cavasWidth = width; this.attr('width', width + ''); this.attr('height', height + ''); this.attr('viewBox', [0.5, 0.5, width, height].join(' ')); }; FunnelChart.prototype.updateSize = function () { this._updateCanvasSize(); this._alignContent(); }; FunnelChart.prototype.normalizeData = function () { var blockColor = generateBackgroundColors(this.blocks.length); var sum = this.blocks.reduce(function (ac, cr) { return ac + cr.value; }, 0); this.blocks.forEach(function (block, i) { block.color = block.color || blockColor[i]; block.percent = block.value * 100 / sum; }); }; FunnelChart.prototype.createContent = function () { this.normalizeData(); this.$title.firstChild.data = this.title + ''; this.$funnelCtn.clearChild(); this._createNote(); this._createFunnel(); }; FunnelChart.prototype._createNote = function () { var thisC = this; this.$noteCtn.clearChild(); this.$notes = this.blocks.map(function (block) { var noteElt = thisC._makeNote(block); thisC.$noteCtn.addChild(noteElt); return noteElt; }); }; FunnelChart.prototype._createFunnel = function () { var thisC = this; this.$blocks = this.blocks.map(function (block) { var blockElt = thisC._makeBlock(block); thisC.$funnelCtn.addChild(blockElt); return blockElt; }); }; FunnelChart.prototype._makeNote = function (block) { var $note = FunnelChart_({ "class": 'av-funnel-note', child: [{ tag: 'text', style: { fill: block.color }, attr: { y: 30 }, "class": 'av-funnel-note-name', child: { text: block.name } }, { "class": 'av-funnel-note-desc' }] }); $note.$name = FunnelChart_$('av-funnel-note-name', $note); return $note; }; FunnelChart.prototype._makeBlock = function (block) { var valueColor = Color/* default.parse */.Z.parse(block.color + '').getContrastYIQ(); var percenColor = valueColor.clone(); percenColor.rgba[0] = (percenColor.rgba[0] + Math.sqrt(0.5)) / 2; percenColor.rgba[1] = (percenColor.rgba[1] + Math.sqrt(0.5)) / 2; percenColor.rgba[2] = (percenColor.rgba[2] + Math.sqrt(0.5)) / 2; var $block = FunnelChart_({ "class": 'av-funnel-block', child: [{ tag: 'shape', "class": 'av-funnel-block-shape', style: { fill: block.color + '' } }, { tag: 'text', "class": 'av-funnel-block-value', attr: { y: 25 }, style: { fill: valueColor + '' }, child: { text: block.value } }, { tag: 'text', "class": 'av-funnel-block-percent', attr: { y: 55 }, style: { fill: percenColor + '' }, child: { text: block.percent.toFixed(1) + '%' } }] }); $block.$shape = FunnelChart_$('shape', $block); $block.$value = FunnelChart_$('.av-funnel-block-value', $block); return $block; }; FunnelChart.prototype._alignNote = function () { var dy = this._contentHeight / this.blocks.length; this._stackHeight = dy; this.$notes.forEach(function (noteElt, i) { noteElt.attr({ transform: translate(0, dy * i) }); }); var noteWidth = this.$noteCtn.getBBox().width; this._noteCtnX = this._contentWidth - noteWidth; this.$noteCtn.attr({ transform: translate(this._noteCtnX, 0) }); }; FunnelChart.prototype._alignFunnel = function () { var thisC = this; this._funnelWidth = this._noteCtnX - 20; var maxValue = this.blocks.reduce(function (ac, block) { return Math.max(ac, block.value); }, 0); this.$funnelCtn.attr('transform', translate(this._funnelWidth / 2, 0)); this.$blocks.forEach(function (blockElt, i) { var block = thisC.blocks[i]; var nextBlock = thisC.blocks[i + 1] || block; var y = i * thisC._stackHeight; blockElt.$shape.begin().moveTo(-thisC._funnelWidth / 2 * block.value / maxValue, 0).lineTo(thisC._funnelWidth / 2 * block.value / maxValue, 0).lineTo(thisC._funnelWidth / 2 * nextBlock.value / maxValue, thisC._stackHeight).lineTo(-thisC._funnelWidth / 2 * nextBlock.value / maxValue, thisC._stackHeight).closePath().end(); blockElt.attr('transform', translate(0, y)); }); }; FunnelChart.prototype._alignContent = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('_alignContent'); return; } this.$title.attr({ x: this._cavasWidth / 2, y: 14 + this._contentMargin }); this.$content.attr('transform', translate(this._contentMargin, this._contentMargin + 50)); this._contentWidth = this._cavasWidth - this._contentMargin * 2; this._contentHeight = this._canvasHeight - this._contentMargin * 2 - 50; this._alignNote(); this._alignFunnel(); }; FunnelChart.prototype._updateContent = function () { this.createContent(); this._alignContent(); }; /*** * * @type {FunnelChart} */ FunnelChart.eventHandler = {}; FunnelChart.eventHandler.attached = function () { ResizeSystem/* default.add */.Z.add(this.$attachhook); this.updateSize(); }; src_VCore.install(FunnelChart); /* harmony default export */ const src_FunnelChart = ((/* unused pure expression or super */ null && (FunnelChart))); // EXTERNAL MODULE: ./src/style/barstackchart.css var barstackchart = __webpack_require__(5768); ;// CONCATENATED MODULE: ./src/BarStackChart.js var BarStackChart_ = src_VCore._; var BarStackChart_$ = src_VCore.$; /*** * @extends SvgCanvas * @constructor */ function BarStackChart() { var _this = this; this._contentMargin = 5; /*** * * @type {GContainer} */ this.$content = BarStackChart_$('.vc-bar-stack-content', this); this.$content.box.setPosition(40, 5); /*** * * @type {GContainer} */ this.$noteCtn = BarStackChart_$('.vc-bar-stack-note-ctn', this); /*** * * @type {GContainer} */ this.$stack = BarStackChart_$('.vc-bar-stack', this); this.domSignal = new DomSignal/* default */.ZP(BarStackChart_$('sattachhook.vc-dom-signal', this)); this.domSignal.on('_updateContentPosition', this.updateContentPosition.bind(this)).on('updateContent', this.updateContent.bind(this)); this.blocks = []; this.$blocks = []; this.$notes = []; this.domSignal.emit('updateContent'); this.resizeCtrl = new ChartResizeController(this); (0,DataStructure_Object/* observePropertyChanges */.U)(this, ['blocks'], function () { _this.domSignal.emit('updateContent'); }); } BarStackChart.tag = 'BarStackChart'.toLowerCase(); BarStackChart.render = function () { return BarStackChart_({ tag: 'svgcanvas', "class": ['vc-bar-stack-chart', 'base-chart'], child: [{ tag: 'gcontainer', "class": 'vc-bar-stack-content', child: [{ tag: 'gcontainer', "class": 'vc-bar-stack-note-ctn' }, { tag: 'gcontainer', "class": 'vc-bar-stack' }] }, 'sattachhook.vc-dom-signal'] }); }; BarStackChart.prototype.revokeResource = function () { (0,DataStructure_Object/* unobservePropertyChanges */.i3)(this, ['blocks']); (0,utils.revokeResource)(this.resizeCtrl); this.revokeResource = noop/* default */.Z; while (this.lastChild) { (0,utils.revokeResource)(this.lastChild); this.lastChild.remove(); } }; BarStackChart.prototype.normalizeData = function () { var blockColor = generateBackgroundColors(this.blocks.length); var sum = this.blocks.reduce(function (ac, cr) { return ac + cr.value; }, 0); this.blocks.forEach(function (block, i) { block.color = block.color || blockColor[i]; block.percent = block.percent || block.value * 100 / sum; }); }; BarStackChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updateContentPosition(); }; /*** * * @param block * @returns {GContainer} * @private */ BarStackChart.prototype._makeNote = function (block) { var noteElt = BarStackChart_({ tag: 'gcontainer', "class": 'vc-bar-stack-note', child: [{ tag: 'text', "class": 'vc-bar-stack-note-name', style: { fill: block.color + '' }, attr: { y: 15, x: 0 }, child: { text: block.name } }, { tag: 'text', "class": 'vc-bar-stack-note-desc' }] }); noteElt.$name = BarStackChart_$('.vc-bar-stack-note-name', this); noteElt.$desc = BarStackChart_$('.vc-bar-stack-note-desc', this); return noteElt; }; /*** * * @param block * @returns {GContainer} * @private */ BarStackChart.prototype._makeBlock = function (block) { var valueColor = Color/* default.parse */.Z.parse(block.color + '').getContrastYIQ(); var percenColor = valueColor.clone(); percenColor.rgba[0] = (percenColor.rgba[0] + Math.sqrt(0.5)) / 2; percenColor.rgba[1] = (percenColor.rgba[1] + Math.sqrt(0.5)) / 2; percenColor.rgba[2] = (percenColor.rgba[2] + Math.sqrt(0.5)) / 2; var blockElt = BarStackChart_({ tag: 'gcontainer', "class": 'vc-bar-stack-block', child: [{ tag: 'rect', "class": 'vc-bar-stack-block-rect', style: { fill: block.color }, attr: { x: -250, y: 0, width: 500, height: 10 } }, { tag: 'text', "class": 'vc-bar-stack-block-value', attr: { y: 25 }, style: { fill: valueColor + '' }, child: { text: block.value } }, { tag: 'text', "class": 'vc-bar-stack-block-percent', attr: { y: 55 }, style: { fill: percenColor + '' }, child: { text: block.percent.toFixed(1) + '%' } }] }); blockElt.$rect = BarStackChart_$('.vc-bar-stack-block-rect', blockElt); return blockElt; }; BarStackChart.prototype._createNote = function () { var thisC = this; this.$noteCtn.clearChild(); this.$notes = this.blocks.map(function (block) { var noteElt = thisC._makeNote(block); thisC.$noteCtn.addChild(noteElt); return noteElt; }); }; BarStackChart.prototype._createStack = function () { var thisC = this; this.$stack.clearChild(); this.$blocks = this.blocks.map(function (block) { var blockElt = thisC._makeBlock(block); thisC.$stack.addChild(blockElt); return blockElt; }); }; BarStackChart.prototype.createContent = function () { this.normalizeData(); this._createNote(); this._createStack(); }; BarStackChart.prototype.updateContentPosition = function () { if (!this.isDescendantOf(document.body)) { this.emit('_updateContentPosition'); return; } this.$content.box.setPosition(this._contentMargin, 40); this.$content.box.setSize(this.box.width - 2 * this._contentMargin, this.box.height - this._contentMargin - 40); this._updateNotePosition(); this._updateStackPosition(); }; BarStackChart.prototype._updateNotePosition = function () { var thisC = this; var noteCtnBox = this.$noteCtn.getBBox(); this.$noteCtn.box.setSize(noteCtnBox.width, this.$content.box.height); this.$noteCtn.box.setPosition(this.$content.box.width - noteCtnBox.width, 0); var dy = this.$noteCtn.box.height / this.blocks.length; this.$notes.forEach(function (noteElt, i) { noteElt.box.y = dy * i + dy / 2 - 7; }); }; BarStackChart.prototype._updateStackPosition = function () { var thisC = this; this.$stack.box.setSize(this.$content.box.width - this.$noteCtn.box.width - 20, this.$content.box.height); this.$stack.box.x = this.$stack.box.width / 2; //to center var dy = this.$noteCtn.box.height / this.blocks.length; var width = this.$stack.box.width; var maxValue = this.blocks.reduce(function (ac, cr) { return Math.max(ac, cr.value); }, 0); this.$blocks.forEach(function (blockElt, i) { var block = thisC.blocks[i]; blockElt.box.y = dy * i; blockElt.$rect.attr({ height: dy, width: block.value / maxValue * width, x: -block.value / maxValue * width / 2 }); }); }; BarStackChart.prototype.updateContent = function () { this.createContent(); this.updateContentPosition(); }; src_VCore.install(BarStackChart); /* harmony default export */ const src_BarStackChart = ((/* unused pure expression or super */ null && (BarStackChart))); // EXTERNAL MODULE: ./src/style/piechart.css var piechart = __webpack_require__(3468); // EXTERNAL MODULE: ./node_modules/absol/src/Math/Polygon.js var Polygon = __webpack_require__(9894); ;// CONCATENATED MODULE: ./src/PieChart.js var PieChart_ = src_VCore._; var PieChart_$ = src_VCore.$; /*** * @typedef VCPiece * @property {string} name * @property {number} value * @property {string} valueText * @property {string} fillColor * @property {boolean} separated */ /*** * @extends BChart * @constructor */ function PieChart() { src_BChart.call(this); this.titleCtrl.revokeResource(); delete this.titleCtrl; this.$pieCtn = this.$body; this.$pie = PieChart_('gcontainer'); this.$pieCtn.addChild(this.$pie); /*** * * @type {VCPiece[]} */ this.pieces = []; } OOP/* default.mixClass */.ZP.mixClass(PieChart, src_BChart); PieChart.property = Object.assign({}, src_BChart.property); PieChart.eventHandler = Object.assign({}, src_BChart.eventHandler); PieChart.tag = 'PieChart'.toLowerCase(); PieChart.render = function (data, o, dom) { return src_BChart.render(data, o, dom).addClass('vc-piece-chart'); }; PieChart.eventHandler.mouseEnterNote = function (idx, event) { var pieceElt = this.$pieces[idx]; var textValueElt = this.$pieceValues[idx]; var title = pieceElt.attr('title'); if (!title) { if (this.tooltipToken) closeTooltip(this.tooltipToken); return; } var bound = textValueElt.getBoundingClientRect(); this.tooltipToken = showTooltip(title, bound.left - 3, bound.top + bound.height + 3); }; PieChart.eventHandler.mouseLeaveNote = function (idx) { var token = this.tooltipToken; if (!token) return; setTimeout(function () { closeTooltip(token); }, 1000); }; PieChart.prototype._createPie = function () { var _this = this; this.$pie.clearChild(); var thisC = this; this.$pieces = this.pieces.map(function (piece, idx) { var pieceElt = PieChart_({ tag: 'shape', "class": 'vc-piece', style: { fill: piece.fillColor + '' }, attr: { title: piece.name + ': ' + (piece.valueText || piece.value) }, on: { mouseenter: function mouseenter(event) { _this.eventHandler.mouseEnterNote(idx, event); }, mouseleave: function mouseleave(event) { _this.eventHandler.mouseLeaveNote(idx, event); } } }); thisC.$pie.addChild(pieceElt); return pieceElt; }); this.$pieceValues = this.pieces.map(function (piece) { var valueElt = PieChart_({ tag: 'text', "class": 'vc-piece-value', style: { fill: Color/* default.parse */.Z.parse(piece.fillColor + '').getContrastYIQ() }, child: { text: piece.valueText || piece.value || '' } }); thisC.$pie.addChild(valueElt); return valueElt; }); }; PieChart.prototype.computeNotes = function () { return this.pieces.map(function (piece, i) { return { color: piece.fillColor, text: piece.name, type: 'rect', idx: i }; }); }; PieChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createPie(); }; PieChart.prototype._updatePiePosition = function () { var piece, pieceElt; var sum = this.pieces.reduce(function (ac, cr) { return ac + cr.value; }, 0); this.$pieCenter = PieChart_({ tag: 'circle', attr: { cx: 0, cy: 0, r: 1 }, style: { fill: 'transparent' } }); this.$pie.addChild(this.$pieCenter); var pieCenterBound = this.$pieCenter.getBBox(); var piePoly, jj, textRect, canContain; for (var k = 0; k < 50; ++k) { var startAngle = -Math.PI / 2; var endAngle = 0; var valueElt; var valueBound, pieceBound; var x0, y0; var r = Math.min(this.$pieCtn.box.width - 5, this.$pieCtn.box.height - 5) / 2 * (1 - k / 150); var sr = Math.max(3, r / 15); for (var i = 0; i < this.pieces.length; ++i) { piece = this.pieces[i]; pieceElt = this.$pieces[i]; valueElt = this.$pieceValues[i]; if (piece.value === 0) { pieceElt.addStyle('display', 'none'); valueElt.addStyle('display', 'none'); } else { pieceElt.removeStyle('display'); valueElt.removeStyle('display'); } endAngle = startAngle + Math.PI * 2 * piece.value / sum; x0 = 0; y0 = 0; if (piece.separated) { x0 += sr * Math.cos((startAngle + endAngle) / 2); y0 += sr * Math.sin((startAngle + endAngle) / 2); } pieceElt.begin(); piePoly = []; if (piece.value < sum) { pieceElt.moveTo(x0, y0); pieceElt.lineTo(x0 + r * Math.cos(startAngle), y0 + r * Math.sin(startAngle)); piePoly.push(new Vec2/* default */.Z(x0, y0)); piePoly.push(new Vec2/* default */.Z(x0 + r * Math.cos(startAngle), y0 + r * Math.sin(startAngle))); } else { pieceElt.moveTo(x0 + r * Math.cos(startAngle), y0 + r * Math.sin(startAngle)); piePoly.push(new Vec2/* default */.Z(x0 + r * Math.cos(startAngle), y0 + r * Math.sin(startAngle))); } pieceElt.arcTo(x0 + r * Math.cos((startAngle + endAngle) / 2), y0 + r * Math.sin((startAngle + endAngle) / 2), r, r, 0, 1, 0).arcTo(x0 + r * Math.cos(endAngle), y0 + r * Math.sin(endAngle), r, r, 0, 1, 0).closePath().end(); for (jj = 8; jj >= 0; --jj) { piePoly.push(new Vec2/* default */.Z(x0 + r * Math.cos(startAngle * jj / 8 + endAngle * (8 - jj) / 8), y0 + r * Math.sin(startAngle * jj / 8 + endAngle * (8 - jj) / 8))); } valueBound = valueElt.getBBox(); pieceBound = pieceElt.getBBox(); if (piece.value === sum) { valueElt.attr({ x: 0, y: 7 }); valueElt.removeStyle('visibility'); } else { valueElt.attr({ x: x0 + (r - 20 - valueBound.width / 2) * Math.cos((startAngle + endAngle) / 2), y: y0 + (r - 20 - valueBound.height / 2) * Math.sin((startAngle + endAngle) / 2) + 7 }); textRect = new Math_Rectangle/* default */.Z(x0 + (r - 20 - valueBound.width / 2) * Math.cos((startAngle + endAngle) / 2) - valueBound.width / 2, y0 + (r - 20 - valueBound.height / 2) * Math.sin((startAngle + endAngle) / 2) + 7 - valueBound.height, valueBound.width, valueBound.height); piePoly = new Polygon/* default */.Z(piePoly); canContain = [textRect.A(), textRect.B(), textRect.C(), textRect.D()].every(function (v) { return piePoly.pointLocalIn(v) > 0; }); if (canContain) { valueElt.removeStyle('visibility'); } else { valueElt.addStyle('visibility', 'hidden'); } } startAngle = endAngle; } var piePound = this.$pie.getBBox(); if (piePound.width < this.$pieCtn.box.width && piePound.height < this.$pieCtn.box.height) { this.$pie.box.setPosition(this.$pieCtn.box.width / 2 - (piePound.width / 2 - (pieCenterBound.x + 1 - piePound.x)), this.$pieCtn.box.height / 2 - (piePound.height / 2 - (pieCenterBound.y + 1 - piePound.y))); break; } } }; PieChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updatePiePosition(); }; PieChart.prototype.normalizeData = function () { var colorScheme = this.colorScheme; var blockColors = (0,utils.isNaturalNumber)(colorScheme) ? (0,SelectColorSchemeMenu/* generatorColorScheme */.TD)(colorScheme, this.pieces.length) : generateBackgroundColors(this.pieces.length); this.pieces.forEach(function (piece, i) { piece.fillColor = piece.fillColor || blockColors[i]; }); }; src_VCore.install(PieChart); /* harmony default export */ const src_PieChart = (PieChart); ;// CONCATENATED MODULE: ./src/HCollumnChart.js var HCollumnChart_ = src_VCore._; var HCollumnChart_$ = src_VCore.$; /*** * @extends SvgCanvas * @constructor */ function HColumnChart() { this.$title = HCollumnChart_$('.vc-title', this); console.log(HCollumnChart_$('sattachhook.vc-dom-signal', this)); this.domSignal = new DomSignal/* default */.ZP(HCollumnChart_$('sattachhook.vc-dom-signal', this)); // this.domSignal.on({ // updateContent: this.updateContent.bind(this) // }); // this.emit('updateContent'); } HColumnChart.tag = "HColumnChart".toLowerCase(); HColumnChart.render = function () { return HCollumnChart_({ tag: svg_SvgCanvas.tag, "class": 'vc-h-column-chart', child: [{ tag: 'text', "class": 'vc-title', child: { text: '' }, attr: { y: 20 } }, { "class": 'vc-h-column-root', child: [{ "class": 'vc-h-column-ox-key-ctn' }, { "class": 'vc-h-column-oy-key-ctn' }, { tag: 'hlinearrow' }] }, 'sattachhook.vc-dom-signal'] }); }; HColumnChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updateContentPosition(); }; HColumnChart.prototype.updateContent = function () { if (!this.isDescendantOf(document.body)) { this.domSignal.emit('updateContent'); return; } this.normalizeData(); this.createContent(); this.updateContentPosition(); }; HColumnChart.prototype.normalizeData = function () {}; HColumnChart.prototype._createTitle = function () { this.$title.firstChild.data = this.title; }; HColumnChart.prototype.createContent = function () { this._createTitle(); }; HColumnChart.prototype._alignTitle = function () { this.$title.attr('x', this.box.width / 2); }; HColumnChart.prototype.updateContentPosition = function () { this._alignTitle(); }; src_VCore.install(HColumnChart); /* harmony default export */ const HCollumnChart = ((/* unused pure expression or super */ null && (HColumnChart))); // EXTERNAL MODULE: ./src/style/tinycirclechart.css var tinycirclechart = __webpack_require__(7381); ;// CONCATENATED MODULE: ./src/TinyCircleChart.js /*** * @extends SvgCanvas * @constructor */ function TinyCircleChart() { this.resizeCtrl = new ChartResizeController(this); this.contentPadding = 5; this._arcs = []; this.computedData = { notes: [] }; this.total = NaN; this.$notes = []; this.$noteCtn = VCore_$('.vc-note-ctn', this); this.$arcs = []; this.$content = VCore_$('.vc-content', this); this.$circleBlank = VCore_$('.vc-tiny-circle-blank', this); this.$title = VCore_$('.vc-title', this); } TinyCircleChart.tag = 'TinyCircleChart'.toLowerCase(); TinyCircleChart.render = function () { return VCore_({ tag: svg_SvgCanvas.tag, "class": ['vc-chart', 'vc-tiny-circle-chart'], child: [{ tag: 'gcontainer', "class": 'vc-content', child: [{ tag: 'path', "class": 'vc-tiny-circle-blank' }, { tag: 'text', "class": 'vc-title', attr: { y: '7' }, child: { text: '' } }] }, { tag: 'gcontainer', "class": 'vc-note-ctn' }] }); }; TinyCircleChart.prototype._computeNote = function () { this.computedData.notes = (this._arcs || []).map(function (arc, i, array) { var note = {}; note.color = arc.color || Color/* default.fromHSL */.Z.fromHSL(1 / array.length * i, 0.5, 0.5); note.text = arc.name.replace(/[^\s]+/g, function (all) { if (all === '$value') { return arc.value + ''; } return all; }); note.type = 'rect'; return note; }); this.computedData.estimateNoteWidth = this.computedData.notes.reduce(function (ac, node) { return Math.max((0,utils.measureText)(node.text, '14px arial').width, ac); }, 0) + 28; this.computedData.estimateNoteHeight = this.computedData.notes.length * 20; var screenSize = (0,Dom/* getScreenSize */.tE)(); var fontSize = VCore_$(document.body).getFontSize(); this.computedData.estimateWidth = Math.max(this.computedData.estimateNoteWidth + this.computedData.estimateNoteHeight, 250); if (this.computedData.estimateWidth * fontSize / 14 > screenSize.width - 20) { this.computedData.estimateWidth = this.computedData.estimateNoteWidth; this.computedData.estimateHeight = Math.max(this.computedData.estimateNoteHeight + this.computedData.estimateNoteWidth, 100); } else { this.computedData.estimateHeight = Math.max(this.computedData.estimateNoteHeight + 10, 100); } this.addStyle({ 'min-width': this.computedData.estimateWidth / 14 + 'rem', 'min-height': this.computedData.estimateHeight / 14 + 'rem' }); }; TinyCircleChart.prototype._createNote = src_BChart.prototype._createNote; TinyCircleChart.prototype._updateNotesPosition = function () { var t = VCore_$(document.body).getFontSize(); this.$notes.forEach(function (noteElt, i) { noteElt.box.y = Math.ceil(t * 1.428) * i; }); }; TinyCircleChart.prototype._createArcs = function () { this.$arcs.forEach(function (arc) { arc.remove(); }); this.$arcs = (this._arcs || []).map(function (arc, i, array) { var arcElt = VCore_('path.vc-arc'); arcElt.addStyle('fill', this.computedData.notes[i].color); this.$content.addChild(arcElt); return arcElt; }.bind(this)); }; TinyCircleChart.prototype._updateArcsPosition = function () { var noteBBox = this.$noteCtn.getBBox(); var R = 0; if (this.box.width - noteBBox.width >= this.box.height - noteBBox.height) { R = Math.min(this.box.width - noteBBox.width - 2 * this.contentPadding - 10, this.box.height - this.contentPadding) / 2; this.$noteCtn.box.position = { x: 2 * R + 10 + this.contentPadding, y: this.box.height / 2 - noteBBox.height / 2 }; this.$content.box.position = { x: R + this.contentPadding, y: this.box.height / 2 }; } else { R = Math.min(this.box.height - noteBBox.height - 2 * this.contentPadding - 10, this.box.width - this.contentPadding) / 2; this.$noteCtn.box.position = { y: 2 * R + 10 + this.contentPadding, x: this.box.width / 2 - noteBBox.width / 2 }; this.$content.box.position = { y: R + this.contentPadding, x: this.box.width / 2 }; } var r = Math.min(R - 12, R - R / 10); this.$circleBlank.attr('d', new controller_Turtle().moveTo(0, -R).arcBy(R, R, 0, 0, 1, R, R).arcBy(R, R, 0, 0, 1, -R, R).arcBy(R, R, 0, 0, 1, -R, -R).arcBy(R, R, 0, 0, 1, R, -R).moveTo(0, -r).arcBy(r, r, 0, 0, 1, r, r).arcBy(r, r, 0, 0, 1, -r, r).arcBy(r, r, 0, 0, 1, -r, -r).arcBy(r, r, 0, 0, 1, r, -r).closePath().getPath()); var total = this.total; if (!(total > 0 && total < Infinity && typeof total === "number")) { total = (this._arcs || []).reduce(function (ac, cr) { return ac + cr.value; }, 0); } var angle0, angle1 = -Math.PI / 2; var total2 = Math.max(total, 1); var angleCenter; for (var i = 0; i < this.$arcs.length; ++i) { angle0 = angle1; angle1 = angle1 + Math.PI * 2 * this._arcs[i].value / total2; angleCenter = (angle0 + angle1) / 2; this.$arcs[i].attr('d', new controller_Turtle().moveTo(R * Math.cos(angle0), R * Math.sin(angle0)).arcTo(R, R, 0, this._arcs[i].value > total2 ? 1 : 0, 1, R * Math.cos(angleCenter), R * Math.sin(angleCenter)).arcTo(R, R, 0, this._arcs[i].value > total2 ? 1 : 0, 1, R * Math.cos(angle1), R * Math.sin(angle1)).lineTo(r * Math.cos(angle1), r * Math.sin(angle1)).arcTo(r, r, 0, this._arcs[i].value > total2 ? 1 : 0, 0, r * Math.cos(angleCenter), r * Math.sin(angleCenter)).arcTo(r, r, 0, this._arcs[i].value > total2 ? 1 : 0, 0, r * Math.cos(angle0), r * Math.sin(angle0)).closePath().getPath()); } this.$title.firstChild.data = total + ''; }; TinyCircleChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this._updateArcsPosition(); }; TinyCircleChart.property = {}; TinyCircleChart.property.arcs = { set: function set(value) { this._arcs = value; this._computeNote(); this._createNote(); this._updateNotesPosition(); this._createArcs(); }, get: function get() { return this._arcs; } }; src_VCore.install(TinyCircleChart); /* harmony default export */ const src_TinyCircleChart = (TinyCircleChart); ;// CONCATENATED MODULE: ./src/DoughnutChart.js var DoughnutChart_ = src_VCore._; var DoughnutChart_$ = src_VCore.$; /*** * @typedef VCPiece * @property {string} name * @property {number} value * @property {string} valueText * @property {string} fillColor * @property {boolean} separated */ /*** * @extends BChart * @constructor */ function DoughnutChart() { src_BChart.call(this); this.titleCtrl.revokeResource(); delete this.titleCtrl; this.$pieCtn = this.$body; this.$pie = DoughnutChart_('gcontainer'); this.$pieCtn.addChild(this.$pie); /*** * * @type {VCPiece[]} */ this.pieces = []; } OOP/* default.mixClass */.ZP.mixClass(DoughnutChart, src_BChart); DoughnutChart.property = Object.assign({}, src_BChart.property); DoughnutChart.eventHandler = Object.assign({}, src_BChart.eventHandler); DoughnutChart.prototype.dataKeys = src_BChart.prototype.dataKeys.concat(['pieces']); DoughnutChart.tag = 'DoughnutChart'.toLowerCase(); DoughnutChart.render = function (data, o, dom) { return src_BChart.render(data, o, dom).addClass('vc-piece-chart'); }; DoughnutChart.eventHandler.mouseEnterNote = function (idx, event) { var pieceElt = this.$pieces[idx]; var textValueElt = this.$pieceValues[idx]; var title = pieceElt.attr('title'); if (!title) { if (this.tooltipToken) closeTooltip(this.tooltipToken); return; } var bound = textValueElt.getBoundingClientRect(); this.tooltipToken = showTooltip(title, bound.left - 3, bound.top + bound.height + 3); }; DoughnutChart.eventHandler.mouseLeaveNote = function (idx) { var token = this.tooltipToken; if (!token) return; setTimeout(function () { if (token) closeTooltip(token); }, 1000); }; DoughnutChart.prototype._createPie = function () { var _this = this; this.$pie.clearChild(); var thisC = this; this.$pieces = this.pieces.map(function (piece, idx) { var pieceElt = DoughnutChart_({ tag: 'shape', "class": 'vc-piece', style: { fill: (piece.fillColor || _this.blockColors[idx]) + '' }, attr: { title: piece.name + ': ' + (piece.valueText || piece.value) }, on: { mouseenter: function mouseenter(event) { _this.eventHandler.mouseEnterNote(idx, event); }, mouseleave: function mouseleave(event) { _this.eventHandler.mouseLeaveNote(idx, event); } } }); thisC.$pie.addChild(pieceElt); return pieceElt; }); this.$pieceValues = this.pieces.map(function (piece, idx) { var valueElt = DoughnutChart_({ tag: 'text', "class": 'vc-piece-value', style: { fill: Color/* default.parse */.Z.parse((piece.fillColor || _this.blockColors[idx]) + '').getContrastYIQ() }, child: { text: piece.valueText || piece.value || '' } }); thisC.$pie.addChild(valueElt); return valueElt; }); }; DoughnutChart.prototype.computeNotes = function () { var _this2 = this; return this.pieces.map(function (piece, i) { return { color: piece.fillColor || _this2.blockColors[i], text: piece.name, type: 'rect', idx: i }; }); }; DoughnutChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createPie(); }; DoughnutChart.prototype._updatePiePosition = function () { var piece, pieceElt; var sum = this.pieces.reduce(function (ac, cr) { return ac + cr.value; }, 0); this.$pieCenter = DoughnutChart_({ tag: 'circle', attr: { cx: 0, cy: 0, r: 1 }, style: { fill: 'transparent' } }); this.$pie.addChild(this.$pieCenter); var pieCenterBound = this.$pieCenter.getBBox(); var piePoly, jj, textRect, canContain; for (var k = 0; k < 50; ++k) { var startAngle = -Math.PI / 2; var endAngle = 0; var valueElt; var valueBound, pieceBound; var x0, y0; var cp, p0; var r = Math.min(this.$pieCtn.box.width - 5, this.$pieCtn.box.height - 5) / 2 * (1 - k / 150); var ri = r * 4 / 9; var sr = Math.max(3, r / 15); var makeVec = function makeVec(r, angle) { return new Vec2/* default */.Z(r * Math.cos(angle), r * Math.sin(angle)); }; for (var i = 0; i < this.pieces.length; ++i) { piece = this.pieces[i]; pieceElt = this.$pieces[i]; valueElt = this.$pieceValues[i]; if (piece.value === 0) { pieceElt.addStyle('display', 'none'); valueElt.addStyle('display', 'none'); } else { pieceElt.removeStyle('display'); valueElt.removeStyle('display'); } endAngle = startAngle + Math.PI * 2 * piece.value / sum; x0 = 0; y0 = 0; p0 = new Vec2/* default */.Z(x0, y0); if (piece.separated) { p0 = p0.add(makeVec(sr, (startAngle + endAngle) / 2)); x0 = p0.x; y0 = p0.y; } pieceElt.begin(); piePoly = []; cp = p0.add(makeVec(r, startAngle)); pieceElt.moveTo(cp.x, cp.y); piePoly.push(cp); cp = p0.add(makeVec(r, (startAngle + endAngle) / 2)); pieceElt.arcTo(cp.x, cp.y, r, r, 0, 1, 0); cp = p0.add(makeVec(r, endAngle)); pieceElt.arcTo(cp.x, cp.y, r, r, 0, 1, 0); for (jj = 8; jj >= 0; --jj) { piePoly.push(p0.add(makeVec(r, startAngle * jj / 8 + endAngle * (8 - jj) / 8))); } cp = p0.add(makeVec(ri, endAngle)); if (piece.value < sum) { pieceElt.lineTo(cp.x, cp.y); } else { pieceElt.closePath(); pieceElt.moveTo(cp.x, cp.y); } cp = p0.add(makeVec(ri, (startAngle + endAngle) / 2)); pieceElt.arcTo(cp.x, cp.y, ri, ri, 0, 0, 1); cp = p0.add(makeVec(ri, startAngle)); pieceElt.arcTo(cp.x, cp.y, ri, ri, 0, 0, 1); for (jj = 0; jj <= 8; ++jj) { piePoly.push(p0.add(makeVec(ri, startAngle * jj / 8 + endAngle * (8 - jj) / 8))); } pieceElt.closePath().end(); valueBound = valueElt.getBBox(); pieceBound = pieceElt.getBBox(); if (piece.value === sum) { valueElt.attr({ x: x0 + (r - 20 - valueBound.width / 2) * Math.cos(-Math.PI / 2), y: y0 + (r - 20 - valueBound.height / 2) * Math.sin(-Math.PI / 2) + 7 }); valueElt.removeStyle('visibility'); } else { valueElt.attr({ x: x0 + (r - 20 - valueBound.width / 2) * Math.cos((startAngle + endAngle) / 2), y: y0 + (r - 20 - valueBound.height / 2) * Math.sin((startAngle + endAngle) / 2) + 7 }); textRect = new Math_Rectangle/* default */.Z(x0 + (r - 20 - valueBound.width / 2) * Math.cos((startAngle + endAngle) / 2) - valueBound.width / 2, y0 + (r - 20 - valueBound.height / 2) * Math.sin((startAngle + endAngle) / 2) + 7 - valueBound.height, valueBound.width, valueBound.height); piePoly = new Polygon/* default */.Z(piePoly); canContain = [textRect.A(), textRect.B(), textRect.C(), textRect.D()].every(function (v) { return piePoly.pointLocalIn(v) > 0; }); if (canContain) { valueElt.removeStyle('visibility'); } else { valueElt.addStyle('visibility', 'hidden'); } } startAngle = endAngle; } var piePound = this.$pie.getBBox(); if (piePound.width < this.$pieCtn.box.width && piePound.height < this.$pieCtn.box.height) { this.$pie.box.setPosition(this.$pieCtn.box.width / 2 - (piePound.width / 2 - (pieCenterBound.x + 1 - piePound.x)), this.$pieCtn.box.height / 2 - (piePound.height / 2 - (pieCenterBound.y + 1 - piePound.y))); break; } } }; DoughnutChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updatePiePosition(); }; DoughnutChart.prototype.normalizeData = function () { var colorScheme = this.colorScheme; this.blockColors = (0,utils.isNaturalNumber)(colorScheme) ? (0,SelectColorSchemeMenu/* generatorColorScheme */.TD)(colorScheme, this.pieces.length) : generateBackgroundColors(this.pieces.length); }; src_VCore.install(DoughnutChart); /* harmony default export */ const src_DoughnutChart = (DoughnutChart); ;// CONCATENATED MODULE: ./src/SimpleColumnChart.js function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } /** * @extends BChart * @constructor */ function SimpleColumnChart() { src_BChart.apply(this, arguments); this.keys = []; this.values = []; this.texts = []; this.fillColors = []; this.$columns = []; this.$texts = []; } OOP/* default.mixClass */.ZP.mixClass(SimpleColumnChart, src_BChart); SimpleColumnChart.tag = 'SimpleColumnChart'.toLowerCase(); SimpleColumnChart.render = function () { return src_BChart.render.apply(this, arguments).addClass('vc-simple-column-chart'); }; SimpleColumnChart.prototype.computeNotes = function () { var _this = this; return this.keys.map(function (key, i) { return { color: _this.fillColors[i], text: key, type: 'rect', idx: i }; }); }; SimpleColumnChart.prototype.normalizeData = function () { var colorScheme = this.colorScheme; var blockColors = (0,utils.isNaturalNumber)(colorScheme) ? (0,SelectColorSchemeMenu/* generatorColorScheme */.TD)(colorScheme, this.values.length) : generateBackgroundColors(this.values.length); this.fillColors = this.fillColors || []; while (this.fillColors.length < this.values.length) { this.fillColors.push(blockColors[this.fillColors.length]); } this._maxValue = Math.max.apply(Math, _toConsumableArray(this.values)); if (!this.texts || this.values.length !== this.texts.length) {// this.texts = this.values.map(value=> this.nu); } }; SimpleColumnChart.prototype._createColumns = function () { var _this2 = this; this.$columns.forEach(function (e) { return e.remove(); }); this.$texts.forEach(function (e) { return e.remove(); }); this.$columns = this.values.map(function (value, i) { return VCore_({ tag: 'rect', attr: { x: 0, y: 0 }, style: { fill: _this2.fillColors[i] } }); }); this.$body.addChild(this.$columns); this.$texts = this.texts.map(function (key, i) { var color = _this2.fillColors[i]; color = typeof color === "string" ? Color/* default.parse */.Z.parse(color) : color; color = color.getContrastYIQ(); return VCore_({ tag: 'text', "class": 'vc-value-text', attr: { x: 10, y: 10 }, style: { color: color + '' }, child: { text: key } }); }); this.$body.addChild(this.$texts); }; SimpleColumnChart.prototype._updateRowPosition = function () { var _this3 = this; var width = this.$body.box.width; var height = this.$body.box.height; if (height === 0) return; var colWidth = Math.min(150, width / this.$columns.length); var x0 = (width - colWidth * this.$columns.length) / 2; var maxValue = this._maxValue ? this._maxValue : 1; this.$columns.forEach(function (colElt, i) { var colHeight = map(_this3.values[i], 0, maxValue, 0, height); colElt.attr({ width: colWidth, y: height - colHeight, height: colHeight, x: x0 + i * colWidth }); }); this.$texts.forEach(function (textElt, i) { var colHeight = map(_this3.values[i], 0, maxValue, 0, height); var y = height - colHeight; if (colHeight > 20) { y += 14; textElt.removeStyle('fill'); } else { y -= 5; textElt.addStyle('fill', 'black'); } textElt.attr({ y: y, x: x0 + (i + 0.5) * colWidth }); }); }; SimpleColumnChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createColumns(); }; SimpleColumnChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updateRowPosition(); }; src_VCore.install(SimpleColumnChart); /* harmony default export */ const src_SimpleColumnChart = (SimpleColumnChart); ;// CONCATENATED MODULE: ./src/SimplerBarChart.js /** * @extends BChart * @constructor */ function SimpleBarChart() { src_BChart.apply(this, arguments); this.keys = []; this.values = []; this.texts = []; this.fillColors = []; this.$rows = []; this.$texts = []; } OOP/* default.mixClass */.ZP.mixClass(SimpleBarChart, src_BChart); SimpleBarChart.tag = 'SimpleBarChart'.toLowerCase(); SimpleBarChart.render = function () { return src_BChart.render.apply(this, arguments).addClass('vc-simple-bar-chart'); }; SimpleBarChart.prototype.computeNotes = src_SimpleColumnChart.prototype.computeNotes; SimpleBarChart.prototype.normalizeData = src_SimpleColumnChart.prototype.normalizeData; SimpleBarChart.prototype._createRows = function () { var _this = this; this.$rows.forEach(function (e) { return e.remove(); }); this.$texts.forEach(function (e) { return e.remove(); }); this.$rows = this.values.map(function (value, i) { return VCore_({ tag: 'rect', attr: { x: 0, y: 0 }, style: { fill: _this.fillColors[i] } }); }); this.$body.addChild(this.$rows); this.$texts = this.texts.map(function (key, i) { var color = _this.fillColors[i]; color = typeof color === "string" ? Color/* default.parse */.Z.parse(color) : color; color = color.getContrastYIQ().toString('hex6'); var res = VCore_({ tag: 'text', "class": 'vc-value-text', attr: { x: 10, y: 10 }, style: { color: color }, child: { text: key } }); return res; }); this.$body.addChild(this.$texts); }; SimpleBarChart.prototype._updateRowPosition = function () { var _this2 = this; var width = this.$body.box.width; var height = this.$body.box.height; if (width === 0) return; var rowHeight = Math.min(150, height / this.$rows.length); var y0 = (height - rowHeight * this.$rows.length) / 2; var maxValue = this._maxValue ? this._maxValue : 1; this.$rows.forEach(function (colElt, i) { var rowWidth = map(_this2.values[i], 0, maxValue, 0, width); colElt.attr({ width: rowWidth, x: 0, height: rowHeight, y: y0 + i * rowHeight }); }); this.$texts.forEach(function (textElt, i) { var rowWidth = map(_this2.values[i], 0, maxValue, 0, width); var box = textElt.getBBox(); var y = y0 + (i + 0.5) * rowHeight + box.height / 2; var x = rowWidth; if (rowWidth > box.width + 10) { textElt.removeStyle('fill'); x -= 5; textElt.addStyle('text-anchor', 'end'); } else { x += 5; textElt.addStyle('text-anchor', 'start'); textElt.addStyle('fill', 'black'); } textElt.attr({ x: x, y: y }); }); }; SimpleBarChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createRows(); }; SimpleBarChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updateRowPosition(); }; src_VCore.install(SimpleBarChart); /* harmony default export */ const SimplerBarChart = (SimpleBarChart); ;// CONCATENATED MODULE: ./src/SimpleLineChart.js function SimpleLineChart_toConsumableArray(arr) { return SimpleLineChart_arrayWithoutHoles(arr) || SimpleLineChart_iterableToArray(arr) || SimpleLineChart_unsupportedIterableToArray(arr) || SimpleLineChart_nonIterableSpread(); } function SimpleLineChart_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function SimpleLineChart_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return SimpleLineChart_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return SimpleLineChart_arrayLikeToArray(o, minLen); } function SimpleLineChart_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function SimpleLineChart_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return SimpleLineChart_arrayLikeToArray(arr); } function SimpleLineChart_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } /** * @extends BChart * @constructor */ function SimpleLineChart() { src_BChart.apply(this, arguments); this.keys = []; this.values = []; this.texts = []; this.fillColors = []; this.$points = []; this.$texts = []; this.$bgRects = []; } OOP/* default.mixClass */.ZP.mixClass(SimpleLineChart, src_BChart); SimpleLineChart.tag = 'SimpleLineChart'.toLowerCase(); SimpleLineChart.render = function () { return src_BChart.render.apply(this, arguments).addClass('vc-simple-column-chart'); }; SimpleLineChart.prototype.computeNotes = function () { var _this = this; return this.keys.map(function (key, i) { return { color: _this.fillColors[i] || 'black', text: key, type: 'point', idx: i }; }); }; SimpleLineChart.prototype.normalizeData = function () { var colorScheme = this.colorScheme; var blockColors = (0,utils.isNaturalNumber)(colorScheme) ? (0,SelectColorSchemeMenu/* generatorColorScheme */.TD)(colorScheme, this.values.length) : generateBackgroundColors(this.values.length); this.fillColors = this.fillColors || []; while (this.fillColors.length < this.values.length) { this.fillColors.push(blockColors[this.fillColors.length]); } this._maxValue = Math.max.apply(Math, SimpleLineChart_toConsumableArray(this.values)); if (!this.texts || this.values.length !== this.texts.length) {// this.texts = this.values.map(value=> this.nu); } }; SimpleLineChart.prototype._createPoints = function () { var _this2 = this; this.$bgRects.forEach(function (elt) { return elt.remove(); }); this.$bgRects = this.values.map(function (u, i) { return VCore_({ tag: 'rect', "class": ['vc-simple-background'], style: { fill: i % 2 ? 'rgba(132, 132, 132, 0.07)' : 'rgba(132, 132, 132, 0.2)' }, on: { mouseenter: function mouseenter(event) { _this2.eventHandler.mouseEnterNote(i, event); }, mouseleave: function mouseleave(event) { _this2.eventHandler.mouseLeaveNote(i, event); } } }); }); this.$body.addChild(this.$bgRects); this.$ox = this.$ox || VCore_({ tag: 'path', "class": ['vc-simple-ox', 'vchart-axis'] }); this.$oxArrow = this.$oxArrow || VCore_({ tag: 'path', "class": ['vchart-axis'], attr: { d: 'm0 -5v10l6.8 -5z' } }); this.$body.addChild(this.$ox); this.$body.addChild(this.$oxArrow); this.$points.forEach(function (e) { return e.remove(); }); this.$texts.forEach(function (e) { return e.remove(); }); this.$points = this.values.map(function (value, i) { return VCore_({ tag: 'circle', attr: { cx: 0, cy: 0, r: 8 }, style: { stroke: 'white', strokeWidth: 2, fill: _this2.fillColors[i], pointerEvents: 'none' } }); }); this.$line = VCore_({ tag: 'path', style: { strokeWidth: 2, stroke: 'rgb(100, 100, 150)', fill: 'none', pointerEvents: 'none' } }); this.$body.addChild(this.$line); this.$body.addChild(this.$points); }; SimpleLineChart.prototype._updatePointPosition = function () { var _this3 = this; var width = this.$body.box.width; var height = this.$body.box.height; if (height === 0) return; var aHeight = height - 10; var aWidth = width - 25; var colWidth = aWidth / this.$points.length; var x0 = 10; var maxValue = this._maxValue ? this._maxValue : 1; this.$ox.attr('d', new controller_Turtle().moveTo(0, height).hLineBy(width).getPath()); this.$oxArrow.attr('transform', translate(width - 3, height)); this.$bgRects.forEach(function (elt, i) { elt.attr({ width: colWidth, height: height, x: x0 + i * colWidth, y: 0 }); }); var linePath = this.values.reduce(function (ac, value, i) { var colHeight = map(_this3.values[i], 0, maxValue, 0, aHeight); if (i) { ac.lineTo(x0 + (i + 0.5) * colWidth, height - colHeight); } else { ac.moveTo(x0 + (i + 0.5) * colWidth, height - colHeight); } return ac; }, new controller_Turtle()).getPath(); this.$line.attr('d', linePath); this.$points.forEach(function (colElt, i) { var colHeight = map(_this3.values[i], 0, maxValue, 0, aHeight); colElt.attr({ cy: height - colHeight, cx: x0 + (i + 0.5) * colWidth }); }); // this.$texts.forEach((textElt, i) => { // var colHeight = map(this.values[i], 0, maxValue, 0, height); // var y = height - colHeight; // if (colHeight > 20) { // y += 14; // textElt.removeStyle('fill'); // } else { // y -= 5; // textElt.addStyle('fill', 'black'); // } // textElt.attr({ // y: y, // x: x0 + (i + 0.5) * colWidth // }); // }); }; SimpleLineChart.prototype.createContent = function () { src_BChart.prototype.createContent.call(this); this._createPoints(); }; SimpleLineChart.prototype.updateBodyPosition = function () { src_BChart.prototype.updateBodyPosition.call(this); this._updatePointPosition(); }; SimpleLineChart.eventHandler = {}; SimpleLineChart.eventHandler.mouseEnterNote = function (idx, event) { var bound = this.$points[idx].getBoundingClientRect(); this.tooltipToken = showTooltip(this.keys[idx] + ': ' + this.texts[idx], bound.right, bound.top); }; SimpleLineChart.eventHandler.mouseLeaveNote = function (idx, event) { var token = this.tooltipToken; if (!token) return; setTimeout(function () { closeTooltip(token); }, 1000); }; src_VCore.install(SimpleLineChart); /* harmony default export */ const src_SimpleLineChart = (SimpleLineChart); ;// CONCATENATED MODULE: ./node_modules/absol/src/Math/Turtle.js /** * @typedef TurtleCommand * @property {String} cmd * @property {String} action * @property {Number[]} args * @property {Vec2} dest * @property {Vec2} tangent */ /*** * * @constructor */ function Turtle_Turtle() { /** * @type {Array<TurtleCommand>} */ this._commands = []; /** * @type {Vec2} */ this._pos = new Vec2/* default */.Z(0, 0); /** * @type {Vec2} */ this._startPos = this._pos; /** * @type {Vec2} */ this._tangent = new Vec2/* default */.Z(0, 0); } /** * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.moveBy = function (dx, dy) { this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._startPos = this._pos; this._commands.push({ cmd: 'm', action: 'moveBy', args: [dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.moveTo = function (x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._startPos = this._pos; this._commands.push({ cmd: 'M', action: 'moveTo', args: [x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * * @param {number} length * @returns {this} */ Turtle_Turtle.prototype.moveForward = function (length) { var dV = this._tangent.normalized().mult(length); this._pos = this._pos.add(dV); this._startPos = this._pos; this._commands.push({ cmd: 'm', action: 'moveTo', args: [dV.x, dV.y], dest: this._pos, tangent: this._tangent }); return this; }; /** * * @param {number} length * @returns {this} */ Turtle_Turtle.prototype.lineForward = function (length) { var dV = this._tangent.normalized().mult(length); this._pos = this._pos.add(dV); this._startPos = this._pos; this._commands.push({ cmd: 'l', action: 'moveTo', args: [dV.x, dV.y], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} angle - degree * @returns {this} */ Turtle_Turtle.prototype.rotateDirTo = function (angle) { this._tangent = Vec2/* default.fromDirection */.Z.fromDirection(angle * Math.PI / 180); return this; }; /*** * * @param {Number} dAngle * @returns {this} */ Turtle_Turtle.prototype.rotateDirBy = function (dAngle) { this._tangent = this._tangent.rotate(dAngle * Math.PI / 180); return this; }; /** * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.lineTo = function (x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'L', action: 'lineTo', args: [x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.lineBy = function (dx, dy) { this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'l', action: 'lineBy', args: [dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @returns {this} */ Turtle_Turtle.prototype.hLineTo = function (x) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, this._pos.y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'H', action: 'hLineTo', args: [x], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} x * @returns {this} */ Turtle_Turtle.prototype.hLineBy = function (x) { this._tangent = new Vec2/* default */.Z(x, 0); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'h', action: 'hLineBy', args: [x], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.vLineTo = function (y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(this._pos.x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'V', action: 'vLineTo', args: [y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.vLineBy = function (y) { this._tangent = new Vec2/* default */.Z(0, y); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'v', action: 'vLineBy', args: [y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c1x * @param {Number} c1y * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.cubicBezierTo = function (c1x, c1y, c2x, c2y, x, y) { this._tangent = new Vec2/* default */.Z(c2x, c2y); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'C', action: 'cubicBezierTo', args: [c1x, c1y, c2x, c2y, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c1dx * @param {Number} c1dy * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.cubicBezierBy = function (c1dx, c1dy, c2dx, c2dy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(c2dx, c2dy)); this._pos = this._pos.add(new Vec2/* default */.Z(dx, dy)); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'c', action: 'cubicBezierBy', args: [c1dx, c1dy, c2dx, c2dy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c2x * @param {Number} c2y * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.smoothCubicBezierTo = function (c2x, c2y, x, y) { this._tangent = new Vec2/* default */.Z(c2x, c2y); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'S', action: 'smoothCubicBezierTo', args: [c2x, c2y, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} c2dx * @param {Number} c2dy * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.smoothCubicBezierBy = function (c2dx, c2dy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(c2dx, c2dy)); this._pos = this._pos.add(new Vec2/* default */.Z(dx, dy)); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 's', action: 'smoothCubicBezierBy', args: [c2dx, c2dy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.quadraticBezierTo = function (cx, cy, x, y) { this._tangent = new Vec2/* default */.Z(cx, cy); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'Q', action: 'quadraticBezierTo', args: [cx, cy, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.quadraticBezierBy = function (cdx, cdy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(cdx, cdy)); this._pos = this._pos.add(new Vec2/* default */.Z(dx, dy)); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'q', action: 'quadraticBezierBy', args: [cdx, cdy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cx * @param {Number} cy * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.smoothQuadraticBezierTo = function (cx, cy, x, y) { this._tangent = new Vec2/* default */.Z(cx, cy); this._pos = new Vec2/* default */.Z(x, y); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'T', action: 'smoothQuadraticBezierTo', args: [cx, cy, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /** * @param {Number} cdx * @param {Number} cdy * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.smoothQuadraticBezierBy = function (cdx, cdy, dx, dy) { this._tangent = this._pos.add(new Vec2/* default */.Z(cdx, cdy)); this._pos = this._pos.add(new Vec2/* default */.Z(dx, dy)); this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 't', action: 'smoothQuadraticBezierBy', args: [cdx, cdy, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} rx * @param {Number} ry * @param {Number} angle * @param {Number} large * @param {Number} sweep * @param {Number} x * @param {Number} y * @returns {this} */ Turtle_Turtle.prototype.arcTo = function (rx, ry, angle, large, sweep, x, y) { this._tangent = this._pos; this._pos = new Vec2/* default */.Z(x, y); var AB = this._pos.sub(this._tangent); //in ellipse var AB_inE = AB.rotate(-angle / 180 * Math.PI); //in circle var AB_inC = new Vec2/* default */.Z(AB_inE.x / rx, AB_inE.y / ry); var AH_inC; var HO_length_inC; var AH_length_inC; var HO_inC; var BO_inC; var tangent_inC; var tangent_inE; AH_inC = AB_inC.div(2); AH_length_inC = AH_inC.abs(); HO_length_inC = Math.sqrt(1 - AH_length_inC * AH_length_inC); if (!sweep !== !large) { HO_inC = AB_inC.rotate90().normalized().mult(HO_length_inC); BO_inC = AH_inC.inv().add(HO_inC); tangent_inC = BO_inC.rotate90().inv(); } else { HO_inC = AB_inC.rotate90().inv().normalized().mult(HO_length_inC);//ok BO_inC = AH_inC.inv().add(HO_inC); tangent_inC = BO_inC.rotate90(); } if (large) tangent_inC = tangent_inC.inv(); tangent_inE = new Vec2/* default */.Z(tangent_inC.x * rx, tangent_inC.y * ry); this._tangent = tangent_inE.rotate(angle / 180 * Math.PI); this._commands.push({ cmd: 'A', action: 'lineTo', args: [rx, ry, angle, large, sweep, x, y], dest: this._pos, tangent: this._tangent }); return this; }; /*** * * @param {Number} rx * @param {Number} ry * @param {Number} angle * @param {Number} large * @param {Number} sweep * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.arcBy = function (rx, ry, angle, large, sweep, dx, dy) { //todo: wrong_tangent this._tangent = new Vec2/* default */.Z(dx, dy); this._pos = this._pos.add(this._tangent); this._commands.push({ cmd: 'a', action: 'arcBy', args: [rx, ry, angle, large, sweep, dx, dy], dest: this._pos, tangent: this._tangent }); return this; }; /** * @returns {this} */ Turtle_Turtle.prototype.closePath = function () { this._tangent = this._pos; this._pos = this._startPos; this._tangent = this._pos.sub(this._tangent); this._commands.push({ cmd: 'z', action: 'closePath', args: [], dest: this._pos }); return this; }; /** * @param {Number} dx * @param {Number} dy * @returns {this} */ Turtle_Turtle.prototype.translate = function (dx, dy) { var command; var deltaVec = new Vec2/* default */.Z(dx, dy); for (var i = 0; i < this._commands.length; ++i) { command = this._commands[i]; command.dest = command.dest.add(deltaVec); switch (command.cmd) { case 'M': case 'L': command.args[0] = command.dest.x; command.args[1] = command.dest.y; break; case 'H': command.args[0] = command.dest.x; break; case 'V': command.args[0] = command.dest.y; break; case 'C': command.args[0] += dx; command.args[1] += dy; command.args[2] += dx; command.args[3] += dy; command.args[4] = command.dest.x; command.args[5] = command.dest.y; break; case 'Q': command.args[0] += dx; command.args[1] += dy; command.args[3] = command.dest.x; command.args[4] = command.dest.y; break; case 'A': command.args[5] = command.dest.x; command.args[6] = command.dest.y; break; } } return this; }; /** * @returns {String} */ Turtle_Turtle.prototype.getPath = function () { return this._commands.map(function (command) { return command.cmd + ' ' + command.args.join(','); }).join(' '); }; /*** * * @returns {this} */ Turtle_Turtle.prototype.reset = function () { this._commands = []; this._pos = new Vec2/* default */.Z(0, 0); this._startPos = this._pos; this._tangent = new Vec2/* default */.Z(0, 0); return this; }; /** * * @returns {Turtle|this} */ Turtle_Turtle.prototype.clone = function () { var Constructor = this.constructor; var res = new Constructor(); res._commands.push.apply(res._commands, this._commands); res._pos = this._pos.copy(); res._startPos = this._startPos.copy(); res._tangent = this._tangent.copy() return res; }; /* harmony default export */ const Math_Turtle = (Turtle_Turtle); // EXTERNAL MODULE: ./node_modules/absol/src/HTML5/DelaySignal.js var DelaySignal = __webpack_require__(8098); ;// CONCATENATED MODULE: ./src/HorizontalRangeChart.js /** * @extends SvgCanvas * @constructor */ function HorizontalRangeChart() { var _this = this; this.resizeCtrl = new ChartResizeController(this); this.titleCtrl = new ChartTitleController(this); this.fixedAxisCtrl = new HRCFixedAxisController(this); this.$attachhook.once('attached', function () { _this.fixedAxisCtrl.start(); _this.updateContent(); }); /** * * @type {KeyNoteGroup} */ this.$keyNoteGroup = VCore_$(KeyNoteGroup.tag, this); this.$title = VCore_$('.vc-title', this); this.$body = VCore_$('.vc-body', this); this.$axis = VCore_$('.vchart-axis', this); this.$oxy = VCore_$('#oxy', this); this.$oxArrow = VCore_$('#ox-arrow', this); this.$oyLabelCtn = VCore_$('.vc-oy-label-ctn', this); this.$oxLabelCtn = VCore_$('.vc-ox-label-ctn', this); this.$rangeCtn = VCore_$('.vc-range-ctn', this); this.$grid = VCore_$('.vc-grid', this); this.$valueName = VCore_$('.vc-value-name', this); this.domSignal = new DelaySignal/* default */.Z(); this.$fixedContentRef = VCore_$('.vc-fixed-content-ref', this); this.domSignal.on({ updateContent: function updateContent() { if (_this.isDescendantOf(document.body)) { _this.fixedAxisCtrl.start(); _this.updateContent(); } } }); (0,DataStructure_Object/* observePropertyChanges */.U)(this, this.dataKeys, function () { if (_this.domSignal) _this.domSignal.emit('updateContent'); }); /** * @name ranges * @type {[]} * @memberof HorizontalRangeChart# */ /** * @name maxText * @type {string} * @memberof HorizontalRangeChart# */ /** * @name valueName * @type {string} * @memberof HorizontalRangeChart# */ /** * @name minText * @type {string} * @memberof HorizontalRangeChart# */ /** * @name midText * @type {string} * @memberof HorizontalRangeChart# */ /** * @name normalText * @type {string} * @memberof HorizontalRangeChart# */ /** * @name zeroOY * @type {boolean} * @memberof HorizontalRangeChart */ } (0,OOP/* mixClass */.Jx)(HorizontalRangeChart, src_BChart); HorizontalRangeChart.tag = 'HorizontalRangeChart'.toLowerCase(); HorizontalRangeChart.render = function (data, o, dom) { var res = VCore_({ tag: svg_SvgCanvas, "class": ['vc-chart', 'vc-horizontal-range-chart', 'as-height-auto'], style: {}, child: [{ tag: 'text', "class": 'vc-title', attr: { 'alignment-baseline': "hanging" }, child: { text: '' } }, { tag: 'rect', "class": 'vc-fixed-content-ref', attr: { width: '10', height: '33' }, style: { fill: 'transparent', stroke: 'none' } }, { tag: KeyNoteGroup }, { tag: 'gcontainer', "class": 'vc-body', child: [{ tag: 'path', "class": 'vc-grid' }, { tag: 'gcontainer', "class": 'vchart-axis', child: [{ tag: 'path', id: 'oxy', attr: { d: 'm0 -1v1 h1', fill: 'none' } }, { tag: 'path', id: "ox-arrow", attr: { d: 'm0 -5v10l6.8 -5z' } }] }, { tag: 'gcontainer', "class": 'vc-oy-label-ctn' }, { tag: 'text', "class": 'vc-value-name', child: { text: '' } }, { tag: 'gcontainer', "class": 'vc-ox-label-ctn' }, { tag: 'gcontainer', "class": 'vc-range-ctn' }] }] }); var colorScheme = o && o.props && o.props.colorScheme; if ((0,utils.isNaturalNumber)(colorScheme)) { colorScheme = Math.max(0, Math.min(SelectColorSchemeMenu/* DEFAULT_CHART_COLOR_SCHEMES.length */.cF.length, colorScheme)); res.attr('data-color-scheme', colorScheme + ''); } return res; }; HorizontalRangeChart.prototype.rowSpacing = 40; HorizontalRangeChart.prototype.plotRadius = 8; HorizontalRangeChart.prototype.rangeHeight = 20; HorizontalRangeChart.prototype.rangeWidth = 3; HorizontalRangeChart.prototype.rangeMaxColor = '#86aeea'; HorizontalRangeChart.prototype.rangeMinColor = '#7ebd3b'; HorizontalRangeChart.prototype.rangeMidColor = 'red'; HorizontalRangeChart.prototype.rangeMidHeight = 26; HorizontalRangeChart.prototype.rangeMidWidth = 5; HorizontalRangeChart.prototype.normalColor = 'rgb(247, 148, 29)'; HorizontalRangeChart.prototype.dataKeys = src_BChart.prototype.dataKeys.concat(['rowSpacing', 'plotRadius', 'rangeHeight', 'ranges', 'rangeWidth', 'rangeMaxColor', 'rangeMinColor', 'rangeMidHeight', 'rangeMidWidth']); HorizontalRangeChart.prototype.numberToString = function () { return Math_int.numberToString.apply(this, arguments); }; HorizontalRangeChart.prototype.addStyle = function (arg0, arg1) { if (arg0 === 'height') { if (arg1 === 'auto') { this.addClass('as-height-auto'); } } else { this.removeClass('as-height-auto'); AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } return this; }; HorizontalRangeChart.prototype.revokeResource = function () { src_BChart.prototype.revokeResource.call(this); this.fixedAxisCtrl.revokeResource(); }; HorizontalRangeChart.prototype.createNote = function () { var items = [{ noteType: 'line', text: this.midText || 'Medium', key: 'mid', color: this.rangeMidColor }, { noteType: 'line', text: this.maxText || 'Maximum', key: 'max', color: this.rangeMaxColor }, { noteType: 'point', text: this.normalText || 'Normal', key: 'normal', color: this.normalColor }]; this.$keyNoteGroup.items = items; }; HorizontalRangeChart.prototype.createOYLabel = function () { var ranges = this.ranges; if (!Array.isArray(ranges)) ranges = []; if (this.$oyLabels) this.$oyLabels.forEach(function (e) { return e.remove(); }); this.$oyLabels = ranges.map(function (it) { return VCore_({ tag: 'text', attr: { 'alignment-baseline': "middle" }, child: { text: it.name } }); }); this.$oyLabelCtn.addChild(this.$oyLabels); }; HorizontalRangeChart.prototype.createRanges = function () { var _this2 = this; var ranges = this.ranges; if (!Array.isArray(ranges)) ranges = []; this.$ranges = ranges.map(function (range) { var elt = VCore_({ tag: 'gcontainer', child: [] }); elt.$line = VCore_({ tag: 'path', style: { stroke: 'rgb(124,124,147)', strokeWidth: 3 } }); elt.addChild(elt.$line); if ((0,utils.isRealNumber)(range.normal)) { elt.$normal = VCore_({ tag: 'circle', attr: { cx: 0, cy: 0, r: _this2.plotRadius, title: _this2.numberToString(range.normal) }, style: { fill: _this2.normalColor, stroke: 'rgb(92, 92, 95)' } }); elt.addChild(elt.$normal); } elt.$min = VCore_({ tag: 'rect', attr: { x: -_this2.rangeWidth / 2, y: -_this2.rangeHeight / 2, width: _this2.rangeWidth, height: _this2.rangeHeight, title: _this2.numberToString(range.min) }, style: { fill: _this2.rangeMinColor, // fill:'black', // fill: 'rgb(72, 72, 75)', stroke: 'none' } }); elt.addChild(elt.$min); if ((0,utils.isRealNumber)(range.mid)) { elt.$mid = VCore_({ tag: svg_GContainer, child: { tag: 'rect', style: { // fill: '#58EBF4', fill: 'red', stroke: 'none' }, attr: { // x: -this.plotRadius / 1.4, // y: -this.plotRadius / 1.4, // width: this.plotRadius / 0.7, height: this.plotRadius / 0.7, width: _this2.rangeMidWidth, height: _this2.rangeMidHeight, x: -_this2.rangeMidWidth / 2, y: -_this2.rangeMidHeight / 2, title: _this2.numberToString(range.mid) // transform:'rotate(45)' } } }); elt.addChild(elt.$mid); } elt.$max = VCore_({ tag: 'rect', style: { fill: _this2.rangeMaxColor, // fill: 'rgb(72, 72, 75)', stroke: 'none' }, attr: { x: -_this2.rangeWidth / 2, y: -_this2.rangeHeight / 2, width: _this2.rangeWidth, height: _this2.rangeHeight, title: _this2.numberToString(range.max) } }); elt.addChild(elt.$max); return elt; }); this.$rangeCtn.clearChild().addChild(this.$ranges); }; HorizontalRangeChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updateContentPosition(); }; HorizontalRangeChart.prototype.updateContentPosition = function () { var _this3 = this; if (!this.$oyLabels) return; var ranges = this.ranges; if (!Array.isArray(ranges)) ranges = []; var i, j; var width = this.box.width || 0; var y = 5; this.$title.attr('x', width / 2).attr('y', y); y += 30; this.$keyNoteGroup.box.width = width - 20; this.$keyNoteGroup.box.x = 10; this.$keyNoteGroup.box.y = y; this.$keyNoteGroup.updateSize(); this.$keyNoteGroup.box.x = width / 2 - this.$keyNoteGroup.getBBox().width / 2; y += (this.$keyNoteGroup.box.height || 0) + 20; this.$body.box.y = y + 24; var oyLabelWidth = this.$oyLabels.reduce(function (ac, cr) { return Math.max(ac, cr.getBBox().width); }, 0); oyLabelWidth = Math.ceil(oyLabelWidth); var spacing = this.rowSpacing; this.$body.box.x = oyLabelWidth + 10; this.$body.box.width = width - this.$body.box.x - 10; this.$fixedContentRef.attr('y', this.$body.box.y - 24); this.$fixedContentRef.attr('width', this.$body.box.width + this.$body.box.x + 8); this.$oyLabelCtn.box.x = -this.$body.box.x; this.$axis.box.width = this.$body.box.width; this.$oxArrow.attr('d', 'M' + this.$axis.box.width + ' 0 m0 -5v10l6.8 -5z'); this.$axis.box.height = spacing * this.$oyLabels.length; /** * * @type {Turtle} */ var turtle = new Math_Turtle().moveTo(this.$axis.box.width, 0).hLineTo(0).vLineTo(this.$axis.box.height); var valueNameWidth = this.$valueName.getBBox().width; this.$valueName.attr('x', this.$axis.box.width).attr('y', -8); var dx = Math.max(100, Math.floor(20 + measureArial14TextWidth(this.numberToString(this.computedData.max)))); var sm = calBeautySegment(Math.floor((this.$axis.box.width - valueNameWidth - 10 - dx / 2) / dx), this.computedData.min, this.computedData.max + 1); this.computedData.sm = sm; dx = Math.floor((this.$axis.box.width - valueNameWidth - 10 - dx / 2) / sm.segmentCount); var dv = (sm.maxValue - sm.minValue) / sm.segmentCount; this.computedData.dx = dx; //for fixed content this.computedData.dv = dv; turtle.moveTo(0, 2); for (i = 0; i < sm.segmentCount; ++i) { turtle.moveBy(dx, -4); turtle.vLineBy(4); } this.$oxy.attr('d', turtle.getPath()); this.$oyLabels.forEach(function (elt, i) { elt.attr('y', i * spacing + spacing / 2); }); while (this.$oxLabelCtn.childNodes.length > sm.segmentCount + 1 && this.$oxLabelCtn.lastChild) { this.$oxLabelCtn.lastChild.remove(); } while (this.$oxLabelCtn.childNodes.length < sm.segmentCount + 1) { this.$oxLabelCtn.addChild(VCore_({ tag: 'text', style: { textAnchor: 'middle' }, attr: { y: -8 }, child: { text: '' } })); } Array.prototype.forEach.call(this.$oxLabelCtn.childNodes, function (elt, i) { elt.firstChild.data = _this3.numberToString(sm.minValue + i * dv); elt.attr('x', dx * i); }); turtle = new Math_Turtle(); var oxLength = this.$axis.box.width - 5; turtle.moveTo(oxLength, 0); for (i = 0; i < ranges.length; ++i) { turtle.moveBy(-oxLength, spacing).hLineBy(oxLength); } turtle.moveTo(0, spacing * ranges.length, 0); for (i = 0; i < sm.segmentCount; ++i) { turtle.moveBy(dx, -spacing * ranges.length).vLineBy(spacing * ranges.length); } this.$grid.attr('d', turtle.getPath()); this.$ranges.forEach(function (elt, i) { elt.box.y = i * spacing + spacing / 2; var range = ranges[i]; elt.$min.attr('x', map(range.min - sm.minValue, 0, dv, 0, dx) - _this3.rangeWidth / 2); if (elt.$mid) elt.$mid.box.x = map(range.mid - sm.minValue, 0, dv, 0, dx); elt.$max.attr('x', map(range.max - sm.minValue, 0, dv, 0, dx) - _this3.rangeWidth / 2); elt.$line.attr('d', "M".concat(map(range.min - sm.minValue, 0, dv, 0, dx), " 0 l").concat(map(range.max - range.min, 0, dv, 0, dx), " 0")); if (elt.$normal) elt.$normal.attr('cx', map(range.normal - sm.minValue, 0, dv, 0, dx)); }); this.$body.box.height = this.$axis.box.height + 10; //10px : padding bottom this.box.height = this.$body.box.y + this.$body.box.height; this.fixedAxisCtrl.updateContentPosition(); }; HorizontalRangeChart.prototype.computeData = function () { var ranges = Array.isArray(this.ranges) ? this.ranges : []; this.computedData = {}; this.computedData.max = ranges.reduce(function (ac, cr) { return Math.max(ac, cr.min, cr.max, cr.mid); }, -Infinity); this.computedData.min = ranges.reduce(function (ac, cr) { return Math.min(ac, cr.min, cr.max, cr.mid); }, Infinity); if (this.zeroOY) this.computedData.min = Math.min(this.computedData.min, 0); }; HorizontalRangeChart.prototype.updateContent = function () { this.computeData(); this.$title.firstChild.data = this.title; this.$valueName.firstChild.data = this.valueName || ''; this.createNote(); this.createOYLabel(); this.createRanges(); this.fixedAxisCtrl.updateContent(); this.updateContentPosition(); }; src_VCore.install(HorizontalRangeChart); /* harmony default export */ const src_HorizontalRangeChart = (HorizontalRangeChart); /** * * @param {HorizontalRangeChart|SvgCanvas}elt * @constructor */ function HRCFixedAxisController(elt) { this.elt = elt; this.state = 'PENDING'; this.listenningElementList = []; this.ev_scroll = this.ev_scroll.bind(this); this.$canvas = null; } HRCFixedAxisController.prototype.start = function () { if (this.state !== 'PENDING') return; this.state = "RUNNING"; var elt = this.elt.parentElement; while (elt) { elt.addEventListener('scroll', this.ev_scroll); this.listenningElementList.push(elt); elt = elt.parentElement; } elt = document; elt.addEventListener('scroll', this.ev_scroll); this.listenningElementList.push(elt); this.$canvas = VCore_({ tag: svg_SvgCanvas.tag, "class": 'vc-chart', style: { pointerEvents: 'none', minHeight: 'unset', position: 'fixed', zIndex: (0,utils.findMaxZIndex)(this.elt) + 100, left: 0, top: 0, visibility: 'hidden', height: '33px', backgroundColor: 'transparent' }, child: [{ tag: 'path', "class": 'vc-fixed-axis-bg', style: { pointerEvents: 'all', fill: 'white', stroke: 'none' } }, { tag: 'gcontainer', "class": 'vc-body', child: [{ tag: 'gcontainer', "class": 'vc-ox-label-ctn' }, { tag: 'text', "class": 'vc-value-name', child: { text: '' } }, { tag: 'gcontainer', "class": 'vchart-axis', child: [{ tag: 'path', id: 'oxy', attr: { d: 'm0 -1v1 h1', fill: 'none' } }, { tag: 'path', id: "ox-arrow", attr: { d: 'm0 -5v10l6.8 -5z' } }] }] }] }).addTo(this.elt.parentElement); this.$bg = VCore_$('.vc-fixed-axis-bg', this.$canvas); this.$body = VCore_$('.vc-body', this.$canvas); this.$axis = VCore_$('.vchart-axis', this.$canvas); this.$oxy = VCore_$('#oxy', this.$canvas); this.$oxArrow = VCore_$('#ox-arrow', this.$canvas); this.$body.box.y = 25; this.$oxLabelCtn = VCore_$('.vc-ox-label-ctn', this.$canvas); this.$valueName = VCore_$('.vc-value-name', this.$canvas); }; HRCFixedAxisController.prototype.stop = function () { if (this.state !== 'RUNNING') return; this.state = "STOPPED"; var elt; while (this.listenningElementList.length > 0) { elt = this.listenningElementList.pop(); elt.removeEventListener('scroll', this.ev_scroll); } this.$canvas.remove(); }; HRCFixedAxisController.prototype.revokeResource = function () { this.revokeResource = noop/* default */.Z; this.stop(); this.elt = null; this.revokeResource = noop/* default */.Z; }; HRCFixedAxisController.prototype.updateContent = function () { this.$valueName.firstChild.data = this.elt.valueName || ''; }; HRCFixedAxisController.prototype.updateContentPosition = function () { var _this4 = this; if (this.state !== "RUNNING") return; var i; if (!this.elt.computedData) return; var sm = this.elt.computedData.sm; var dx = this.elt.computedData.dx; var dv = this.elt.computedData.dv; var width = parseFloat(this.elt.$fixedContentRef.attr('width')); var height = parseFloat(this.elt.$fixedContentRef.attr('height')); this.$canvas.addStyle({ width: width + 'px', height: height + 1 + 'px' }); this.$canvas.box.setSize(width, height); this.$body.box.x = this.elt.$body.box.x; this.$axis.box.x = this.elt.$axis.box.x; this.$oxArrow.attr('d', 'M' + this.elt.$axis.box.width + ' 0 m0 -5v10l6.8 -5z'); this.$valueName.attr('x', this.elt.$axis.box.width).attr('y', -8); var turtle = new Math_Turtle().moveTo(this.elt.$axis.box.width, 0).hLineTo(0).vLineTo(10); turtle.moveTo(0, 2); for (i = 0; i < sm.segmentCount; ++i) { turtle.moveBy(dx, -4); turtle.vLineBy(4); } this.$oxy.attr('d', turtle.getPath()); while (this.$oxLabelCtn.childNodes.length > sm.segmentCount + 1 && this.$oxLabelCtn.lastChild) { this.$oxLabelCtn.lastChild.remove(); } while (this.$oxLabelCtn.childNodes.length < sm.segmentCount + 1) { this.$oxLabelCtn.addChild(VCore_({ tag: 'text', style: { textAnchor: 'middle' }, attr: { y: -8 }, child: { text: '' } })); } Array.prototype.forEach.call(this.$oxLabelCtn.childNodes, function (elt, i) { elt.firstChild.data = _this4.elt.numberToString(sm.minValue + i * dv); elt.attr('x', dx * i); }); turtle = new Math_Turtle(); turtle.moveTo(width, 0).vLineTo(height).hLineBy(-8).vLineBy(-9).hLineTo(0).vLineTo(0).closePath(); this.$bg.attr('d', turtle.getPath()); this.updateDomPosition(); }; HRCFixedAxisController.prototype.updateDomPosition = function () { var outBound = (0,Dom/* traceOutBoundingClientRect */.DI)(this.elt); var refBound = this.elt.$fixedContentRef.getBoundingClientRect(); var bound = this.elt.getBoundingClientRect(); var hidden = false; hidden = hidden || bound.bottom < outBound.top + refBound.height + 5; hidden = hidden || refBound.top > outBound.top; if (hidden) { this.$canvas.addStyle('visibility', 'hidden'); } else { this.$canvas.removeStyle('visibility'); this.$canvas.addStyle({ left: refBound.left - 0.5 + 'px', top: Math.max(refBound.top, outBound.top) - 1.5 + 'px' }); } }; HRCFixedAxisController.prototype.ev_scroll = function () { if (this.elt.isDescendantOf(document.body)) { this.updateDomPosition(); } else { this.stop(); this.revokeResource(); } }; ;// CONCATENATED MODULE: ./src/HorizontalRankChart.js function HorizontalRankChart_toConsumableArray(arr) { return HorizontalRankChart_arrayWithoutHoles(arr) || HorizontalRankChart_iterableToArray(arr) || HorizontalRankChart_unsupportedIterableToArray(arr) || HorizontalRankChart_nonIterableSpread(); } function HorizontalRankChart_nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function HorizontalRankChart_unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return HorizontalRankChart_arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return HorizontalRankChart_arrayLikeToArray(o, minLen); } function HorizontalRankChart_iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function HorizontalRankChart_arrayWithoutHoles(arr) { if (Array.isArray(arr)) return HorizontalRankChart_arrayLikeToArray(arr); } function HorizontalRankChart_arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } /** * @extends SvgCanvas * @constructor */ function HorizontalRankChart() { var _this = this; this.resizeCtrl = new ChartResizeController(this); this.titleCtrl = new ChartTitleController(this); this.fixedAxisCtrl = new HRCFixedAxisController(this); this.$attachhook.once('attached', function () { _this.fixedAxisCtrl.start(); _this.updateContent(); }); this.$title = VCore_$('.vc-title', this); this.$body = VCore_$('.vc-body', this); this.$axis = VCore_$('.vchart-axis', this); this.$oxy = VCore_$('#oxy', this); this.$oxArrow = VCore_$('#ox-arrow', this); this.$oyLabelCtn = VCore_$('.vc-oy-label-ctn', this); this.$oxLabelCtn = VCore_$('.vc-ox-label-ctn', this); this.$grid = VCore_$('.vc-grid', this); this.$valueName = VCore_$('.vc-value-name', this); this.$postionCtn = VCore_$('.vc-postion-ctn', this); this.$fixedContentRef = VCore_$('.vc-fixed-content-ref', this); this.$oyLabels = []; this.cpData = null; this.colors = ['white', 'rgb(201, 241, 253)', 'rgb(212, 227, 252)', 'rgb(218, 202, 251)', 'rgb(242, 201, 251)', 'rgb(255, 218, 216)', 'rgb(255, 236, 215)', 'rgb(254, 252, 224)', 'rgb(223, 237, 214)', 'rgb(77, 215, 250)', 'rgb(117, 169, 249)', 'rgb(139, 81, 245)', 'rgb(215, 87, 246)', 'rgb(255, 138, 132)', 'rgb(152, 165, 52)', 'rgb(254, 248, 160)', 'rgb(174, 221, 148)', 'rgb(0, 164, 221)', 'rgb(20, 100, 246)', 'rgb(156, 41, 183)']; this.domSignal = new DelaySignal/* default */.Z(); this.domSignal.on('updateContent', function () { if (_this.isDescendantOf(document.body)) { _this.fixedAxisCtrl.start(); _this.updateContent(); } }); (0,OOP/* drillProperty */.pj)(this, this, 'computedData', 'cpData'); (0,DataStructure_Object/* observePropertyChanges */.U)(this, this.dataKeys, function () { return _this.domSignal.emit('updateContent'); }); /** * @name positions * @type {{name: string, ranks:number[]}[]} * @memberof HorizontalRankChart# */ /** * @name valueName * @type {string} * @memberof HorizontalRangeChart# */ } HorizontalRankChart.tag = 'HorizontalRankChart'.toLowerCase(); HorizontalRankChart.render = function (data, o, dom) { var res = VCore_({ tag: svg_SvgCanvas, "class": ['vc-chart', 'vc-horizontal-rank-chart', 'as-height-auto'], style: {}, child: [{ tag: 'text', "class": 'vc-title', attr: { 'alignment-baseline': "hanging" }, child: { text: '' } }, { tag: 'rect', "class": 'vc-fixed-content-ref', attr: { width: '10', height: '33' }, style: { fill: 'transparent', stroke: 'none' } }, { tag: KeyNoteGroup }, { tag: 'gcontainer', "class": 'vc-body', child: [{ tag: 'path', "class": 'vc-grid' }, { tag: 'gcontainer', "class": 'vchart-axis', child: [{ tag: 'path', id: 'oxy', attr: { d: 'm0 -1v1 h1', fill: 'none' } }, { tag: 'path', id: "ox-arrow", attr: { d: 'm0 -5v10l6.8 -5z' } }] }, { tag: 'text', "class": 'vc-value-name', child: { text: '' } }, { tag: 'gcontainer', "class": 'vc-oy-label-ctn' }, { tag: 'gcontainer', "class": 'vc-ox-label-ctn' }, { tag: 'gcontainer', "class": 'vc-postion-ctn' }] }] }); var colorScheme = o && o.props && o.props.colorScheme; if ((0,utils.isNaturalNumber)(colorScheme)) { colorScheme = Math.max(0, Math.min(SelectColorSchemeMenu/* DEFAULT_CHART_COLOR_SCHEMES.length */.cF.length, colorScheme)); res.attr('data-color-scheme', colorScheme + ''); } return res; }; HorizontalRankChart.prototype.dataKeys = src_BChart.prototype.dataKeys.concat(['position', 'valueName']); HorizontalRankChart.prototype.revokeResource = function () { (0,DataStructure_Object/* unobservePropertyChanges */.i3)(this, this.dataKeys); (0,utils.revokeResource)(this.titleCtrl); (0,utils.revokeResource)(this.resizeCtrl); (0,utils.revokeResource)(this.domSignal); this.fixedAxisCtrl.revokeResource(); while (this.lastChild) { this.lastChild.remove(); } }; HorizontalRankChart.prototype.addStyle = function (arg0, arg1) { if (arg0 === 'height') { if (arg1 === 'auto') { this.addClass('as-height-auto'); } } else { this.removeClass('as-height-auto'); AElement/* default.prototype.addStyle.apply */.Z.prototype.addStyle.apply(this, arguments); } return this; }; HorizontalRankChart.prototype.computeData = function () { var positions = Array.isArray(this.positions) ? this.positions : []; this.cpData = {}; this.cpData.min = positions.reduce(function (ac, cr) { return Math.min.apply(Math, [ac].concat(HorizontalRankChart_toConsumableArray(cr.ranks))); }, Infinity); this.cpData.count = positions.reduce(function (ac, cr) { return Math.max(ac, cr.ranks.length); }, 0); this.cpData.max = positions.reduce(function (ac, cr) { return Math.max.apply(Math, [ac].concat(HorizontalRankChart_toConsumableArray(cr.ranks))); }, -Infinity); if (this.cpData.min > this.cpData.max) { this.cpData.min = 0; this.cpData.max = 0; } this.cpData.max += 1; if (this.zeroOY) this.cpData.min = Math.min(this.cpData.min, 0); this.colors = this.cpData.count < 10 ? ["#FF5733", // Bright Orange "#33FF57", // Bright Green "#3357FF", // Bright Blue "#FF33A8", // Bright Pink "#FF3333", // Bright Red "#33FFF5", // Bright Cyan "#FFFF33", // Bright Yellow "#FF8C33", // Bright Coral "#33FF8C", // Bright Mint "#8C33FF" // Bright Purple ] : ["#FF5733", // Bright Orange "#33FF57", // Bright Green "#3357FF", // Bright Blue "#FF33A8", // Bright Pink "#FF3333", // Bright Red "#33FFF5", // Bright Cyan "#FFFF33", // Bright Yellow "#FF8C33", // Bright Coral "#33FF8C", // Bright Mint "#8C33FF", // Bright Purple "#FF5733", // Bright Orange "#33FF57", // Bright Green "#3357FF", // Bright Blue "#FF33A8", // Bright Pink "#FF3333", // Bright Red "#33FFF5", // Bright Cyan "#FFFF33", // Bright Yellow "#FF8C33", // Bright Coral "#33FF8C", // Bright Mint "#8C33FF" // Bright Purple ]; }; HorizontalRankChart.prototype.createOYLabel = function () { var positions = Array.isArray(this.positions) ? this.positions : []; this.$oyLabels = positions.map(function (it) { return VCore_({ tag: 'text', attr: { 'alignment-baseline': "middle" }, child: { text: it.name } }); }); this.$oyLabelCtn.addChild(this.$oyLabels); }; HorizontalRankChart.prototype.createPositions = function () { var _this2 = this; var positions = Array.isArray(this.positions) ? this.positions : []; this.$position = positions.map(function (it) { var elt = VCore_({ tag: 'gcontainer' }); elt.$line = VCore_({ tag: 'path', style: { stroke: 'rgb(69, 69, 72)', 'stroke-width': 3 } }); elt.addChild(elt.$line); elt.$ranks = it.ranks.map(function (r, i) { return VCore_({ tag: 'gcontainer', "class": 'rank-chart-group', attr: { title: _this2.numberToString(r) }, child: [{ tag: 'circle', "class": 'vc-circle-plot', style: { fill: _this2.colors[i], stroke: 'black', strokeWidth: 2 }, attr: { r: 8, x: 0, y: 0 } }] }); }); elt.addChild(elt.$ranks); return elt; }); this.$postionCtn.clearChild().addChild(this.$position); }; HorizontalRankChart.prototype.updateContentPosition = function () { var _this3 = this; if (!this.cpData) return; var i, j; var width = this.box.width || 0; var positions = Array.isArray(this.positions) ? this.positions : []; var y = 5; this.$title.attr('x', width / 2).attr('y', y); y += 30; var oyLabelWidth = this.$oyLabels.reduce(function (ac, cr) { return Math.max(ac, cr.getBBox().width); }, 0); oyLabelWidth = Math.ceil(oyLabelWidth); var spacing = 40; this.$body.box.y = y + 24; this.$body.box.x = oyLabelWidth + 10; this.$body.box.width = width - this.$body.box.x - 10; this.$oyLabelCtn.box.x = -this.$body.box.x; this.$axis.box.width = this.$body.box.width; this.$oxArrow.attr('d', 'M' + this.$axis.box.width + ' 0 m0 -5v10l6.8 -5z'); this.$axis.box.height = spacing * this.$oyLabels.length; var valueNameWidth = this.$valueName.getBBox().width; this.$valueName.attr('x', this.$axis.box.width).attr('y', -8); this.$fixedContentRef.attr('y', this.$body.box.y - 24); this.$fixedContentRef.attr('width', this.$body.box.width + this.$body.box.x + 8); /** * * @type {Turtle} */ var turtle = new Math_Turtle().moveTo(this.$axis.box.width, 0).hLineTo(0).vLineTo(this.$axis.box.height); var dx = Math.max(100, Math.floor(20 + measureArial14TextWidth(this.numberToString(this.cpData.max)))); var sm = calBeautySegment(Math.floor((this.$axis.box.width - valueNameWidth - 10 - dx / 2) / dx), this.cpData.min, this.cpData.max + 1); this.cpData.sm = sm; dx = Math.floor((this.$axis.box.width - valueNameWidth - 10 - dx / 2) / sm.segmentCount); var dv = (sm.maxValue - sm.minValue) / sm.segmentCount; this.cpData.dx = dx; this.cpData.dv = dv; turtle.moveTo(0, 2); for (i = 0; i < sm.segmentCount; ++i) { turtle.moveBy(dx, -4); turtle.vLineBy(4); } this.$oxy.attr('d', turtle.getPath()); this.$oyLabels.forEach(function (elt, i) { elt.attr('y', i * spacing + spacing / 2); }); while (this.$oxLabelCtn.childNodes.length > sm.segmentCount + 1) { this.$oxLabelCtn.lastChild.remove(); } while (this.$oxLabelCtn.childNodes.length < sm.segmentCount + 1) { this.$oxLabelCtn.addChild(VCore_({ tag: 'text', style: { textAnchor: 'middle' }, attr: { y: -8 }, child: { text: '' } })); } Array.prototype.forEach.call(this.$oxLabelCtn.childNodes, function (elt, i) { elt.firstChild.data = _this3.numberToString(sm.minValue + i * dv); elt.attr('x', dx * i); }); /***** draw grid *******/ turtle = new Math_Turtle(); var oxLength = this.$axis.box.width - 5; turtle.moveTo(oxLength, 0); for (i = 0; i < positions.length; ++i) { turtle.moveBy(-oxLength, spacing).hLineBy(oxLength); } turtle.moveTo(0, spacing * positions.length, 0); for (i = 0; i < sm.segmentCount; ++i) { turtle.moveBy(dx, -spacing * positions.length).vLineBy(spacing * positions.length); } this.$grid.attr('d', turtle.getPath()); this.$position.forEach(function (elt, i) { elt.box.y = i * spacing + spacing / 2; var position = positions[i]; for (var k = 0; k < position.ranks.length; ++k) { elt.$ranks[k].box.x = map(position.ranks[k] - sm.minValue, 0, dv, 0, dx); } if (position.ranks.length > 0) elt.$line.attr('d', "M".concat(map(position.ranks[0] - sm.minValue, 0, dv, 0, dx), " 0 L").concat(map(position.ranks[position.ranks.length - 1] - sm.minValue, 0, dv, 0, dx), " 0")); }); //auto size this.$body.box.height = this.$axis.box.height + 10; //10px: padding button this.box.height = this.$body.box.y + this.$body.box.height; this.fixedAxisCtrl.updateContentPosition(); }; HorizontalRankChart.prototype.numberToString = function () { return Math_int.numberToString.apply(this, arguments); }; HorizontalRankChart.prototype.updateContent = function () { this.computeData(); this.$title.firstChild.data = this.title; this.$valueName.firstChild.data = this.valueName || ''; this.createOYLabel(); this.createPositions(); this.fixedAxisCtrl.updateContent(); this.updateContentPosition(); }; HorizontalRankChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updateContentPosition(); }; src_VCore.install(HorizontalRankChart); /* harmony default export */ const src_HorizontalRankChart = (HorizontalRankChart); // EXTERNAL MODULE: ./src/style/stackedhorizontalbarchart.css var stackedhorizontalbarchart = __webpack_require__(7399); ;// CONCATENATED MODULE: ./src/StackedHorizontalBarChart.js /** * @extends SvgCanvas * @constructor */ function StackedHorizontalBarChart() { this.resizeCtrl = new ChartResizeController(this); this.titleCtrl = new ChartTitleController(this); this.computedData = { max: 0 }; this.$title = VCore_$('text.vc-title', this); /** * * @type {GContainer} */ this.$keysCtn = VCore_$('g.vc-stacked-horizontal-keys-ctn', this); /** * * @type {GContainer} */ this.$body = VCore_$('.vc-body', this); this.$keys = []; this.$oxy = VCore_$('#oxy', this); this.$oxArrow = VCore_$('#ox-arrow', this); this.$grid = VCore_$('path.vc-grid', this); this.$rects = []; /** * * @type {KeyNoteGroup} */ this.$keyNoteGroup = VCore_$(KeyNoteGroup.tag, this); /** * y axis keys * @name keys * @type {string[]} * @memberOf StackedHorizontalBarChart# */ /** * series data * @name series * @type {Array<{name: string, values: number[]}>} * @memberOf StackedHorizontalBarChart# */ } StackedHorizontalBarChart.tag = 'StackedHorizontalBarChart'.toLowerCase(); StackedHorizontalBarChart.prototype.rowSpacing = 40; StackedHorizontalBarChart.prototype.paddingContent = 10; StackedHorizontalBarChart.prototype.numberToString = function () { return Math_int.numberToString.apply(this, arguments); }; StackedHorizontalBarChart.render = function () { return VCore_({ tag: svg_SvgCanvas, "class": ['vc-chart', 'vc-stacked-horizontal-bar-chart', 'as-height-auto'], child: [{ tag: 'text', "class": 'vc-title', attr: { y: 15 }, child: { text: '' } }, { tag: KeyNoteGroup }, { tag: svg_GContainer, "class": 'vc-body', child: [{ tag: svg_GContainer, "class": 'vc-stacked-horizontal-keys-ctn' }, { tag: 'path', "class": 'vc-grid' }, { tag: 'gcontainer', "class": 'vchart-axis', child: [{ tag: 'path', id: 'oxy', attr: { d: 'm0 -1v1 h1', fill: 'none' } }, { tag: 'path', id: "ox-arrow", attr: { d: 'm0 -5v10l6.8 -5z' } }] }] }] }); }; StackedHorizontalBarChart.prototype.computeData = function () { var _this = this; var cpData = this.computedData; cpData.max = this.keys.reduce(function (ac, cr, i) { var s = _this.series.reduce(function (ac2, cr2) { var value = cr2.values[i]; if (!(0,utils.isRealNumber)(value)) value = 0; return ac2 + value; }, 0); return Math.max(ac, s); }, 0); if (cpData.max === 0) { cpData.max = 1; // prevent division by zero } cpData.min = 0; cpData.requiredWidth = 0; cpData.requiredWidth = Math.max(cpData.requiredWidth, cpData.titleWidth); cpData.colors = (0,SelectColorSchemeMenu/* generatorColorScheme */.TD)(1, this.series.length || 10); this.addStyle('--vc-required-width', cpData.requiredWidth + 'px'); }; StackedHorizontalBarChart.prototype.updateKeys = function () { var keys = this.keys || []; this.$keysCtn.clearChild(); this.$keys = this.keys.map(function (key) { return VCore_({ tag: 'text', child: { text: key } }); }); this.$keysCtn.addChild(this.$keys); }; StackedHorizontalBarChart.prototype.updateNotes = function () { var _this2 = this; this.$keyNoteGroup.items = this.series.map(function (it, i) { return { noteType: 'rect', text: it.name, color: it.color || _this2.computedData.colors[i] }; }); }; StackedHorizontalBarChart.prototype.updateKeysPosition = function () { var _this3 = this; this.$keys.forEach(function (elt, i) { elt.attr('y', _this3.rowSpacing * (0.5 + i) + 7); }); this.$keysCtn.box.width = this.$keysCtn.getBBox().width; this.$keysCtn.box.x = -this.$keysCtn.box.width - 10; }; StackedHorizontalBarChart.prototype.updateAxisPosition = function () { var turtle = new Math_Turtle(); turtle.moveTo(this.$body.box.width + 10, 0).hLineBy(-this.$body.box.width - 10).vLineBy(this.$body.box.height); this.$oxy.attr('d', turtle.getPath()); this.$oxArrow.attr('d', 'M' + (this.$body.box.width + 10) + ' 0 m0 -5v10l6.8 -5z'); turtle = new Math_Turtle(); var i; var n = this.keys.length; var spacing = this.rowSpacing; var width = this.$body.box.width; var height = this.$body.box.height; for (i = 1; i <= n; ++i) { turtle.moveTo(0, i * spacing).hLineBy(width); } var valueWidth = 30; var dx = Math.max(100, Math.floor(20 + measureArial14TextWidth(this.numberToString(this.computedData.max)))); var sm = calBeautySegment(Math.floor((this.$body.box.width - valueWidth - 10 - dx / 2) / dx), this.computedData.min, this.computedData.max + 1); this.computedData.sm = sm; dx = Math.floor((width - valueWidth - 10 - dx / 2) / sm.segmentCount); n = sm.segmentCount; for (i = 1; i <= n; ++i) { turtle.moveTo(i * dx, 0).vLineBy(height); } this.$grid.attr('d', turtle.getPath()); }; StackedHorizontalBarChart.prototype.makeRect = function (value, color, borderColor) { color = Color/* default.parse */.Z.parse(color + ''); var hsla; if (!borderColor) { hsla = color.toHSLA(); hsla[2] -= 0.2; hsla[1] -= 0.2; if (hsla[1] < 0) hsla[1] = 0; if (hsla[2] < 0) hsla[2] = 0; borderColor = Color/* default.fromHSL */.Z.fromHSL(hsla[0], hsla[1], hsla[2]); } var height = Math.min(20, this.rowSpacing - 10); var valueText = this.numberToString(value); var rectElt = VCore_({ tag: svg_GContainer, child: [{ tag: 'rect', attr: { x: 0, y: -height / 2, height: height, width: 40 }, style: { strokeWidth: 1, strokeColor: 'black', fill: color, stroke: borderColor.toString('hex6') } }, { tag: 'text', style: { fill: color.getContrastYIQ() }, attr: { x: 0, y: 0, "text-anchor": "middle", 'dominant-baseline': "middle" }, child: { text: valueText } }] }); rectElt.$rect = VCore_$('rect', rectElt); rectElt.$value = VCore_$('text', rectElt); rectElt.textWidth = TextMeasure/* default.measureWidth */.Z.measureWidth(valueText, TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14); return rectElt; }; StackedHorizontalBarChart.prototype.updateRectangles = function () { this.$rects.forEach(function (elt) { return elt.remove(); }); this.$rects = []; var keys = this.keys || []; var series = this.series || []; var rectElt; var i, j; for (i = 0; i < keys.length; ++i) { for (j = 0; j < series.length; ++j) { rectElt = this.makeRect(series[j].values[i], series[i].color || this.computedData.colors[j]); this.$rects.push(rectElt); } } this.$body.addChild(this.$rects); }; StackedHorizontalBarChart.prototype.updateRectanglePositions = function () { var sm = this.computedData.sm; var keys = this.keys || []; var series = this.series || []; var rectElt; var i, j, k; k = 0; var value, rectWidth; var width = this.$body.box.width; var s; for (i = 0; i < keys.length; ++i) { s = 0; for (j = 0; j < series.length; ++j) { value = series[j].values[i]; rectWidth = map(value, sm.minValue, sm.maxValue, 0, width); rectElt = this.$rects[k]; k++; if (!rectElt) continue; rectElt.$rect.attr('width', rectWidth); rectElt.$value.attr('x', rectWidth / 2); rectElt.box.x = map(s, sm.minValue, sm.maxValue, 0, width); rectElt.box.y = this.rowSpacing * (0.5 + i); if (rectElt.textWidth > rectWidth - 4) { rectElt.$value.addStyle('display', 'none'); rectElt.attr('title', this.numberToString(value)); } else { rectElt.$value.removeStyle('display'); } s += value; } } }; StackedHorizontalBarChart.prototype.updateContent = function () { this.pendingUpdate = false; this.computeData(); this.updateKeys(); this.updateNotes(); this.updateRectangles(); }; StackedHorizontalBarChart.prototype.requestUpdate = function () { var _this4 = this; if (this.pendingUpdate) return; this.pendingUpdate = true; setTimeout(function () { _this4.updateContent(); _this4.updateContentPosition(); }, 1); }; StackedHorizontalBarChart.prototype.updateContentPosition = function () { this.$title.attr('y', this.paddingContent + 17 + ''); this.$title.attr('x', this.box.width / 2 + ''); this.updateKeysPosition(); this.$body.box.x = this.$keysCtn.box.width + this.paddingContent + 10; this.$body.box.width = this.box.width - this.paddingContent - this.$body.box.x - 20; //10 for arrow this.$keyNoteGroup.box.y = 20 + 10 + this.paddingContent; this.$keyNoteGroup.box.width = this.$body.box.width - 20; this.$keyNoteGroup.updateSize(); this.$body.box.y = this.$keyNoteGroup.box.y + this.$keyNoteGroup.box.height + 10; this.$body.box.height = this.rowSpacing * this.keys.length; this.updateAxisPosition(); this.updateRectanglePositions(); this.box.height = this.$body.box.height + this.$body.box.y + this.paddingContent; this.addStyle('--vc-require-height', this.box.height); }; StackedHorizontalBarChart.prototype.updateSize = function () { svg_SvgCanvas.prototype.updateSize.call(this); this.updateContentPosition(); }; StackedHorizontalBarChart.property = {}; StackedHorizontalBarChart.property.title = { set: function set(value) { this.$title.firstChild.data = (value || '') + ''; this.computedData.titleWidth = TextMeasure/* default.measureWidth */.Z.measureWidth(this.$title.firstChild.data, TextMeasure/* default.FONT_ARIAL */.Z.FONT_ARIAL, 14); }, get: function get() { return this.$title.firstChild.data; } }; StackedHorizontalBarChart.property.series = { set: function set(value) { this._series = value || []; this.requestUpdate(); }, get: function get() { return this._series || []; } }; StackedHorizontalBarChart.property.keys = { set: function set(value) { this._keys = value || []; this.requestUpdate(); }, get: function get() { return this._keys || []; } }; src_VCore.install(StackedHorizontalBarChart); /* harmony default export */ const src_StackedHorizontalBarChart = (StackedHorizontalBarChart); ;// CONCATENATED MODULE: ./src/install.js var VChartCreators = [src_BChart, src_VerticalChart, src_PieChart, src_AssessmentChart, src_ColumnChart, src_ColumnAreaChart, src_TinyCircleChart, src_DoughnutChart, src_SimpleColumnChart, SimplerBarChart, src_SimpleLineChart, src_HorizontalRangeChart, src_HorizontalRankChart, src_StackedHorizontalBarChart, LineChart2]; /*** * * @param {Dom} core */ function install_install(core) { core.install(VChartCreators); } ;// CONCATENATED MODULE: ./src/index.js install_install(src_VCore); src_VCore.install(SelectColorSchemeMenu/* default */.ZP); absol.Dom.ShareInstance.install(SelectColorSchemeMenu/* default */.ZP); var src_vchart = { core: src_VCore, creator: src_VCore.creator, _: src_VCore._, $: src_VCore.$, buildSvg: src_VCore._, lambda: { isNumber: isNumber, toLocalString: toLocalString }, text: helper_text, circle: circle, rect: rect, vline: vline, hline: hline, moveVLine: moveVLine, moveHLine: moveHLine, autoCurve: autoCurve, showTooltip: showTooltip, closeTooltip: closeTooltip, addDevContextMenu: addDevContextMenu }; /* harmony default export */ const src = (src_vchart); ;// CONCATENATED MODULE: ./src/vchart.js Object.assign(src, helper_namespaceObject); src.tl = template_namespaceObject; if ('absol' in window) { if (absol.coreDom) { absol.coreDom.install(Object.keys(src.creator).filter(function (e) { return !!e.match(/.+chart/); }).reduce(function (ac, cr) { ac[cr] = src.creator[cr]; return ac; }, {})); install_install(absol.coreDom); } else { console.error("coreDom not found"); } } window.vchart = src; })(); /******/ })() ;